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
1b3ef155
Commit
1b3ef155
authored
Jul 09, 2012
by
Andrew D'Addesio
Committed by
Justin Ruggles
Jul 19, 2012
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
alac: multi-channel decoding support
Signed-off-by:
Justin Ruggles
<
justin.ruggles@gmail.com
>
parent
81c9e2e6
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
43 additions
and
18 deletions
+43
-18
alac.c
libavcodec/alac.c
+43
-18
No files found.
libavcodec/alac.c
View file @
1b3ef155
...
@@ -45,7 +45,7 @@
...
@@ -45,7 +45,7 @@
* 32bit samplerate
* 32bit samplerate
*/
*/
#include "libavutil/audioconvert.h"
#include "avcodec.h"
#include "avcodec.h"
#include "get_bits.h"
#include "get_bits.h"
#include "bytestream.h"
#include "bytestream.h"
...
@@ -53,7 +53,7 @@
...
@@ -53,7 +53,7 @@
#include "mathops.h"
#include "mathops.h"
#define ALAC_EXTRADATA_SIZE 36
#define ALAC_EXTRADATA_SIZE 36
#define MAX_CHANNELS
2
#define MAX_CHANNELS
8
typedef
struct
{
typedef
struct
{
...
@@ -64,9 +64,9 @@ typedef struct {
...
@@ -64,9 +64,9 @@ typedef struct {
int
channels
;
int
channels
;
/* buffers */
/* buffers */
int32_t
*
predict_error_buffer
[
MAX_CHANNELS
];
int32_t
*
predict_error_buffer
[
2
];
int32_t
*
output_samples_buffer
[
MAX_CHANNELS
];
int32_t
*
output_samples_buffer
[
2
];
int32_t
*
extra_bits_buffer
[
MAX_CHANNELS
];
int32_t
*
extra_bits_buffer
[
2
];
uint32_t
max_samples_per_frame
;
uint32_t
max_samples_per_frame
;
uint8_t
sample_size
;
uint8_t
sample_size
;
...
@@ -90,6 +90,28 @@ enum RawDataBlockType {
...
@@ -90,6 +90,28 @@ enum RawDataBlockType {
TYPE_END
TYPE_END
};
};
static
const
uint8_t
alac_channel_layout_offsets
[
8
][
8
]
=
{
{
0
},
{
0
,
1
},
{
2
,
0
,
1
},
{
2
,
0
,
1
,
3
},
{
2
,
0
,
1
,
3
,
4
},
{
2
,
0
,
1
,
4
,
5
,
3
},
{
2
,
0
,
1
,
4
,
5
,
6
,
3
},
{
2
,
6
,
7
,
0
,
1
,
4
,
5
,
3
}
};
static
const
uint16_t
alac_channel_layouts
[
8
]
=
{
AV_CH_LAYOUT_MONO
,
AV_CH_LAYOUT_STEREO
,
AV_CH_LAYOUT_SURROUND
,
AV_CH_LAYOUT_4POINT0
,
AV_CH_LAYOUT_5POINT0_BACK
,
AV_CH_LAYOUT_5POINT1_BACK
,
AV_CH_LAYOUT_6POINT1_BACK
,
AV_CH_LAYOUT_7POINT1_WIDE_BACK
};
static
inline
unsigned
int
decode_scalar
(
GetBitContext
*
gb
,
int
k
,
static
inline
unsigned
int
decode_scalar
(
GetBitContext
*
gb
,
int
k
,
int
readsamplesize
)
int
readsamplesize
)
{
{
...
@@ -249,7 +271,7 @@ static void predictor_decompress_fir_adapt(int32_t *error_buffer,
...
@@ -249,7 +271,7 @@ static void predictor_decompress_fir_adapt(int32_t *error_buffer,
}
}
}
}
static
void
decorrelate_stereo
(
int32_t
*
buffer
[
MAX_CHANNELS
],
static
void
decorrelate_stereo
(
int32_t
*
buffer
[
2
],
int
numsamples
,
uint8_t
interlacing_shift
,
int
numsamples
,
uint8_t
interlacing_shift
,
uint8_t
interlacing_leftweight
)
uint8_t
interlacing_leftweight
)
{
{
...
@@ -269,8 +291,8 @@ static void decorrelate_stereo(int32_t *buffer[MAX_CHANNELS],
...
@@ -269,8 +291,8 @@ static void decorrelate_stereo(int32_t *buffer[MAX_CHANNELS],
}
}
}
}
static
void
append_extra_bits
(
int32_t
*
buffer
[
MAX_CHANNELS
],
static
void
append_extra_bits
(
int32_t
*
buffer
[
2
],
int32_t
*
extra_bits_buffer
[
MAX_CHANNELS
],
int32_t
*
extra_bits_buffer
[
2
],
int
extra_bits
,
int
numchannels
,
int
numsamples
)
int
extra_bits
,
int
numchannels
,
int
numsamples
)
{
{
int
i
,
ch
;
int
i
,
ch
;
...
@@ -326,7 +348,7 @@ static int decode_element(AVCodecContext *avctx, void *data, int ch_index,
...
@@ -326,7 +348,7 @@ static int decode_element(AVCodecContext *avctx, void *data, int ch_index,
}
}
if
(
alac
->
sample_size
>
16
)
{
if
(
alac
->
sample_size
>
16
)
{
for
(
ch
=
0
;
ch
<
channels
;
ch
++
)
for
(
ch
=
0
;
ch
<
channels
;
ch
++
)
alac
->
output_samples_buffer
[
ch
]
=
(
int32_t
*
)
alac
->
frame
.
data
[
ch_index
+
ch
];
alac
->
output_samples_buffer
[
ch
]
=
(
int32_t
*
)
alac
->
frame
.
extended_
data
[
ch_index
+
ch
];
}
}
}
else
if
(
output_samples
!=
alac
->
nb_samples
)
{
}
else
if
(
output_samples
!=
alac
->
nb_samples
)
{
av_log
(
avctx
,
AV_LOG_ERROR
,
"sample count mismatch: %u != %d
\n
"
,
av_log
(
avctx
,
AV_LOG_ERROR
,
"sample count mismatch: %u != %d
\n
"
,
...
@@ -336,11 +358,11 @@ static int decode_element(AVCodecContext *avctx, void *data, int ch_index,
...
@@ -336,11 +358,11 @@ static int decode_element(AVCodecContext *avctx, void *data, int ch_index,
alac
->
nb_samples
=
output_samples
;
alac
->
nb_samples
=
output_samples
;
if
(
is_compressed
)
{
if
(
is_compressed
)
{
int16_t
predictor_coef_table
[
MAX_CHANNELS
][
32
];
int16_t
predictor_coef_table
[
2
][
32
];
int
predictor_coef_num
[
MAX_CHANNELS
];
int
predictor_coef_num
[
2
];
int
prediction_type
[
MAX_CHANNELS
];
int
prediction_type
[
2
];
int
prediction_quantitization
[
MAX_CHANNELS
];
int
prediction_quantitization
[
2
];
int
ricemodifier
[
MAX_CHANNELS
];
int
ricemodifier
[
2
];
interlacing_shift
=
get_bits
(
&
alac
->
gb
,
8
);
interlacing_shift
=
get_bits
(
&
alac
->
gb
,
8
);
interlacing_leftweight
=
get_bits
(
&
alac
->
gb
,
8
);
interlacing_leftweight
=
get_bits
(
&
alac
->
gb
,
8
);
...
@@ -419,7 +441,7 @@ static int decode_element(AVCodecContext *avctx, void *data, int ch_index,
...
@@ -419,7 +441,7 @@ static int decode_element(AVCodecContext *avctx, void *data, int ch_index,
switch
(
alac
->
sample_size
)
{
switch
(
alac
->
sample_size
)
{
case
16
:
{
case
16
:
{
for
(
ch
=
0
;
ch
<
channels
;
ch
++
)
{
for
(
ch
=
0
;
ch
<
channels
;
ch
++
)
{
int16_t
*
outbuffer
=
(
int16_t
*
)
alac
->
frame
.
data
[
ch_index
+
ch
];
int16_t
*
outbuffer
=
(
int16_t
*
)
alac
->
frame
.
extended_
data
[
ch_index
+
ch
];
for
(
i
=
0
;
i
<
alac
->
nb_samples
;
i
++
)
for
(
i
=
0
;
i
<
alac
->
nb_samples
;
i
++
)
*
outbuffer
++
=
alac
->
output_samples_buffer
[
ch
][
i
];
*
outbuffer
++
=
alac
->
output_samples_buffer
[
ch
][
i
];
}}
}}
...
@@ -462,7 +484,9 @@ static int alac_decode_frame(AVCodecContext *avctx, void *data,
...
@@ -462,7 +484,9 @@ static int alac_decode_frame(AVCodecContext *avctx, void *data,
return
AVERROR_INVALIDDATA
;
return
AVERROR_INVALIDDATA
;
}
}
ret
=
decode_element
(
avctx
,
data
,
ch
,
channels
);
ret
=
decode_element
(
avctx
,
data
,
alac_channel_layout_offsets
[
alac
->
channels
-
1
][
ch
],
channels
);
if
(
ret
<
0
)
if
(
ret
<
0
)
return
ret
;
return
ret
;
...
@@ -484,7 +508,7 @@ static av_cold int alac_decode_close(AVCodecContext *avctx)
...
@@ -484,7 +508,7 @@ static av_cold int alac_decode_close(AVCodecContext *avctx)
ALACContext
*
alac
=
avctx
->
priv_data
;
ALACContext
*
alac
=
avctx
->
priv_data
;
int
ch
;
int
ch
;
for
(
ch
=
0
;
ch
<
alac
->
channels
;
ch
++
)
{
for
(
ch
=
0
;
ch
<
FFMIN
(
alac
->
channels
,
2
)
;
ch
++
)
{
av_freep
(
&
alac
->
predict_error_buffer
[
ch
]);
av_freep
(
&
alac
->
predict_error_buffer
[
ch
]);
if
(
alac
->
sample_size
==
16
)
if
(
alac
->
sample_size
==
16
)
av_freep
(
&
alac
->
output_samples_buffer
[
ch
]);
av_freep
(
&
alac
->
output_samples_buffer
[
ch
]);
...
@@ -497,7 +521,7 @@ static av_cold int alac_decode_close(AVCodecContext *avctx)
...
@@ -497,7 +521,7 @@ static av_cold int alac_decode_close(AVCodecContext *avctx)
static
int
allocate_buffers
(
ALACContext
*
alac
)
static
int
allocate_buffers
(
ALACContext
*
alac
)
{
{
int
ch
;
int
ch
;
for
(
ch
=
0
;
ch
<
alac
->
channels
;
ch
++
)
{
for
(
ch
=
0
;
ch
<
FFMIN
(
alac
->
channels
,
2
)
;
ch
++
)
{
int
buf_size
=
alac
->
max_samples_per_frame
*
sizeof
(
int32_t
);
int
buf_size
=
alac
->
max_samples_per_frame
*
sizeof
(
int32_t
);
FF_ALLOC_OR_GOTO
(
alac
->
avctx
,
alac
->
predict_error_buffer
[
ch
],
FF_ALLOC_OR_GOTO
(
alac
->
avctx
,
alac
->
predict_error_buffer
[
ch
],
...
@@ -588,6 +612,7 @@ static av_cold int alac_decode_init(AVCodecContext * avctx)
...
@@ -588,6 +612,7 @@ static av_cold int alac_decode_init(AVCodecContext * avctx)
avctx
->
channels
);
avctx
->
channels
);
return
AVERROR_PATCHWELCOME
;
return
AVERROR_PATCHWELCOME
;
}
}
avctx
->
channel_layout
=
alac_channel_layouts
[
alac
->
channels
-
1
];
if
((
ret
=
allocate_buffers
(
alac
))
<
0
)
{
if
((
ret
=
allocate_buffers
(
alac
))
<
0
)
{
av_log
(
avctx
,
AV_LOG_ERROR
,
"Error allocating buffers
\n
"
);
av_log
(
avctx
,
AV_LOG_ERROR
,
"Error allocating buffers
\n
"
);
...
...
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