summaryrefslogtreecommitdiff
path: root/src/lib/libcrypto/dsa/dsa.h
diff options
context:
space:
mode:
authorjsing <>2023-02-13 04:25:37 +0000
committerjsing <>2023-02-13 04:25:37 +0000
commit53aa84bf6a4cfaffa003a28a5651a7f30bd74400 (patch)
tree3f4664b9d6259b538a970687b222189d9d59afb5 /src/lib/libcrypto/dsa/dsa.h
parent44502592f345cf60ebd8062da41e157768f12e94 (diff)
downloadopenbsd-53aa84bf6a4cfaffa003a28a5651a7f30bd74400.tar.gz
openbsd-53aa84bf6a4cfaffa003a28a5651a7f30bd74400.tar.bz2
openbsd-53aa84bf6a4cfaffa003a28a5651a7f30bd74400.zip
Avoid negative zero.
Whenever setting negative to one (or when it could potentially be one), always use BN_set_negative() since it checks for a zero valued bignum and will not permit negative to be set in this case. Since BN_is_zero() currently relies on top == 0, call BN_set_negative() after top has been set (or bn_correct_top() has been called). This fixes a long standing issue where -0 and +0 have been permitted, however multiple code paths (such as BN_cmp()) fail to treat these as equivalent. Prompted by Guido Vranken who is adding negative zero fuzzing to oss-fuzz. ok tb@
Diffstat (limited to 'src/lib/libcrypto/dsa/dsa.h')
0 files changed, 0 insertions, 0 deletions