summaryrefslogtreecommitdiffstats
path: root/generic/tclBinary.c
diff options
context:
space:
mode:
authornijtmans@users.sourceforge.net <jan.nijtmans>2012-08-23 12:07:22 (GMT)
committernijtmans@users.sourceforge.net <jan.nijtmans>2012-08-23 12:07:22 (GMT)
commitf6b23a705535045ab25719142939ba6a778d5dbd (patch)
tree3b39a4abf553fc24d1fe25b10cb3b153c4653403 /generic/tclBinary.c
parent7dc83ee2161ff6870f219fca0191c38daa7a32e5 (diff)
downloadtcl-f6b23a705535045ab25719142939ba6a778d5dbd.zip
tcl-f6b23a705535045ab25719142939ba6a778d5dbd.tar.gz
tcl-f6b23a705535045ab25719142939ba6a778d5dbd.tar.bz2
[Bug 3496014] Protect Tcl_SetByteArrayObj for invalid values
(Backported from Tcl 8.6)
Diffstat (limited to 'generic/tclBinary.c')
-rw-r--r--generic/tclBinary.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/generic/tclBinary.c b/generic/tclBinary.c
index f321b28..8c95305 100644
--- a/generic/tclBinary.c
+++ b/generic/tclBinary.c
@@ -273,10 +273,15 @@ Tcl_SetByteArrayObj(
TclFreeIntRep(objPtr);
Tcl_InvalidateStringRep(objPtr);
+ if (length < 0) {
+ length = 0;
+ }
byteArrayPtr = (ByteArray *) ckalloc(BYTEARRAY_SIZE(length));
byteArrayPtr->used = length;
byteArrayPtr->allocated = length;
- memcpy(byteArrayPtr->bytes, bytes, (size_t) length);
+ if (length && bytes) {
+ memcpy(byteArrayPtr->bytes, bytes, (size_t) length);
+ }
objPtr->typePtr = &tclByteArrayType;
SET_BYTEARRAY(objPtr, byteArrayPtr);