[OE-core] [PATCH] speex: Scale float input when FIXED_POINT is defined

Arslan, Fahad Fahad_Arslan at mentor.com
Tue Dec 24 13:52:08 UTC 2013


Patch to Speex upstream has been denied with reason that fixing this will break other 
applications using it. 

I think appropriate place to fix the issue is Pulseaudio code. I've submitted patch 
upstream for that and sending a new patch for that to oe-core as well and this speex 
patch may be dropped. 

Fahad
________________________________________
From: Saul Wold [sgw at linux.intel.com]
Sent: Friday, December 20, 2013 9:14 PM
To: Arslan, Fahad; openembedded-core at lists.openembedded.org
Subject: Re: [OE-core] [PATCH] speex: Scale float input when FIXED_POINT is defined

On 12/20/2013 08:06 AM, Fahad Arslan wrote:
> From: Fahad Arslan <Fahad_Arslan at mentor.com>
>
> When Speex is compiled with FIXED_POINT defined, it scales float
> input to +/-32768 instead of +/-1. This was being missed at one
> point causing the input to the resampler to be zeroed. As a result
> there was no audio output.
>
> Signed-off-by: Fahad Arslan <Fahad_Arslan at mentor.com>
> ---
>   .../speex/speex/scaling_fix.patch                  |   12 ++++++++++++
>   meta/recipes-multimedia/speex/speex_1.2rc1.bb      |    3 ++-
>   2 files changed, 14 insertions(+), 1 deletion(-)
>
> diff --git a/meta/recipes-multimedia/speex/speex/scaling_fix.patch b/meta/recipes-multimedia/speex/speex/scaling_fix.patch
> new file mode 100644
> index 0000000..a6340d7
> --- /dev/null
> +++ b/meta/recipes-multimedia/speex/speex/scaling_fix.patch

The patch needs Upstream-Status: and Signed-off-by: tags please

Sau!

> @@ -0,0 +1,12 @@
> +diff -NaurbB a/libspeex/resample.c b/libspeex/resample.c
> +--- a/libspeex/resample.c    2013-12-20 19:47:49.154454769 +0500
> ++++ b/libspeex/resample.c    2013-12-20 19:48:16.558454331 +0500
> +@@ -915,7 +915,7 @@
> +        if (in) {
> +          for(j=0;j<ichunk;++j)
> + #ifdef FIXED_POINT
> +-           x[j+st->filt_len-1]=WORD2INT(in[j*istride_save]);
> ++           x[j+st->filt_len-1]=WORD2INT(32768.*in[j*istride_save]);
> + #else
> +            x[j+st->filt_len-1]=in[j*istride_save];
> + #endif
> diff --git a/meta/recipes-multimedia/speex/speex_1.2rc1.bb b/meta/recipes-multimedia/speex/speex_1.2rc1.bb
> index faf63b0..0fea51e 100644
> --- a/meta/recipes-multimedia/speex/speex_1.2rc1.bb
> +++ b/meta/recipes-multimedia/speex/speex_1.2rc1.bb
> @@ -9,7 +9,8 @@ DEPENDS = "libogg"
>
>   PR = "r2"
>
> -SRC_URI = "http://downloads.us.xiph.org/releases/speex/speex-1.2rc1.tar.gz"
> +SRC_URI = "http://downloads.us.xiph.org/releases/speex/speex-1.2rc1.tar.gz \
> +           file://scaling_fix.patch"
>
>   SRC_URI[md5sum] = "c4438b22c08e5811ff10e2b06ee9b9ae"
>   SRC_URI[sha256sum] = "342f30dc57bd4a6dad41398365baaa690429660b10d866b7d508e8f1179cb7a6"
>



More information about the Openembedded-core mailing list