diff options
author | Ben Laurie <ben@openssl.org> | 1999-05-01 17:40:57 +0000 |
---|---|---|
committer | Ben Laurie <ben@openssl.org> | 1999-05-01 17:40:57 +0000 |
commit | 65d4927b8d645d9bcb5f6085a107d314794e8e34 (patch) | |
tree | 0ed1a2ce94a5f5e21b463f0309cca9c24ecdaf2c /crypto/asn1 | |
parent | 3a1a8467bd7829cef1b269514629912423b1fd8c (diff) | |
download | openssl-new-65d4927b8d645d9bcb5f6085a107d314794e8e34.tar.gz |
Another safe stack.
Diffstat (limited to 'crypto/asn1')
-rw-r--r-- | crypto/asn1/asn1_mac.h | 4 | ||||
-rw-r--r-- | crypto/asn1/x_name.c | 38 |
2 files changed, 24 insertions, 18 deletions
diff --git a/crypto/asn1/asn1_mac.h b/crypto/asn1/asn1_mac.h index 0497805590..f0ab1e9069 100644 --- a/crypto/asn1/asn1_mac.h +++ b/crypto/asn1/asn1_mac.h @@ -154,6 +154,10 @@ err:\ M_ASN1_D2I_get_imp_set(r,func,free_func, \ V_ASN1_SET,V_ASN1_UNIVERSAL); +#define M_ASN1_D2I_get_set_type(type,r,func,free_func) \ + M_ASN1_D2I_get_imp_set_type(type,r,func,free_func, \ + V_ASN1_SET,V_ASN1_UNIVERSAL); + #define M_ASN1_D2I_get_set_opt(r,func,free_func) \ if ((c.slen != 0) && (M_ASN1_next == (V_ASN1_UNIVERSAL| \ V_ASN1_CONSTRUCTED|V_ASN1_SET)))\ diff --git a/crypto/asn1/x_name.c b/crypto/asn1/x_name.c index c26c1ce01a..5df74b9f45 100644 --- a/crypto/asn1/x_name.c +++ b/crypto/asn1/x_name.c @@ -113,7 +113,7 @@ int i2d_X509_NAME(X509_NAME *a, unsigned char **pp) static int i2d_X509_NAME_entries(X509_NAME *a) { X509_NAME_ENTRY *ne,*fe=NULL; - STACK *sk; + STACK_OF(X509_NAME_ENTRY) *sk; BUF_MEM *buf=NULL; int set=0,r,ret=0; int i; @@ -121,9 +121,9 @@ static int i2d_X509_NAME_entries(X509_NAME *a) int size=0; sk=a->entries; - for (i=0; i<sk_num(sk); i++) + for (i=0; i<sk_X509_NAME_ENTRY_num(sk); i++) { - ne=(X509_NAME_ENTRY *)sk_value(sk,i); + ne=sk_X509_NAME_ENTRY_value(sk,i); if (fe == NULL) { fe=ne; @@ -154,9 +154,9 @@ static int i2d_X509_NAME_entries(X509_NAME *a) ASN1_put_object(&p,1,ret,V_ASN1_SEQUENCE,V_ASN1_UNIVERSAL); set= -1; - for (i=0; i<sk_num(sk); i++) + for (i=0; i<sk_X509_NAME_ENTRY_num(sk); i++) { - ne=(X509_NAME_ENTRY *)sk_value(sk,i); + ne=sk_X509_NAME_ENTRY_value(sk,i); if (set != ne->set) { set=ne->set; @@ -179,11 +179,11 @@ X509_NAME *d2i_X509_NAME(X509_NAME **a, unsigned char **pp, long length) M_ASN1_D2I_vars(a,X509_NAME *,X509_NAME_new); orig= *pp; - if (sk_num(ret->entries) > 0) + if (sk_X509_NAME_ENTRY_num(ret->entries) > 0) { - while (sk_num(ret->entries) > 0) - X509_NAME_ENTRY_free((X509_NAME_ENTRY *) - sk_pop(ret->entries)); + while (sk_X509_NAME_ENTRY_num(ret->entries) > 0) + X509_NAME_ENTRY_free( + sk_X509_NAME_ENTRY_pop(ret->entries)); } M_ASN1_D2I_Init(); @@ -191,12 +191,12 @@ X509_NAME *d2i_X509_NAME(X509_NAME **a, unsigned char **pp, long length) for (;;) { if (M_ASN1_D2I_end_sequence()) break; - M_ASN1_D2I_get_set(ret->entries,d2i_X509_NAME_ENTRY, - X509_NAME_ENTRY_free); - for (; idx < sk_num(ret->entries); idx++) + M_ASN1_D2I_get_set_type(X509_NAME_ENTRY,ret->entries, + d2i_X509_NAME_ENTRY, + X509_NAME_ENTRY_free); + for (; idx < sk_X509_NAME_ENTRY_num(ret->entries); idx++) { - ((X509_NAME_ENTRY *)sk_value(ret->entries,idx))->set= - set; + sk_X509_NAME_ENTRY_value(ret->entries,idx)->set=set; } set++; } @@ -216,7 +216,7 @@ X509_NAME *X509_NAME_new(void) ASN1_CTX c; M_ASN1_New_Malloc(ret,X509_NAME); - if ((ret->entries=sk_new(NULL)) == NULL) + if ((ret->entries=sk_X509_NAME_ENTRY_new(NULL)) == NULL) { c.line=__LINE__; goto err2; } M_ASN1_New(ret->bytes,BUF_MEM_new); ret->modified=1; @@ -244,8 +244,8 @@ void X509_NAME_free(X509_NAME *a) return; BUF_MEM_free(a->bytes); - sk_pop_free(a->entries,X509_NAME_ENTRY_free); - Free((char *)a); + sk_X509_NAME_ENTRY_pop_free(a->entries,X509_NAME_ENTRY_free); + Free(a); } void X509_NAME_ENTRY_free(X509_NAME_ENTRY *a) @@ -253,7 +253,7 @@ void X509_NAME_ENTRY_free(X509_NAME_ENTRY *a) if (a == NULL) return; ASN1_OBJECT_free(a->object); ASN1_BIT_STRING_free(a->value); - Free((char *)a); + Free(a); } int X509_NAME_set(X509_NAME **xn, X509_NAME *name) @@ -274,3 +274,5 @@ int X509_NAME_set(X509_NAME **xn, X509_NAME *name) return(*xn != NULL); } +IMPLEMENT_STACK_OF(X509_NAME_ENTRY) +IMPLEMENT_ASN1_SET_OF(X509_NAME_ENTRY) |