--- libraries/liblber/decode.c 2008/09/02 23:54:37 1.105.2.5 +++ libraries/liblber/decode.c 2007/04/04 15:51:10 1.109 @@ -1,8 +1,8 @@ /* decode.c - ber input decoding routines */ -/* $OpenLDAP: pkg/ldap/libraries/liblber/decode.c,v 1.105.2.4 2008/02/11 23:26:41 kurt Exp $ */ +/* $OpenLDAP: pkg/ldap/libraries/liblber/decode.c,v 1.108 2007/03/23 14:27:38 hyc Exp $ */ /* This work is part of OpenLDAP Software . * - * Copyright 1998-2008 The OpenLDAP Foundation. + * Copyright 1998-2007 The OpenLDAP Foundation. * All rights reserved. * * Redistribution and use in source and binary forms, with or without @@ -49,44 +49,32 @@ static ber_len_t ber_getnint LDAP_P(( int ber_decode_oid( BerValue *in, BerValue *out ) { - const unsigned char *der; - unsigned long val; - unsigned val1; - ber_len_t i; + unsigned char *der = (unsigned char *) in->bv_val; + unsigned long val, val1; + int i, len; char *ptr; assert( in != NULL ); assert( out != NULL ); - /* need 4 chars/inbyte + \0 for input={7f 7f 7f...} */ - if ( !out->bv_val || (out->bv_len+3)/4 <= in->bv_len ) + /* expands by 5/2, and we add dots - call it 3 */ + if ( !out->bv_val || out->bv_len < in->bv_len * 3 ) return -1; - ptr = NULL; - der = (unsigned char *) in->bv_val; + val1 = der[0] / 40; + val = der[0] - val1 * 40; + + len = sprintf( out->bv_val, "%ld.%ld", val1, val ); + ptr = out->bv_val + len; val = 0; - for ( i=0; i < in->bv_len; i++ ) { + for ( i=1; ibv_len; i++ ) { + val = val << 7; val |= der[i] & 0x7f; if ( !( der[i] & 0x80 )) { - if ( ptr == NULL ) { - /* Initial "x.y": val=x*40+y, x<=2, y<40 if x<2 */ - ptr = out->bv_val; - val1 = (val < 80 ? val/40 : 2); - val -= val1*40; - ptr += sprintf( ptr, "%u", val1 ); - } - ptr += sprintf( ptr, ".%lu", val ); + ptr += sprintf( ptr, ".%ld", val ); val = 0; - } else if ( val - 1UL < LBER_OID_COMPONENT_MAX >> 7 ) { - val <<= 7; - } else { - /* val would overflow, or is 0 from invalid initial 0x80 octet */ - return -1; } } - if ( ptr == NULL || val != 0 ) - return -1; - out->bv_len = ptr - out->bv_val; return 0; } @@ -419,7 +407,7 @@ ber_get_stringbvl( bgbvr *b, ber_len_t * case BvOff: *b->res.ba = ber_memalloc_x( (n+1) * b->siz, b->ber->ber_memctx ); if ( *b->res.ba == NULL ) return LBER_DEFAULT; - ((struct berval *)((char *)(*b->res.ba) + n*b->siz + + ((struct berval *)((long)(*b->res.ba) + n*b->siz + b->off))->bv_val = NULL; break; } @@ -452,7 +440,7 @@ ber_get_stringbvl( bgbvr *b, ber_len_t * *bvp = bv; break; case BvOff: - *(BerVarray)((char *)(*b->res.ba)+n*b->siz+b->off) = bv; + *(BerVarray)((long)(*b->res.ba)+n*b->siz+b->off) = bv; break; } } @@ -780,11 +768,9 @@ ber_scanf ( BerElement *ber, fmt_reset = fmt; - if ( ber->ber_debug & (LDAP_DEBUG_TRACE|LDAP_DEBUG_BER)) { - ber_log_printf( LDAP_DEBUG_TRACE, ber->ber_debug, - "ber_scanf fmt (%s) ber:\n", fmt ); - ber_log_dump( LDAP_DEBUG_BER, ber->ber_debug, ber, 1 ); - } + ber_log_printf( LDAP_DEBUG_TRACE, ber->ber_debug, + "ber_scanf fmt (%s) ber:\n", fmt ); + ber_log_dump( LDAP_DEBUG_BER, ber->ber_debug, ber, 1 ); for ( rc = 0; *fmt && rc != LBER_DEFAULT; fmt++ ) { /* When this is modified, remember to update