ASN1_BIT_STRING_set_bit() didn't clear previously set bits
authorRichard Levitte <levitte@openssl.org>
Sun, 3 Feb 2002 21:31:41 +0000 (21:31 +0000)
committerRichard Levitte <levitte@openssl.org>
Sun, 3 Feb 2002 21:31:41 +0000 (21:31 +0000)
CHANGES
crypto/asn1/a_bitstr.c

diff --git a/CHANGES b/CHANGES
index 42c32dc20ad5ae38f5c24df148b46bfd9ad6bf45..0f65cb17c0197d16c55573891f04ec3778cedf4a 100644 (file)
--- a/CHANGES
+++ b/CHANGES
@@ -4,14 +4,19 @@
 
  Changes between 0.9.6 and 0.9.7  [xx XXX 2001]
 
-     OpenSSL 0.9.6a/0.9.6b (bugfix releases, 5 Apr 2001 and 9 July 2001)
-     and OpenSSL 0.9.7 were developed in parallel, based on OpenSSL 0.9.6.  
+     OpenSSL 0.9.6a/0.9.6b/0.9.6c (bugfix releases, 5 Apr 2001, 9 July 2001
+     and 21 Dec 2001) and OpenSSL 0.9.7 were developed in parallel, based
+     on OpenSSL 0.9.6.  
 
      Change log entries are tagged as follows:
          -) applies to 0.9.6a/0.9.6b/0.9.6c only
          *) applies to 0.9.6a/0.9.6b/0.9.6c and 0.9.7
          +) applies to 0.9.7 only
 
+  *) Have ASN1_BIT_STRING_set_bit() really clear a bit when the requested
+     value is 0.
+     [Richard Levitte]
+
   +) Have the CHIL engine fork-safe (as defined by nCipher) and actually
      make the newer ENGINE framework commands for the CHIL engine work.
      [Toomas Kiisk <vix@cyber.ee> and Richard Levitte]
index 46e97038a28c8fc9d072a6eb05e385f53c868e54..c36817c1ee4ca7c654604db50f74e3e481a77a44 100644 (file)
@@ -172,6 +172,7 @@ int ASN1_BIT_STRING_set_bit(ASN1_BIT_STRING *a, int n, int value)
        w=n/8;
        v=1<<(7-(n&0x07));
        iv= ~v;
+       if (!value) v=0;
 
        a->flags&= ~(ASN1_STRING_FLAG_BITS_LEFT|0x07); /* clear, set on write */