mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2025-12-26 12:50:10 +01:00
radeonsi/vcn: Fix radeon_enc_code_ue with values over 2^16
Values over 2^16 as ue(v) are encoded with more than 32 bits, but radeon_enc_code_fixed_bits can only handle 32 bits at max. Change radeon_enc_code_ue to code the leading zeros separately. Reviewed-by: Ruijing Dong <ruijing.dong@amd.com> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/30672>
This commit is contained in:
parent
40d01175be
commit
138ba42a87
1 changed files with 4 additions and 3 deletions
|
|
@ -1914,7 +1914,7 @@ void radeon_enc_flush_headers(struct radeon_encoder *enc)
|
|||
|
||||
void radeon_enc_code_ue(struct radeon_encoder *enc, unsigned int value)
|
||||
{
|
||||
int x = -1;
|
||||
unsigned int x = 0;
|
||||
unsigned int ue_code = value + 1;
|
||||
value += 1;
|
||||
|
||||
|
|
@ -1923,8 +1923,9 @@ void radeon_enc_code_ue(struct radeon_encoder *enc, unsigned int value)
|
|||
x += 1;
|
||||
}
|
||||
|
||||
unsigned int ue_length = (x << 1) + 1;
|
||||
radeon_enc_code_fixed_bits(enc, ue_code, ue_length);
|
||||
if (x > 1)
|
||||
radeon_enc_code_fixed_bits(enc, 0, x - 1);
|
||||
radeon_enc_code_fixed_bits(enc, ue_code, x);
|
||||
}
|
||||
|
||||
void radeon_enc_code_se(struct radeon_encoder *enc, int value)
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue