shithub: ft²

Download patch

ref: 846ce9d9cad4b46246ea18f3def3112a7e49b802
parent: 789bc88cf75667d2a9e63278feb221fe474a8113
author: Olav Sørensen <[email protected]>
date: Tue Jun 14 17:26:17 EDT 2022

Fixed possible "Copy smp." crash

--- a/src/ft2_sample_ed.c
+++ b/src/ft2_sample_ed.c
@@ -153,26 +153,34 @@
 	smpPtr_t sp;
 
 	freeSmpData(dst);
-	memcpy(dst, src, sizeof (sample_t));
 
-	// zero out stuff that wasn't supposed to be cloned
-	dst->origDataPtr = dst->dataPtr = NULL;
-	dst->isFixed = false;
-	dst->fixedPos = 0;
-
-	// if source sample isn't empty, allocate room and copy it over (and fix it)
-	if (src->length > 0 && src->dataPtr != NULL)
+	if (src == NULL)
 	{
-		bool sample16Bit = !!(src->flags & SAMPLE_16BIT);
-		if (!allocateSmpDataPtr(&sp, src->length, sample16Bit))
+		memset(dst, 0, sizeof (sample_t));
+	}
+	else
+	{
+		memcpy(dst, src, sizeof (sample_t));
+
+		// zero out stuff that wasn't supposed to be cloned
+		dst->origDataPtr = dst->dataPtr = NULL;
+		dst->isFixed = false;
+		dst->fixedPos = 0;
+
+		// if source sample isn't empty, allocate room and copy it over (and fix it)
+		if (src->length > 0 && src->dataPtr != NULL)
 		{
-			dst->length = 0;
-			return false;
-		}
+			bool sample16Bit = !!(src->flags & SAMPLE_16BIT);
+			if (!allocateSmpDataPtr(&sp, src->length, sample16Bit))
+			{
+				dst->length = 0;
+				return false;
+			}
 
-		setSmpDataPtr(dst, &sp);
-		memcpy(dst->dataPtr, src->dataPtr, src->length << sample16Bit);
-		fixSample(dst);
+			setSmpDataPtr(dst, &sp);
+			memcpy(dst->dataPtr, src->dataPtr, src->length << sample16Bit);
+			fixSample(dst);
+		}
 	}
 
 	return true;
@@ -695,14 +703,18 @@
 
 static int32_t SDLCALL copySampleThread(void *ptr)
 {
-	sample_t *src = &instr[editor.srcInstr]->smp[editor.srcSmp];
-	sample_t *dst = &instr[editor.curInstr]->smp[editor.curSmp];
-
 	pauseAudio();
 
+	sample_t *src;
+	if (instr[editor.srcInstr] == NULL)
+		src = NULL;
+	else
+		src = &instr[editor.srcInstr]->smp[editor.srcSmp];
+
 	if (instr[editor.curInstr] == NULL && !allocateInstr(editor.curInstr))
 		goto error;
 
+	sample_t *dst = &instr[editor.curInstr]->smp[editor.curSmp];
 	if (!cloneSample(src, dst))
 		goto error;