Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in / Register
Toggle navigation
F
ffmpeg.wasm-core
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Linshizhi
ffmpeg.wasm-core
Commits
a31787ee
Commit
a31787ee
authored
Apr 11, 2012
by
Mans Rullgard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
qdm2: use get_bits_left()
Signed-off-by:
Mans Rullgard
<
mans@mansr.com
>
parent
7bb3a302
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
21 additions
and
25 deletions
+21
-25
qdm2.c
libavcodec/qdm2.c
+21
-25
No files found.
libavcodec/qdm2.c
View file @
a31787ee
...
@@ -69,8 +69,6 @@ do { \
...
@@ -69,8 +69,6 @@ do { \
#define SB_DITHERING_NOISE(sb,noise_idx) (noise_table[(noise_idx)++] * sb_noise_attenuation[(sb)])
#define SB_DITHERING_NOISE(sb,noise_idx) (noise_table[(noise_idx)++] * sb_noise_attenuation[(sb)])
#define BITS_LEFT(length,gb) ((length) - get_bits_count ((gb)))
#define SAMPLES_NEEDED \
#define SAMPLES_NEEDED \
av_log (NULL,AV_LOG_INFO,"This file triggers some untested code. Please contact the developers.\n");
av_log (NULL,AV_LOG_INFO,"This file triggers some untested code. Please contact the developers.\n");
...
@@ -793,10 +791,10 @@ static void synthfilt_build_sb_samples (QDM2Context *q, GetBitContext *gb, int l
...
@@ -793,10 +791,10 @@ static void synthfilt_build_sb_samples (QDM2Context *q, GetBitContext *gb, int l
else
if
(
sb
>=
24
)
else
if
(
sb
>=
24
)
joined_stereo
=
1
;
joined_stereo
=
1
;
else
else
joined_stereo
=
(
BITS_LEFT
(
length
,
gb
)
>=
1
)
?
get_bits1
(
gb
)
:
0
;
joined_stereo
=
(
get_bits_left
(
gb
)
>=
1
)
?
get_bits1
(
gb
)
:
0
;
if
(
joined_stereo
)
{
if
(
joined_stereo
)
{
if
(
BITS_LEFT
(
length
,
gb
)
>=
16
)
if
(
get_bits_left
(
gb
)
>=
16
)
for
(
j
=
0
;
j
<
16
;
j
++
)
for
(
j
=
0
;
j
<
16
;
j
++
)
sign_bits
[
j
]
=
get_bits1
(
gb
);
sign_bits
[
j
]
=
get_bits1
(
gb
);
...
@@ -809,14 +807,14 @@ static void synthfilt_build_sb_samples (QDM2Context *q, GetBitContext *gb, int l
...
@@ -809,14 +807,14 @@ static void synthfilt_build_sb_samples (QDM2Context *q, GetBitContext *gb, int l
}
}
for
(
ch
=
0
;
ch
<
channels
;
ch
++
)
{
for
(
ch
=
0
;
ch
<
channels
;
ch
++
)
{
zero_encoding
=
(
BITS_LEFT
(
length
,
gb
)
>=
1
)
?
get_bits1
(
gb
)
:
0
;
zero_encoding
=
(
get_bits_left
(
gb
)
>=
1
)
?
get_bits1
(
gb
)
:
0
;
type34_predictor
=
0
.
0
;
type34_predictor
=
0
.
0
;
type34_first
=
1
;
type34_first
=
1
;
for
(
j
=
0
;
j
<
128
;
)
{
for
(
j
=
0
;
j
<
128
;
)
{
switch
(
q
->
coding_method
[
ch
][
sb
][
j
/
2
])
{
switch
(
q
->
coding_method
[
ch
][
sb
][
j
/
2
])
{
case
8
:
case
8
:
if
(
BITS_LEFT
(
length
,
gb
)
>=
10
)
{
if
(
get_bits_left
(
gb
)
>=
10
)
{
if
(
zero_encoding
)
{
if
(
zero_encoding
)
{
for
(
k
=
0
;
k
<
5
;
k
++
)
{
for
(
k
=
0
;
k
<
5
;
k
++
)
{
if
((
j
+
2
*
k
)
>=
128
)
if
((
j
+
2
*
k
)
>=
128
)
...
@@ -838,7 +836,7 @@ static void synthfilt_build_sb_samples (QDM2Context *q, GetBitContext *gb, int l
...
@@ -838,7 +836,7 @@ static void synthfilt_build_sb_samples (QDM2Context *q, GetBitContext *gb, int l
break
;
break
;
case
10
:
case
10
:
if
(
BITS_LEFT
(
length
,
gb
)
>=
1
)
{
if
(
get_bits_left
(
gb
)
>=
1
)
{
float
f
=
0
.
81
;
float
f
=
0
.
81
;
if
(
get_bits1
(
gb
))
if
(
get_bits1
(
gb
))
...
@@ -852,7 +850,7 @@ static void synthfilt_build_sb_samples (QDM2Context *q, GetBitContext *gb, int l
...
@@ -852,7 +850,7 @@ static void synthfilt_build_sb_samples (QDM2Context *q, GetBitContext *gb, int l
break
;
break
;
case
16
:
case
16
:
if
(
BITS_LEFT
(
length
,
gb
)
>=
10
)
{
if
(
get_bits_left
(
gb
)
>=
10
)
{
if
(
zero_encoding
)
{
if
(
zero_encoding
)
{
for
(
k
=
0
;
k
<
5
;
k
++
)
{
for
(
k
=
0
;
k
<
5
;
k
++
)
{
if
((
j
+
k
)
>=
128
)
if
((
j
+
k
)
>=
128
)
...
@@ -872,7 +870,7 @@ static void synthfilt_build_sb_samples (QDM2Context *q, GetBitContext *gb, int l
...
@@ -872,7 +870,7 @@ static void synthfilt_build_sb_samples (QDM2Context *q, GetBitContext *gb, int l
break
;
break
;
case
24
:
case
24
:
if
(
BITS_LEFT
(
length
,
gb
)
>=
7
)
{
if
(
get_bits_left
(
gb
)
>=
7
)
{
n
=
get_bits
(
gb
,
7
);
n
=
get_bits
(
gb
,
7
);
for
(
k
=
0
;
k
<
3
;
k
++
)
for
(
k
=
0
;
k
<
3
;
k
++
)
samples
[
k
]
=
(
random_dequant_type24
[
n
][
k
]
-
2
.
0
)
*
0
.
5
;
samples
[
k
]
=
(
random_dequant_type24
[
n
][
k
]
-
2
.
0
)
*
0
.
5
;
...
@@ -884,7 +882,7 @@ static void synthfilt_build_sb_samples (QDM2Context *q, GetBitContext *gb, int l
...
@@ -884,7 +882,7 @@ static void synthfilt_build_sb_samples (QDM2Context *q, GetBitContext *gb, int l
break
;
break
;
case
30
:
case
30
:
if
(
BITS_LEFT
(
length
,
gb
)
>=
4
)
if
(
get_bits_left
(
gb
)
>=
4
)
samples
[
0
]
=
type30_dequant
[
qdm2_get_vlc
(
gb
,
&
vlc_tab_type30
,
0
,
1
)];
samples
[
0
]
=
type30_dequant
[
qdm2_get_vlc
(
gb
,
&
vlc_tab_type30
,
0
,
1
)];
else
else
samples
[
0
]
=
SB_DITHERING_NOISE
(
sb
,
q
->
noise_idx
);
samples
[
0
]
=
SB_DITHERING_NOISE
(
sb
,
q
->
noise_idx
);
...
@@ -893,7 +891,7 @@ static void synthfilt_build_sb_samples (QDM2Context *q, GetBitContext *gb, int l
...
@@ -893,7 +891,7 @@ static void synthfilt_build_sb_samples (QDM2Context *q, GetBitContext *gb, int l
break
;
break
;
case
34
:
case
34
:
if
(
BITS_LEFT
(
length
,
gb
)
>=
7
)
{
if
(
get_bits_left
(
gb
)
>=
7
)
{
if
(
type34_first
)
{
if
(
type34_first
)
{
type34_div
=
(
float
)(
1
<<
get_bits
(
gb
,
2
));
type34_div
=
(
float
)(
1
<<
get_bits
(
gb
,
2
));
samples
[
0
]
=
((
float
)
get_bits
(
gb
,
5
)
-
16
.
0
)
/
15
.
0
;
samples
[
0
]
=
((
float
)
get_bits
(
gb
,
5
)
-
16
.
0
)
/
15
.
0
;
...
@@ -946,24 +944,23 @@ static void synthfilt_build_sb_samples (QDM2Context *q, GetBitContext *gb, int l
...
@@ -946,24 +944,23 @@ static void synthfilt_build_sb_samples (QDM2Context *q, GetBitContext *gb, int l
*
*
* @param quantized_coeffs pointer to quantized_coeffs[ch][0]
* @param quantized_coeffs pointer to quantized_coeffs[ch][0]
* @param gb bitreader context
* @param gb bitreader context
* @param length packet length in bits
*/
*/
static
void
init_quantized_coeffs_elem0
(
int8_t
*
quantized_coeffs
,
GetBitContext
*
gb
,
int
length
)
static
void
init_quantized_coeffs_elem0
(
int8_t
*
quantized_coeffs
,
GetBitContext
*
gb
)
{
{
int
i
,
k
,
run
,
level
,
diff
;
int
i
,
k
,
run
,
level
,
diff
;
if
(
BITS_LEFT
(
length
,
gb
)
<
16
)
if
(
get_bits_left
(
gb
)
<
16
)
return
;
return
;
level
=
qdm2_get_vlc
(
gb
,
&
vlc_tab_level
,
0
,
2
);
level
=
qdm2_get_vlc
(
gb
,
&
vlc_tab_level
,
0
,
2
);
quantized_coeffs
[
0
]
=
level
;
quantized_coeffs
[
0
]
=
level
;
for
(
i
=
0
;
i
<
7
;
)
{
for
(
i
=
0
;
i
<
7
;
)
{
if
(
BITS_LEFT
(
length
,
gb
)
<
16
)
if
(
get_bits_left
(
gb
)
<
16
)
break
;
break
;
run
=
qdm2_get_vlc
(
gb
,
&
vlc_tab_run
,
0
,
1
)
+
1
;
run
=
qdm2_get_vlc
(
gb
,
&
vlc_tab_run
,
0
,
1
)
+
1
;
if
(
BITS_LEFT
(
length
,
gb
)
<
16
)
if
(
get_bits_left
(
gb
)
<
16
)
break
;
break
;
diff
=
qdm2_get_se_vlc
(
&
vlc_tab_diff
,
gb
,
2
);
diff
=
qdm2_get_se_vlc
(
&
vlc_tab_diff
,
gb
,
2
);
...
@@ -983,16 +980,15 @@ static void init_quantized_coeffs_elem0 (int8_t *quantized_coeffs, GetBitContext
...
@@ -983,16 +980,15 @@ static void init_quantized_coeffs_elem0 (int8_t *quantized_coeffs, GetBitContext
*
*
* @param q context
* @param q context
* @param gb bitreader context
* @param gb bitreader context
* @param length packet length in bits
*/
*/
static
void
init_tone_level_dequantization
(
QDM2Context
*
q
,
GetBitContext
*
gb
,
int
length
)
static
void
init_tone_level_dequantization
(
QDM2Context
*
q
,
GetBitContext
*
gb
)
{
{
int
sb
,
j
,
k
,
n
,
ch
;
int
sb
,
j
,
k
,
n
,
ch
;
for
(
ch
=
0
;
ch
<
q
->
nb_channels
;
ch
++
)
{
for
(
ch
=
0
;
ch
<
q
->
nb_channels
;
ch
++
)
{
init_quantized_coeffs_elem0
(
q
->
quantized_coeffs
[
ch
][
0
],
gb
,
length
);
init_quantized_coeffs_elem0
(
q
->
quantized_coeffs
[
ch
][
0
],
gb
);
if
(
BITS_LEFT
(
length
,
gb
)
<
16
)
{
if
(
get_bits_left
(
gb
)
<
16
)
{
memset
(
q
->
quantized_coeffs
[
ch
][
0
],
0
,
8
);
memset
(
q
->
quantized_coeffs
[
ch
][
0
],
0
,
8
);
break
;
break
;
}
}
...
@@ -1003,11 +999,11 @@ static void init_tone_level_dequantization (QDM2Context *q, GetBitContext *gb, i
...
@@ -1003,11 +999,11 @@ static void init_tone_level_dequantization (QDM2Context *q, GetBitContext *gb, i
for
(
sb
=
0
;
sb
<
n
;
sb
++
)
for
(
sb
=
0
;
sb
<
n
;
sb
++
)
for
(
ch
=
0
;
ch
<
q
->
nb_channels
;
ch
++
)
for
(
ch
=
0
;
ch
<
q
->
nb_channels
;
ch
++
)
for
(
j
=
0
;
j
<
8
;
j
++
)
{
for
(
j
=
0
;
j
<
8
;
j
++
)
{
if
(
BITS_LEFT
(
length
,
gb
)
<
1
)
if
(
get_bits_left
(
gb
)
<
1
)
break
;
break
;
if
(
get_bits1
(
gb
))
{
if
(
get_bits1
(
gb
))
{
for
(
k
=
0
;
k
<
8
;
k
++
)
{
for
(
k
=
0
;
k
<
8
;
k
++
)
{
if
(
BITS_LEFT
(
length
,
gb
)
<
16
)
if
(
get_bits_left
(
gb
)
<
16
)
break
;
break
;
q
->
tone_level_idx_hi1
[
ch
][
sb
][
j
][
k
]
=
qdm2_get_vlc
(
gb
,
&
vlc_tab_tone_level_idx_hi1
,
0
,
2
);
q
->
tone_level_idx_hi1
[
ch
][
sb
][
j
][
k
]
=
qdm2_get_vlc
(
gb
,
&
vlc_tab_tone_level_idx_hi1
,
0
,
2
);
}
}
...
@@ -1021,7 +1017,7 @@ static void init_tone_level_dequantization (QDM2Context *q, GetBitContext *gb, i
...
@@ -1021,7 +1017,7 @@ static void init_tone_level_dequantization (QDM2Context *q, GetBitContext *gb, i
for
(
sb
=
0
;
sb
<
n
;
sb
++
)
for
(
sb
=
0
;
sb
<
n
;
sb
++
)
for
(
ch
=
0
;
ch
<
q
->
nb_channels
;
ch
++
)
{
for
(
ch
=
0
;
ch
<
q
->
nb_channels
;
ch
++
)
{
if
(
BITS_LEFT
(
length
,
gb
)
<
16
)
if
(
get_bits_left
(
gb
)
<
16
)
break
;
break
;
q
->
tone_level_idx_hi2
[
ch
][
sb
]
=
qdm2_get_vlc
(
gb
,
&
vlc_tab_tone_level_idx_hi2
,
0
,
2
);
q
->
tone_level_idx_hi2
[
ch
][
sb
]
=
qdm2_get_vlc
(
gb
,
&
vlc_tab_tone_level_idx_hi2
,
0
,
2
);
if
(
sb
>
19
)
if
(
sb
>
19
)
...
@@ -1036,7 +1032,7 @@ static void init_tone_level_dequantization (QDM2Context *q, GetBitContext *gb, i
...
@@ -1036,7 +1032,7 @@ static void init_tone_level_dequantization (QDM2Context *q, GetBitContext *gb, i
for
(
sb
=
0
;
sb
<
n
;
sb
++
)
for
(
sb
=
0
;
sb
<
n
;
sb
++
)
for
(
ch
=
0
;
ch
<
q
->
nb_channels
;
ch
++
)
for
(
ch
=
0
;
ch
<
q
->
nb_channels
;
ch
++
)
for
(
j
=
0
;
j
<
8
;
j
++
)
{
for
(
j
=
0
;
j
<
8
;
j
++
)
{
if
(
BITS_LEFT
(
length
,
gb
)
<
16
)
if
(
get_bits_left
(
gb
)
<
16
)
break
;
break
;
q
->
tone_level_idx_mid
[
ch
][
sb
][
j
]
=
qdm2_get_vlc
(
gb
,
&
vlc_tab_tone_level_idx_mid
,
0
,
2
)
-
32
;
q
->
tone_level_idx_mid
[
ch
][
sb
][
j
]
=
qdm2_get_vlc
(
gb
,
&
vlc_tab_tone_level_idx_mid
,
0
,
2
)
-
32
;
}
}
...
@@ -1094,7 +1090,7 @@ static void process_subpacket_10 (QDM2Context *q, QDM2SubPNode *node, int length
...
@@ -1094,7 +1090,7 @@ static void process_subpacket_10 (QDM2Context *q, QDM2SubPNode *node, int length
init_get_bits
(
&
gb
,
((
node
==
NULL
)
?
empty_buffer
:
node
->
packet
->
data
),
((
node
==
NULL
)
?
0
:
node
->
packet
->
size
*
8
));
init_get_bits
(
&
gb
,
((
node
==
NULL
)
?
empty_buffer
:
node
->
packet
->
data
),
((
node
==
NULL
)
?
0
:
node
->
packet
->
size
*
8
));
if
(
length
!=
0
)
{
if
(
length
!=
0
)
{
init_tone_level_dequantization
(
q
,
&
gb
,
length
);
init_tone_level_dequantization
(
q
,
&
gb
);
fill_tone_level_array
(
q
,
1
);
fill_tone_level_array
(
q
,
1
);
}
else
{
}
else
{
fill_tone_level_array
(
q
,
0
);
fill_tone_level_array
(
q
,
0
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment