Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc
Commits
27dc2eab
Commit
27dc2eab
authored
Apr 21, 2015
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
avcodec: allocate picture in get_buffer2() when using hwaccel
parent
43d1d27d
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
46 additions
and
14 deletions
+46
-14
modules/codec/avcodec/video.c
modules/codec/avcodec/video.c
+46
-14
No files found.
modules/codec/avcodec/video.c
View file @
27dc2eab
...
...
@@ -84,6 +84,13 @@ struct decoder_sys_t
vlc_sem_t
sem_mt
;
};
typedef
struct
{
vlc_va_t
*
va
;
picture_t
*
pic
;
void
*
opaque
;
}
lavc_va_picture_t
;
#ifdef HAVE_AVCODEC_MT
# define wait_mt(s) vlc_sem_wait( &s->sem_mt )
# define post_mt(s) vlc_sem_post( &s->sem_mt )
...
...
@@ -208,12 +215,6 @@ static void lavc_CopyPicture(decoder_t *dec, picture_t *pic, AVFrame *frame)
{
decoder_sys_t
*
sys
=
dec
->
p_sys
;
if
(
sys
->
p_va
!=
NULL
)
{
vlc_va_Extract
(
sys
->
p_va
,
pic
,
frame
->
opaque
,
frame
->
data
[
3
]);
return
;
}
if
(
!
FindVlcChroma
(
sys
->
p_context
->
pix_fmt
))
{
const
char
*
name
=
av_get_pix_fmt_name
(
sys
->
p_context
->
pix_fmt
);
...
...
@@ -791,9 +792,10 @@ static picture_t *DecodeVideo( decoder_t *p_dec, block_t **pp_block )
if
(
!
b_drawpicture
||
(
!
p_sys
->
p_va
&&
!
p_sys
->
p_ff_pic
->
linesize
[
0
]
)
)
continue
;
if
(
p_sys
->
p_
va
!=
NULL
||
p_sys
->
p_
ff_pic
->
opaque
==
NULL
)
if
(
p_sys
->
p_ff_pic
->
opaque
==
NULL
)
{
/* Get a new picture */
if
(
p_sys
->
p_va
==
NULL
)
p_pic
=
ffmpeg_NewPictBuf
(
p_dec
,
p_context
);
if
(
!
p_pic
)
{
...
...
@@ -806,6 +808,16 @@ static picture_t *DecodeVideo( decoder_t *p_dec, block_t **pp_block )
lavc_CopyPicture
(
p_dec
,
p_pic
,
p_sys
->
p_ff_pic
);
}
else
if
(
p_sys
->
p_va
!=
NULL
)
{
lavc_va_picture_t
*
vapic
=
p_sys
->
p_ff_pic
->
opaque
;
p_pic
=
vapic
->
pic
;
vlc_va_Extract
(
p_sys
->
p_va
,
p_pic
,
vapic
->
opaque
,
p_sys
->
p_ff_pic
->
data
[
3
]
);
picture_Hold
(
p_pic
);
}
else
{
p_pic
=
(
picture_t
*
)
p_sys
->
p_ff_pic
->
opaque
;
picture_Hold
(
p_pic
);
...
...
@@ -949,34 +961,54 @@ static void ffmpeg_InitCodec( decoder_t *p_dec )
}
}
static
void
lavc_va_ReleaseFrame
(
void
*
opaque
,
uint8_t
*
data
)
{
lavc_va_picture_t
*
vapic
=
opaque
;
vlc_va_Release
(
vapic
->
va
,
vapic
->
opaque
,
data
);
picture_Release
(
vapic
->
pic
);
free
(
vapic
);
}
static
int
lavc_va_GetFrame
(
struct
AVCodecContext
*
ctx
,
AVFrame
*
frame
,
int
flags
)
{
decoder_t
*
dec
=
ctx
->
opaque
;
decoder_sys_t
*
sys
=
dec
->
p_sys
;
vlc_va_t
*
va
=
sys
->
p_va
;
vlc_va_t
*
va
=
dec
->
p_sys
->
p_va
;
if
(
vlc_va_Setup
(
va
,
ctx
,
&
dec
->
fmt_out
.
video
.
i_chroma
))
{
msg_Err
(
dec
,
"hardware acceleration setup failed"
);
return
-
1
;
}
if
(
vlc_va_Get
(
va
,
&
frame
->
opaque
,
&
frame
->
data
[
0
]))
picture_t
*
pic
=
ffmpeg_NewPictBuf
(
dec
,
ctx
);
if
(
pic
==
NULL
)
return
-
1
;
lavc_va_picture_t
*
vapic
=
xmalloc
(
sizeof
(
*
vapic
));
vapic
->
va
=
va
;
vapic
->
pic
=
pic
;
if
(
vlc_va_Get
(
va
,
&
vapic
->
opaque
,
&
frame
->
data
[
0
]))
{
msg_Err
(
dec
,
"hardware acceleration picture allocation failed"
);
picture_Release
(
pic
);
return
-
1
;
}
/* data[0] must be non-NULL for libavcodec internal checks.
* data[3] actually contains the format-specific surface handle. */
frame
->
data
[
3
]
=
frame
->
data
[
0
];
frame
->
buf
[
0
]
=
av_buffer_create
(
frame
->
data
[
0
],
0
,
va
->
releas
e
,
frame
->
opaque
,
0
);
frame
->
buf
[
0
]
=
av_buffer_create
(
frame
->
data
[
0
],
0
,
lavc_va_ReleaseFram
e
,
vapic
,
0
);
if
(
unlikely
(
frame
->
buf
[
0
]
==
NULL
))
{
vlc_va_Release
(
va
,
frame
->
opaque
,
frame
->
data
[
0
]);
lavc_va_ReleaseFrame
(
vapic
,
frame
->
data
[
0
]);
return
-
1
;
}
frame
->
opaque
=
vapic
;
assert
(
frame
->
data
[
0
]
!=
NULL
);
(
void
)
flags
;
return
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