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
a964d6a8
Commit
a964d6a8
authored
Mar 16, 2013
by
Nicolas George
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
lavu/frame: use channels rather than channel_layout.
parent
0d09aa9d
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
16 additions
and
5 deletions
+16
-5
frame.c
libavutil/frame.c
+16
-5
No files found.
libavutil/frame.c
View file @
a964d6a8
...
@@ -18,6 +18,7 @@
...
@@ -18,6 +18,7 @@
*/
*/
#include "channel_layout.h"
#include "channel_layout.h"
#include "avassert.h"
#include "buffer.h"
#include "buffer.h"
#include "common.h"
#include "common.h"
#include "dict.h"
#include "dict.h"
...
@@ -40,6 +41,11 @@ MAKE_ACCESSORS(AVFrame, frame, AVDictionary *, metadata)
...
@@ -40,6 +41,11 @@ MAKE_ACCESSORS(AVFrame, frame, AVDictionary *, metadata)
MAKE_ACCESSORS
(
AVFrame
,
frame
,
int
,
decode_error_flags
)
MAKE_ACCESSORS
(
AVFrame
,
frame
,
int
,
decode_error_flags
)
MAKE_ACCESSORS
(
AVFrame
,
frame
,
int
,
pkt_size
)
MAKE_ACCESSORS
(
AVFrame
,
frame
,
int
,
pkt_size
)
#define CHECK_CHANNELS_CONSISTENCY(frame) \
av_assert2(!(frame)->channel_layout || \
(frame)->channels == \
av_get_channel_layout_nb_channels((frame)->channel_layout))
AVDictionary
**
avpriv_frame_get_metadatap
(
AVFrame
*
frame
)
{
return
&
frame
->
metadata
;};
AVDictionary
**
avpriv_frame_get_metadatap
(
AVFrame
*
frame
)
{
return
&
frame
->
metadata
;};
int
av_frame_set_qp_table
(
AVFrame
*
f
,
AVBufferRef
*
buf
,
int
stride
,
int
qp_type
)
int
av_frame_set_qp_table
(
AVFrame
*
f
,
AVBufferRef
*
buf
,
int
stride
,
int
qp_type
)
...
@@ -158,11 +164,12 @@ fail:
...
@@ -158,11 +164,12 @@ fail:
static
int
get_audio_buffer
(
AVFrame
*
frame
,
int
align
)
static
int
get_audio_buffer
(
AVFrame
*
frame
,
int
align
)
{
{
int
channels
=
av_get_channel_layout_nb_channels
(
frame
->
channel_layout
)
;
int
channels
=
frame
->
channels
;
int
planar
=
av_sample_fmt_is_planar
(
frame
->
format
);
int
planar
=
av_sample_fmt_is_planar
(
frame
->
format
);
int
planes
=
planar
?
channels
:
1
;
int
planes
=
planar
?
channels
:
1
;
int
ret
,
i
;
int
ret
,
i
;
CHECK_CHANNELS_CONSISTENCY
(
frame
);
if
(
!
frame
->
linesize
[
0
])
{
if
(
!
frame
->
linesize
[
0
])
{
ret
=
av_samples_get_buffer_size
(
&
frame
->
linesize
[
0
],
channels
,
ret
=
av_samples_get_buffer_size
(
&
frame
->
linesize
[
0
],
channels
,
frame
->
nb_samples
,
frame
->
format
,
frame
->
nb_samples
,
frame
->
format
,
...
@@ -240,7 +247,8 @@ int av_frame_ref(AVFrame *dst, AVFrame *src)
...
@@ -240,7 +247,8 @@ int av_frame_ref(AVFrame *dst, AVFrame *src)
return
ret
;
return
ret
;
if
(
src
->
nb_samples
)
{
if
(
src
->
nb_samples
)
{
int
ch
=
av_get_channel_layout_nb_channels
(
src
->
channel_layout
);
int
ch
=
src
->
channels
;
CHECK_CHANNELS_CONSISTENCY
(
src
);
av_samples_copy
(
dst
->
extended_data
,
src
->
extended_data
,
0
,
0
,
av_samples_copy
(
dst
->
extended_data
,
src
->
extended_data
,
0
,
0
,
dst
->
nb_samples
,
ch
,
dst
->
format
);
dst
->
nb_samples
,
ch
,
dst
->
format
);
}
else
{
}
else
{
...
@@ -279,12 +287,13 @@ int av_frame_ref(AVFrame *dst, AVFrame *src)
...
@@ -279,12 +287,13 @@ int av_frame_ref(AVFrame *dst, AVFrame *src)
/* duplicate extended data */
/* duplicate extended data */
if
(
src
->
extended_data
!=
src
->
data
)
{
if
(
src
->
extended_data
!=
src
->
data
)
{
int
ch
=
av_get_channel_layout_nb_channels
(
src
->
channel_layout
)
;
int
ch
=
src
->
channels
;
if
(
!
ch
)
{
if
(
!
ch
)
{
ret
=
AVERROR
(
EINVAL
);
ret
=
AVERROR
(
EINVAL
);
goto
fail
;
goto
fail
;
}
}
CHECK_CHANNELS_CONSISTENCY
(
src
);
dst
->
extended_data
=
av_malloc
(
sizeof
(
*
dst
->
extended_data
)
*
ch
);
dst
->
extended_data
=
av_malloc
(
sizeof
(
*
dst
->
extended_data
)
*
ch
);
if
(
!
dst
->
extended_data
)
{
if
(
!
dst
->
extended_data
)
{
...
@@ -388,7 +397,8 @@ int av_frame_make_writable(AVFrame *frame)
...
@@ -388,7 +397,8 @@ int av_frame_make_writable(AVFrame *frame)
return
ret
;
return
ret
;
if
(
tmp
.
nb_samples
)
{
if
(
tmp
.
nb_samples
)
{
int
ch
=
av_get_channel_layout_nb_channels
(
tmp
.
channel_layout
);
int
ch
=
tmp
.
channels
;
CHECK_CHANNELS_CONSISTENCY
(
&
tmp
);
av_samples_copy
(
tmp
.
extended_data
,
frame
->
extended_data
,
0
,
0
,
av_samples_copy
(
tmp
.
extended_data
,
frame
->
extended_data
,
0
,
0
,
frame
->
nb_samples
,
ch
,
frame
->
format
);
frame
->
nb_samples
,
ch
,
frame
->
format
);
}
else
{
}
else
{
...
@@ -478,9 +488,10 @@ AVBufferRef *av_frame_get_plane_buffer(AVFrame *frame, int plane)
...
@@ -478,9 +488,10 @@ AVBufferRef *av_frame_get_plane_buffer(AVFrame *frame, int plane)
int
planes
,
i
;
int
planes
,
i
;
if
(
frame
->
nb_samples
)
{
if
(
frame
->
nb_samples
)
{
int
channels
=
av_get_channel_layout_nb_channels
(
frame
->
channel_layout
)
;
int
channels
=
frame
->
channels
;
if
(
!
channels
)
if
(
!
channels
)
return
NULL
;
return
NULL
;
CHECK_CHANNELS_CONSISTENCY
(
frame
);
planes
=
av_sample_fmt_is_planar
(
frame
->
format
)
?
channels
:
1
;
planes
=
av_sample_fmt_is_planar
(
frame
->
format
)
?
channels
:
1
;
}
else
}
else
planes
=
4
;
planes
=
4
;
...
...
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