diff --git a/libavcodec/adpcmenc.c b/libavcodec/adpcmenc.c
index 843b32fae51254ea03644c99937c62a1d8bb3912..f8ecd589dce0ecc296cc89731c87d1163ac789f4 100644
--- a/libavcodec/adpcmenc.c
+++ b/libavcodec/adpcmenc.c
@@ -570,7 +570,7 @@ static int adpcm_encode_frame(AVCodecContext *avctx, AVPacket *avpkt,
         init_put_bits(&pb, dst, pkt_size * 8);
 
         for (ch = 0; ch < avctx->channels; ch++) {
-            put_bits(&pb, 9, (c->status[ch].prev_sample + 0x10000) >> 7);
+            put_bits(&pb, 9, (c->status[ch].prev_sample & 0xFFFF) >> 7);
             put_bits(&pb, 7,  c->status[ch].step_index);
             if (avctx->trellis > 0) {
                 uint8_t buf[64];
diff --git a/tests/ref/fate/acodec-adpcm-ima_qt b/tests/ref/fate/acodec-adpcm-ima_qt
index 79b8c60ccc17cd94a7173b2310bd82ed10794167..80015275fc21c23fec76ddeab80f2aea26c29134 100644
--- a/tests/ref/fate/acodec-adpcm-ima_qt
+++ b/tests/ref/fate/acodec-adpcm-ima_qt
@@ -1,4 +1,4 @@
-057d27978b35888776512e4e9669a63b *tests/data/fate/acodec-adpcm-ima_qt.aiff
+23cbae1182e150ebf28e0abfb9cba127 *tests/data/fate/acodec-adpcm-ima_qt.aiff
 281252 tests/data/fate/acodec-adpcm-ima_qt.aiff
-169c40435c68d50112c9c61fc67e446d *tests/data/fate/acodec-adpcm-ima_qt.out.wav
-stddev:  918.61 PSNR: 37.07 MAXDIFF:34029 bytes:  1058400/  1058560
+b0fafd002c38fb70acaddfda1a31ed61 *tests/data/fate/acodec-adpcm-ima_qt.out.wav
+stddev:  904.76 PSNR: 37.20 MAXDIFF:34029 bytes:  1058400/  1058560