7e448dc
From ef3d8be0f80cbb650e4766b545d61e10d7a24c9e Mon Sep 17 00:00:00 2001
7e448dc
From: Mans Rullgard <mans@mansr.com>
7e448dc
Date: Sun, 5 Nov 2017 16:21:23 +0000
7e448dc
Subject: [PATCH] wav: ima_adpcm: fix buffer overflow on corrupt input
7e448dc
 (CVE-2017-15370)
7e448dc
7e448dc
Add the same check bad block size as was done for MS adpcm in commit
7e448dc
f39c574b ("More checks for invalid MS ADPCM blocks").
7e448dc
---
7e448dc
 src/wav.c | 2 +-
7e448dc
 1 file changed, 1 insertion(+), 1 deletion(-)
7e448dc
7e448dc
diff --git a/src/wav.c b/src/wav.c
7e448dc
index 5202556c..3e80e692 100644
7e448dc
--- a/src/wav.c
7e448dc
+++ b/src/wav.c
7e448dc
@@ -127,7 +127,7 @@ static unsigned short  ImaAdpcmReadBlock(sox_format_t * ft)
7e448dc
         /* work with partial blocks.  Specs say it should be null */
7e448dc
         /* padded but I guess this is better than trailing quiet. */
7e448dc
         samplesThisBlock = lsx_ima_samples_in((size_t)0, (size_t)ft->signal.channels, bytesRead, (size_t) 0);
7e448dc
-        if (samplesThisBlock == 0)
7e448dc
+        if (samplesThisBlock == 0 || samplesThisBlock > wav->samplesPerBlock)
7e448dc
         {
7e448dc
             lsx_warn("Premature EOF on .wav input file");
7e448dc
             return 0;