mirror of
https://github.com/openssl/openssl.git
synced 2024-12-27 06:21:43 +08:00
786b6a45fb
Trouble was that integer negation wasn't producing *formally* correct result in platform-neutral sense. Formally correct thing to do is -(int64_t)u, but this triggers undefined behaviour for one value that would still be representable in ASN.1. The trigger was masked with (int64_t)(0-u), but this is formally inappropriate for values other than the problematic one. [Also reorder branches to favour most-likely paths and harmonize asn1_string_set_int64 with asn1_get_int64].] Reviewed-by: Rich Salz <rsalz@openssl.org> (Merged from https://github.com/openssl/openssl/pull/3231) |
||
---|---|---|
.. | ||
a_bitstr.c | ||
a_d2i_fp.c | ||
a_digest.c | ||
a_dup.c | ||
a_gentm.c | ||
a_i2d_fp.c | ||
a_int.c | ||
a_mbstr.c | ||
a_object.c | ||
a_octet.c | ||
a_print.c | ||
a_sign.c | ||
a_strex.c | ||
a_strnid.c | ||
a_time.c | ||
a_type.c | ||
a_utctm.c | ||
a_utf8.c | ||
a_verify.c | ||
ameth_lib.c | ||
asn1_err.c | ||
asn1_gen.c | ||
asn1_item_list.c | ||
asn1_item_list.h | ||
asn1_lib.c | ||
asn1_locl.h | ||
asn1_par.c | ||
asn_mime.c | ||
asn_moid.c | ||
asn_mstbl.c | ||
asn_pack.c | ||
bio_asn1.c | ||
bio_ndef.c | ||
build.info | ||
charmap.h | ||
charmap.pl | ||
d2i_pr.c | ||
d2i_pu.c | ||
evp_asn1.c | ||
f_int.c | ||
f_string.c | ||
i2d_pr.c | ||
i2d_pu.c | ||
n_pkey.c | ||
nsseq.c | ||
p5_pbe.c | ||
p5_pbev2.c | ||
p5_scrypt.c | ||
p8_pkey.c | ||
standard_methods.h | ||
t_bitst.c | ||
t_pkey.c | ||
t_spki.c | ||
tasn_dec.c | ||
tasn_enc.c | ||
tasn_fre.c | ||
tasn_new.c | ||
tasn_prn.c | ||
tasn_scn.c | ||
tasn_typ.c | ||
tasn_utl.c | ||
tbl_standard.h | ||
x_algor.c | ||
x_bignum.c | ||
x_info.c | ||
x_int64.c | ||
x_long.c | ||
x_pkey.c | ||
x_sig.c | ||
x_spki.c | ||
x_val.c |