Reject leading 0x80 in OID subidentifiers.
authorDr. Stephen Henson <steve@openssl.org>
Thu, 6 Aug 2009 16:22:57 +0000 (16:22 +0000)
committerDr. Stephen Henson <steve@openssl.org>
Thu, 6 Aug 2009 16:22:57 +0000 (16:22 +0000)
crypto/asn1/a_object.c
crypto/asn1/asn1.h
crypto/asn1/asn1_err.c

index dc980421d098bb2d641ca15b8cf55dfafb6dbc4d..d169f8c14736e486ba0526eb387499bd42eeaa86 100644 (file)
@@ -291,6 +291,17 @@ ASN1_OBJECT *c2i_ASN1_OBJECT(ASN1_OBJECT **a, const unsigned char **pp,
        ASN1_OBJECT *ret=NULL;
        const unsigned char *p;
        int i;
+       /* Sanity check OID encoding: can't have 0x80 in subidentifiers, see:
+        * X.690 8.19.2
+        */
+       for (i = 0, p = *pp + 1; i < len - 1; i++, p++)
+               {
+               if (*p == 0x80)
+                       {
+                       ASN1err(ASN1_F_C2I_ASN1_OBJECT,ASN1_R_INVALID_OBJECT_ENCODING);
+                       return NULL;
+                       }
+               }
 
        /* only the ASN1_OBJECTs from the 'table' will have values
         * for ->sn or ->ln */
index e3385226d4a5b0aa540305ae1931351145773b37..4e701633e08a1c1961ce805c5a9ec0c83db6df0e 100644 (file)
@@ -1263,6 +1263,7 @@ void ERR_load_ASN1_strings(void);
 #define ASN1_R_INVALID_MIME_TYPE                        200
 #define ASN1_R_INVALID_MODIFIER                                 186
 #define ASN1_R_INVALID_NUMBER                           187
+#define ASN1_R_INVALID_OBJECT_ENCODING                  212
 #define ASN1_R_INVALID_SEPARATOR                        131
 #define ASN1_R_INVALID_TIME_FORMAT                      132
 #define ASN1_R_INVALID_UNIVERSALSTRING_LENGTH           133
index 5f5de98eed530a199aca422cd09ee8d89cc59ab6..ba88eb318be3f5bbc3a829e31023e1dce6212e99 100644 (file)
@@ -240,6 +240,7 @@ static ERR_STRING_DATA ASN1_str_reasons[]=
 {ERR_REASON(ASN1_R_INVALID_MIME_TYPE)    ,"invalid mime type"},
 {ERR_REASON(ASN1_R_INVALID_MODIFIER)     ,"invalid modifier"},
 {ERR_REASON(ASN1_R_INVALID_NUMBER)       ,"invalid number"},
+{ERR_REASON(ASN1_R_INVALID_OBJECT_ENCODING),"invalid object encoding"},
 {ERR_REASON(ASN1_R_INVALID_SEPARATOR)    ,"invalid separator"},
 {ERR_REASON(ASN1_R_INVALID_TIME_FORMAT)  ,"invalid time format"},
 {ERR_REASON(ASN1_R_INVALID_UNIVERSALSTRING_LENGTH),"invalid universalstring length"},