mirror of
https://github.com/xenia-project/FFmpeg.git
synced 2024-11-24 03:59:43 +00:00
avcodec/ttaenc: Fix undefined shift
ttaenc contained (1 << unary) - 1 as an argument for a function expecting an unsigned int. unary can be as big as 31 in this case. The type of the shift and the whole expression is int, because 1 fits into an integer, so that the behaviour is undefined if unary == 31 as the result of the shift can't be represented in an int §. Subtraction by 1 (which makes the result of the whole expression representable in an int) doesn't change that this is undefined (it usually leads to signed integer overflow which is undefined, too). The solution is simple: Make 1 unsigned to change the type of the whole expression to unsigned int (as the function expects anyway). Fixes ticket #8153. §: This of course presupposes the common int range of -2^31..2^31-1 Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@gmail.com> Reviewed-by: Paul B Mahol <onemda@gmail.com> Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
This commit is contained in:
parent
551fcbbccb
commit
3ab488a540
@ -164,7 +164,7 @@ pkt_alloc:
|
||||
put_bits(&pb, 31, 0x7FFFFFFF);
|
||||
unary -= 31;
|
||||
} else {
|
||||
put_bits(&pb, unary, (1 << unary) - 1);
|
||||
put_bits(&pb, unary, (1U << unary) - 1);
|
||||
unary = 0;
|
||||
}
|
||||
} while (unary);
|
||||
|
Loading…
Reference in New Issue
Block a user