From: Stefan Metzmacher Date: Fri, 29 Nov 2019 12:47:16 +0000 (+0100) Subject: lib/krb5_wrap: prefer new enctyptes in ms_suptypes_to_ietf_enctypes() X-Git-Tag: ldb-2.1.1~112 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=0be5505942917c068c5996c02c4772c40c072dba;p=thirdparty%2Fsamba.git lib/krb5_wrap: prefer new enctyptes in ms_suptypes_to_ietf_enctypes() This is currently not critical as we only use keytabs only as acceptor, but in future we'll also use them for kinit() and there we should prefer the newest type. Signed-off-by: Stefan Metzmacher Reviewed-by: Andreas Schneider --- diff --git a/lib/krb5_wrap/enctype_convert.c b/lib/krb5_wrap/enctype_convert.c index a658911190a..4a644358c17 100644 --- a/lib/krb5_wrap/enctype_convert.c +++ b/lib/krb5_wrap/enctype_convert.c @@ -83,13 +83,17 @@ krb5_error_code ms_suptypes_to_ietf_enctypes(TALLOC_CTX *mem_ctx, uint32_t enctype_bitmap, krb5_enctype **enctypes) { - unsigned int i, j = 0; + size_t max_bits = 8 * sizeof(enctype_bitmap); + size_t j = 0; + ssize_t i; + *enctypes = talloc_zero_array(mem_ctx, krb5_enctype, - (8 * sizeof(enctype_bitmap)) + 1); + max_bits + 1); if (!*enctypes) { return ENOMEM; } - for (i = 0; i < (8 * sizeof(enctype_bitmap)); i++) { + + for (i = max_bits - 1; i >= 0; i--) { uint32_t bit_value = (1U << i) & enctype_bitmap; if (bit_value & enctype_bitmap) { (*enctypes)[j] = ms_suptype_to_ietf_enctype(bit_value);