sig_scaled[i] = residual[i] >> shift;
else
for (i = 0; i < subframe_size + RES_PREV_DATA_SIZE; i++)
- sig_scaled[i] = residual[i] << -shift;
+ sig_scaled[i] = (unsigned)residual[i] << -shift;
/* Start of best delay searching code */
gain_num = 0;
tmp = res_pst[subframe_size - 1];
for (i = subframe_size - 1; i >= 1; i--) {
- tmp2 = (res_pst[i] << 15) + ((gt * res_pst[i-1]) << 1);
- tmp2 = (tmp2 + 0x4000) >> 15;
+ tmp2 = (gt * res_pst[i-1]) * 2 + 0x4000;
+ tmp2 = res_pst[i] + (tmp2 >> 15);
tmp2 = (tmp2 * ga * 2 + fact) >> sh_fact;
out[i] = tmp2;
}
- tmp2 = (res_pst[0] << 15) + ((gt * ht_prev_data) << 1);
- tmp2 = (tmp2 + 0x4000) >> 15;
+ tmp2 = (gt * ht_prev_data) * 2 + 0x4000;
+ tmp2 = res_pst[0] + (tmp2 >> 15);
tmp2 = (tmp2 * ga * 2 + fact) >> sh_fact;
out[0] = tmp2;