Protection against possible buffer overflow

This commit is contained in:
rajithr 2015-05-27 19:06:19 +05:30
parent 5a26d25647
commit 08503a20be

View file

@ -141,6 +141,7 @@ packetbuf_copyto(void *to)
int i; int i;
char buffer[1000]; char buffer[1000];
char *bufferptr = buffer; char *bufferptr = buffer;
int bufferlen = 0;
bufferptr[0] = 0; bufferptr[0] = 0;
for(i = hdrptr; i < PACKETBUF_HDR_SIZE; ++i) { for(i = hdrptr; i < PACKETBUF_HDR_SIZE; ++i) {
@ -149,8 +150,8 @@ packetbuf_copyto(void *to)
PRINTF("packetbuf_write: header: %s\n", buffer); PRINTF("packetbuf_write: header: %s\n", buffer);
bufferptr = buffer; bufferptr = buffer;
bufferptr[0] = 0; bufferptr[0] = 0;
for(i = bufptr; i < buflen + bufptr; ++i) { for(i = bufptr; ((i < buflen + bufptr) && (bufferlen < 980)); ++i) {
bufferptr += sprintf(bufferptr, "0x%02x, ", packetbufptr[i]); bufferlen += sprintf(bufferptr + bufferlen, "0x%02x, ", packetbufptr[i]);
} }
PRINTF("packetbuf_write: data: %s\n", buffer); PRINTF("packetbuf_write: data: %s\n", buffer);
} }