[FFmpeg-devel] [PATCH 2/4] softfloat: use av_normalize1_sf in av_int2sf

Andreas Cadhalpun andreas.cadhalpun at googlemail.com
Sun Nov 8 21:11:06 CET 2015


On 08.11.2015 19:40, Michael Niedermayer wrote:
> On Sun, Nov 08, 2015 at 05:23:32PM +0100, Andreas Cadhalpun wrote:
>> Updated variant attached.
>>
>> Best regards,
>> Andreas
> 
>>  softfloat.h |    7 ++++++-
>>  1 file changed, 6 insertions(+), 1 deletion(-)
>> 1621ecf24466d8c1ad8cb394a079a59f39a98e4d  0001-softfloat-handle-INT_MIN-correctly-in-av_int2sf.patch
>> From 50000b9a0ebd17d046d7a99f6388f7fb30ff66e6 Mon Sep 17 00:00:00 2001
>> From: Andreas Cadhalpun <Andreas.Cadhalpun at googlemail.com>
>> Date: Sun, 8 Nov 2015 17:19:10 +0100
>> Subject: [PATCH] softfloat: handle INT_MIN correctly in av_int2sf
>>
>> Otherwise v=INT_MIN doesn't get normalized and thus triggers av_assert2
>> in other functions.
>>
>> Signed-off-by: Andreas Cadhalpun <Andreas.Cadhalpun at googlemail.com>
>> ---
>>  libavutil/softfloat.h | 7 ++++++-
>>  1 file changed, 6 insertions(+), 1 deletion(-)
>>
>> diff --git a/libavutil/softfloat.h b/libavutil/softfloat.h
>> index 4cc3ceb..5b285e3 100644
>> --- a/libavutil/softfloat.h
>> +++ b/libavutil/softfloat.h
>> @@ -153,7 +153,12 @@ static inline av_const SoftFloat av_sub_sf(SoftFloat a, SoftFloat b){
>>   * @returns a SoftFloat with value v * 2^frac_bits
>>   */
>>  static inline av_const SoftFloat av_int2sf(int v, int frac_bits){
>> -    return av_normalize_sf((SoftFloat){v, ONE_BITS + 1 - frac_bits});
>> +    int exp_offset = 0;
>> +    if(v == INT_MIN){
>> +        exp_offset = 1;
>> +        v>>=1;
>> +    }
>> +    return av_normalize_sf(av_normalize1_sf((SoftFloat){v, ONE_BITS + 1 - frac_bits + exp_offset}));
> 
> should be ok

Pushed.

Best regards,
Andreas




More information about the ffmpeg-devel mailing list