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
2a48a75a
Commit
2a48a75a
authored
Jun 01, 2016
by
Paul B Mahol
Committed by
Vittorio Giovara
Jun 06, 2016
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
sgirledec: simplify, no need to use reget buffer
Signed-off-by:
Paul B Mahol
<
onemda@gmail.com
>
parent
6e2ad28c
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
7 additions
and
25 deletions
+7
-25
sgirledec.c
libavcodec/sgirledec.c
+7
-25
No files found.
libavcodec/sgirledec.c
View file @
2a48a75a
...
...
@@ -31,17 +31,9 @@
#include "avcodec.h"
#include "internal.h"
typedef
struct
SGIRLEContext
{
AVFrame
*
frame
;
}
SGIRLEContext
;
static
av_cold
int
sgirle_decode_init
(
AVCodecContext
*
avctx
)
{
SGIRLEContext
*
s
=
avctx
->
priv_data
;
avctx
->
pix_fmt
=
AV_PIX_FMT_BGR8
;
s
->
frame
=
av_frame_alloc
();
if
(
!
s
->
frame
)
return
AVERROR
(
ENOMEM
);
return
0
;
}
...
...
@@ -120,41 +112,31 @@ static int decode_sgirle8(AVCodecContext *avctx, uint8_t *dst,
static
int
sgirle_decode_frame
(
AVCodecContext
*
avctx
,
void
*
data
,
int
*
got_frame
,
AVPacket
*
avpkt
)
{
SGIRLEContext
*
s
=
avctx
->
priv_
data
;
AVFrame
*
frame
=
data
;
int
ret
;
if
((
ret
=
ff_
reget_buffer
(
avctx
,
s
->
frame
))
<
0
)
if
((
ret
=
ff_
get_buffer
(
avctx
,
frame
,
0
))
<
0
)
return
ret
;
ret
=
decode_sgirle8
(
avctx
,
s
->
frame
->
data
[
0
],
avpkt
->
data
,
avpkt
->
size
,
avctx
->
width
,
avctx
->
height
,
s
->
frame
->
linesize
[
0
]);
ret
=
decode_sgirle8
(
avctx
,
frame
->
data
[
0
],
avpkt
->
data
,
avpkt
->
size
,
avctx
->
width
,
avctx
->
height
,
frame
->
linesize
[
0
]);
if
(
ret
<
0
)
return
ret
;
frame
->
pict_type
=
AV_PICTURE_TYPE_I
;
frame
->
key_frame
=
1
;
*
got_frame
=
1
;
if
((
ret
=
av_frame_ref
(
data
,
s
->
frame
))
<
0
)
return
ret
;
return
avpkt
->
size
;
}
static
av_cold
int
sgirle_decode_end
(
AVCodecContext
*
avctx
)
{
SGIRLEContext
*
s
=
avctx
->
priv_data
;
av_frame_free
(
&
s
->
frame
);
return
0
;
}
AVCodec
ff_sgirle_decoder
=
{
.
name
=
"sgirle"
,
.
long_name
=
NULL_IF_CONFIG_SMALL
(
"Silicon Graphics RLE 8-bit video"
),
.
type
=
AVMEDIA_TYPE_VIDEO
,
.
id
=
AV_CODEC_ID_SGIRLE
,
.
priv_data_size
=
sizeof
(
SGIRLEContext
),
.
init
=
sgirle_decode_init
,
.
close
=
sgirle_decode_end
,
.
decode
=
sgirle_decode_frame
,
.
capabilities
=
AV_CODEC_CAP_DR1
,
};
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