Commit d462add1 authored by reynaldo's avatar reynaldo

Fix possibly harmful outbound addressing. Patch by Kenan Gillet.


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@18528 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 4ae3cbb9
...@@ -61,15 +61,14 @@ int ff_celp_lp_synthesis_filter( ...@@ -61,15 +61,14 @@ int ff_celp_lp_synthesis_filter(
{ {
int i,n; int i,n;
// These two lines are to avoid a -1 subtraction in the main loop // This line is to avoid a +1 subtraction in the main loop.
filter_length++; filter_length++;
filter_coeffs--;
for(n=0; n<buffer_length; n++) for(n=0; n<buffer_length; n++)
{ {
int sum = rounder; int sum = rounder;
for(i=1; i<filter_length; i++) for(i=1; i<filter_length; i++)
sum -= filter_coeffs[i] * out[n-i]; sum -= filter_coeffs[i-1] * out[n-i];
sum = (sum >> 12) + in[n]; sum = (sum >> 12) + in[n];
...@@ -94,14 +93,13 @@ void ff_celp_lp_synthesis_filterf( ...@@ -94,14 +93,13 @@ void ff_celp_lp_synthesis_filterf(
{ {
int i,n; int i,n;
// These two lines are to avoid a -1 subtraction in the main loop // This line is to avoid a +1 subtraction in the main loop
filter_length++; filter_length++;
filter_coeffs--;
for(n=0; n<buffer_length; n++) for(n=0; n<buffer_length; n++)
{ {
out[n] = in[n]; out[n] = in[n];
for(i=1; i<filter_length; i++) for(i=1; i<filter_length; i++)
out[n] -= filter_coeffs[i] * out[n-i]; out[n] -= filter_coeffs[i-1] * out[n-i];
} }
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment