mpc: assume the result fo of mpc_decoder_decode() is unsigned
According to the documentation, mpc_decoder_decode() returns an mpc_uint32_t. Since the special return value (mpc_uint32_t)-1 translates to a very large long integer, this may cause segmentation faults if not interpreted properly.
This commit is contained in:
parent
0a6f4048d0
commit
eff21067f0
@ -115,7 +115,7 @@ mpc_decode(struct decoder *mpd_decoder, struct input_stream *inStream)
|
|||||||
|
|
||||||
MPC_SAMPLE_FORMAT sample_buffer[MPC_DECODER_BUFFER_LENGTH];
|
MPC_SAMPLE_FORMAT sample_buffer[MPC_DECODER_BUFFER_LENGTH];
|
||||||
|
|
||||||
long ret;
|
mpc_uint32_t ret;
|
||||||
int32_t chunk[G_N_ELEMENTS(sample_buffer)];
|
int32_t chunk[G_N_ELEMENTS(sample_buffer)];
|
||||||
long bitRate = 0;
|
long bitRate = 0;
|
||||||
unsigned long samplePos = 0;
|
unsigned long samplePos = 0;
|
||||||
@ -179,7 +179,7 @@ mpc_decode(struct decoder *mpd_decoder, struct input_stream *inStream)
|
|||||||
vbrUpdateBits = 0;
|
vbrUpdateBits = 0;
|
||||||
ret = mpc_decoder_decode(&decoder, sample_buffer,
|
ret = mpc_decoder_decode(&decoder, sample_buffer,
|
||||||
&vbrUpdateAcc, &vbrUpdateBits);
|
&vbrUpdateAcc, &vbrUpdateBits);
|
||||||
if (ret <= 0)
|
if (ret == 0 || ret == (mpc_uint32_t)-1)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
samplePos += ret;
|
samplePos += ret;
|
||||||
|
Loading…
Reference in New Issue
Block a user