10Sstevel@tonic-gate /* crypto/buffer/buffer.c */ 20Sstevel@tonic-gate /* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) 30Sstevel@tonic-gate * All rights reserved. 40Sstevel@tonic-gate * 50Sstevel@tonic-gate * This package is an SSL implementation written 60Sstevel@tonic-gate * by Eric Young (eay@cryptsoft.com). 70Sstevel@tonic-gate * The implementation was written so as to conform with Netscapes SSL. 80Sstevel@tonic-gate * 90Sstevel@tonic-gate * This library is free for commercial and non-commercial use as long as 100Sstevel@tonic-gate * the following conditions are aheared to. The following conditions 110Sstevel@tonic-gate * apply to all code found in this distribution, be it the RC4, RSA, 120Sstevel@tonic-gate * lhash, DES, etc., code; not just the SSL code. The SSL documentation 130Sstevel@tonic-gate * included with this distribution is covered by the same copyright terms 140Sstevel@tonic-gate * except that the holder is Tim Hudson (tjh@cryptsoft.com). 150Sstevel@tonic-gate * 160Sstevel@tonic-gate * Copyright remains Eric Young's, and as such any Copyright notices in 170Sstevel@tonic-gate * the code are not to be removed. 180Sstevel@tonic-gate * If this package is used in a product, Eric Young should be given attribution 190Sstevel@tonic-gate * as the author of the parts of the library used. 200Sstevel@tonic-gate * This can be in the form of a textual message at program startup or 210Sstevel@tonic-gate * in documentation (online or textual) provided with the package. 220Sstevel@tonic-gate * 230Sstevel@tonic-gate * Redistribution and use in source and binary forms, with or without 240Sstevel@tonic-gate * modification, are permitted provided that the following conditions 250Sstevel@tonic-gate * are met: 260Sstevel@tonic-gate * 1. Redistributions of source code must retain the copyright 270Sstevel@tonic-gate * notice, this list of conditions and the following disclaimer. 280Sstevel@tonic-gate * 2. Redistributions in binary form must reproduce the above copyright 290Sstevel@tonic-gate * notice, this list of conditions and the following disclaimer in the 300Sstevel@tonic-gate * documentation and/or other materials provided with the distribution. 310Sstevel@tonic-gate * 3. All advertising materials mentioning features or use of this software 320Sstevel@tonic-gate * must display the following acknowledgement: 330Sstevel@tonic-gate * "This product includes cryptographic software written by 340Sstevel@tonic-gate * Eric Young (eay@cryptsoft.com)" 350Sstevel@tonic-gate * The word 'cryptographic' can be left out if the rouines from the library 360Sstevel@tonic-gate * being used are not cryptographic related :-). 370Sstevel@tonic-gate * 4. If you include any Windows specific code (or a derivative thereof) from 380Sstevel@tonic-gate * the apps directory (application code) you must include an acknowledgement: 390Sstevel@tonic-gate * "This product includes software written by Tim Hudson (tjh@cryptsoft.com)" 400Sstevel@tonic-gate * 410Sstevel@tonic-gate * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND 420Sstevel@tonic-gate * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 430Sstevel@tonic-gate * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 440Sstevel@tonic-gate * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 450Sstevel@tonic-gate * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 460Sstevel@tonic-gate * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 470Sstevel@tonic-gate * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 480Sstevel@tonic-gate * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 490Sstevel@tonic-gate * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 500Sstevel@tonic-gate * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 510Sstevel@tonic-gate * SUCH DAMAGE. 520Sstevel@tonic-gate * 530Sstevel@tonic-gate * The licence and distribution terms for any publically available version or 540Sstevel@tonic-gate * derivative of this code cannot be changed. i.e. this code cannot simply be 550Sstevel@tonic-gate * copied and put under another distribution licence 560Sstevel@tonic-gate * [including the GNU Public Licence.] 570Sstevel@tonic-gate */ 580Sstevel@tonic-gate 590Sstevel@tonic-gate #include <stdio.h> 600Sstevel@tonic-gate #include "cryptlib.h" 610Sstevel@tonic-gate #include <openssl/buffer.h> 620Sstevel@tonic-gate 630Sstevel@tonic-gate BUF_MEM *BUF_MEM_new(void) 640Sstevel@tonic-gate { 650Sstevel@tonic-gate BUF_MEM *ret; 660Sstevel@tonic-gate 670Sstevel@tonic-gate ret=OPENSSL_malloc(sizeof(BUF_MEM)); 680Sstevel@tonic-gate if (ret == NULL) 690Sstevel@tonic-gate { 700Sstevel@tonic-gate BUFerr(BUF_F_BUF_MEM_NEW,ERR_R_MALLOC_FAILURE); 710Sstevel@tonic-gate return(NULL); 720Sstevel@tonic-gate } 730Sstevel@tonic-gate ret->length=0; 740Sstevel@tonic-gate ret->max=0; 750Sstevel@tonic-gate ret->data=NULL; 760Sstevel@tonic-gate return(ret); 770Sstevel@tonic-gate } 780Sstevel@tonic-gate 790Sstevel@tonic-gate void BUF_MEM_free(BUF_MEM *a) 800Sstevel@tonic-gate { 810Sstevel@tonic-gate if(a == NULL) 820Sstevel@tonic-gate return; 830Sstevel@tonic-gate 840Sstevel@tonic-gate if (a->data != NULL) 850Sstevel@tonic-gate { 860Sstevel@tonic-gate memset(a->data,0,(unsigned int)a->max); 870Sstevel@tonic-gate OPENSSL_free(a->data); 880Sstevel@tonic-gate } 890Sstevel@tonic-gate OPENSSL_free(a); 900Sstevel@tonic-gate } 910Sstevel@tonic-gate 920Sstevel@tonic-gate int BUF_MEM_grow(BUF_MEM *str, int len) 930Sstevel@tonic-gate { 940Sstevel@tonic-gate char *ret; 950Sstevel@tonic-gate unsigned int n; 960Sstevel@tonic-gate 970Sstevel@tonic-gate if (str->length >= len) 980Sstevel@tonic-gate { 990Sstevel@tonic-gate str->length=len; 1000Sstevel@tonic-gate return(len); 1010Sstevel@tonic-gate } 1020Sstevel@tonic-gate if (str->max >= len) 1030Sstevel@tonic-gate { 1040Sstevel@tonic-gate memset(&str->data[str->length],0,len-str->length); 1050Sstevel@tonic-gate str->length=len; 1060Sstevel@tonic-gate return(len); 1070Sstevel@tonic-gate } 1080Sstevel@tonic-gate n=(len+3)/3*4; 1090Sstevel@tonic-gate if (str->data == NULL) 1100Sstevel@tonic-gate ret=OPENSSL_malloc(n); 1110Sstevel@tonic-gate else 1120Sstevel@tonic-gate ret=OPENSSL_realloc(str->data,n); 1130Sstevel@tonic-gate if (ret == NULL) 1140Sstevel@tonic-gate { 1150Sstevel@tonic-gate BUFerr(BUF_F_BUF_MEM_GROW,ERR_R_MALLOC_FAILURE); 1160Sstevel@tonic-gate len=0; 1170Sstevel@tonic-gate } 1180Sstevel@tonic-gate else 1190Sstevel@tonic-gate { 1200Sstevel@tonic-gate str->data=ret; 1210Sstevel@tonic-gate str->max=n; 1220Sstevel@tonic-gate memset(&str->data[str->length],0,len-str->length); 1230Sstevel@tonic-gate str->length=len; 1240Sstevel@tonic-gate } 1250Sstevel@tonic-gate return(len); 1260Sstevel@tonic-gate } 1270Sstevel@tonic-gate 1280Sstevel@tonic-gate int BUF_MEM_grow_clean(BUF_MEM *str, int len) 1290Sstevel@tonic-gate { 1300Sstevel@tonic-gate char *ret; 1310Sstevel@tonic-gate unsigned int n; 1320Sstevel@tonic-gate 1330Sstevel@tonic-gate if (str->length >= len) 1340Sstevel@tonic-gate { 1350Sstevel@tonic-gate memset(&str->data[len],0,str->length-len); 1360Sstevel@tonic-gate str->length=len; 1370Sstevel@tonic-gate return(len); 1380Sstevel@tonic-gate } 1390Sstevel@tonic-gate if (str->max >= len) 1400Sstevel@tonic-gate { 1410Sstevel@tonic-gate memset(&str->data[str->length],0,len-str->length); 1420Sstevel@tonic-gate str->length=len; 1430Sstevel@tonic-gate return(len); 1440Sstevel@tonic-gate } 1450Sstevel@tonic-gate n=(len+3)/3*4; 1460Sstevel@tonic-gate if (str->data == NULL) 1470Sstevel@tonic-gate ret=OPENSSL_malloc(n); 1480Sstevel@tonic-gate else 1490Sstevel@tonic-gate ret=OPENSSL_realloc_clean(str->data,str->max,n); 1500Sstevel@tonic-gate if (ret == NULL) 1510Sstevel@tonic-gate { 152*2139Sjp161948 BUFerr(BUF_F_BUF_MEM_GROW_CLEAN,ERR_R_MALLOC_FAILURE); 1530Sstevel@tonic-gate len=0; 1540Sstevel@tonic-gate } 1550Sstevel@tonic-gate else 1560Sstevel@tonic-gate { 1570Sstevel@tonic-gate str->data=ret; 1580Sstevel@tonic-gate str->max=n; 1590Sstevel@tonic-gate memset(&str->data[str->length],0,len-str->length); 1600Sstevel@tonic-gate str->length=len; 1610Sstevel@tonic-gate } 1620Sstevel@tonic-gate return(len); 1630Sstevel@tonic-gate } 1640Sstevel@tonic-gate 1650Sstevel@tonic-gate char *BUF_strdup(const char *str) 1660Sstevel@tonic-gate { 167*2139Sjp161948 if (str == NULL) return(NULL); 168*2139Sjp161948 return BUF_strndup(str, strlen(str)); 169*2139Sjp161948 } 170*2139Sjp161948 171*2139Sjp161948 char *BUF_strndup(const char *str, size_t siz) 172*2139Sjp161948 { 1730Sstevel@tonic-gate char *ret; 1740Sstevel@tonic-gate 1750Sstevel@tonic-gate if (str == NULL) return(NULL); 1760Sstevel@tonic-gate 177*2139Sjp161948 ret=OPENSSL_malloc(siz+1); 1780Sstevel@tonic-gate if (ret == NULL) 1790Sstevel@tonic-gate { 180*2139Sjp161948 BUFerr(BUF_F_BUF_STRNDUP,ERR_R_MALLOC_FAILURE); 1810Sstevel@tonic-gate return(NULL); 1820Sstevel@tonic-gate } 183*2139Sjp161948 BUF_strlcpy(ret,str,siz+1); 1840Sstevel@tonic-gate return(ret); 1850Sstevel@tonic-gate } 1860Sstevel@tonic-gate 187*2139Sjp161948 void *BUF_memdup(const void *data, size_t siz) 188*2139Sjp161948 { 189*2139Sjp161948 void *ret; 190*2139Sjp161948 191*2139Sjp161948 if (data == NULL) return(NULL); 192*2139Sjp161948 193*2139Sjp161948 ret=OPENSSL_malloc(siz); 194*2139Sjp161948 if (ret == NULL) 195*2139Sjp161948 { 196*2139Sjp161948 BUFerr(BUF_F_BUF_MEMDUP,ERR_R_MALLOC_FAILURE); 197*2139Sjp161948 return(NULL); 198*2139Sjp161948 } 199*2139Sjp161948 return memcpy(ret, data, siz); 200*2139Sjp161948 } 201*2139Sjp161948 2020Sstevel@tonic-gate size_t BUF_strlcpy(char *dst, const char *src, size_t size) 2030Sstevel@tonic-gate { 2040Sstevel@tonic-gate size_t l = 0; 2050Sstevel@tonic-gate for(; size > 1 && *src; size--) 2060Sstevel@tonic-gate { 2070Sstevel@tonic-gate *dst++ = *src++; 2080Sstevel@tonic-gate l++; 2090Sstevel@tonic-gate } 2100Sstevel@tonic-gate if (size) 2110Sstevel@tonic-gate *dst = '\0'; 2120Sstevel@tonic-gate return l + strlen(src); 2130Sstevel@tonic-gate } 2140Sstevel@tonic-gate 2150Sstevel@tonic-gate size_t BUF_strlcat(char *dst, const char *src, size_t size) 2160Sstevel@tonic-gate { 2170Sstevel@tonic-gate size_t l = 0; 2180Sstevel@tonic-gate for(; size > 0 && *dst; size--, dst++) 2190Sstevel@tonic-gate l++; 2200Sstevel@tonic-gate return l + BUF_strlcpy(dst, src, size); 2210Sstevel@tonic-gate } 222