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
ad2ac1e7
Commit
ad2ac1e7
authored
Aug 25, 2018
by
Paul B Mahol
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
avcodec: add WinCAM Motion Video decoder
parent
f7d749e9
Show whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
274 additions
and
1 deletion
+274
-1
Changelog
Changelog
+1
-0
configure
configure
+1
-0
Makefile
libavcodec/Makefile
+1
-0
allcodecs.c
libavcodec/allcodecs.c
+1
-0
avcodec.h
libavcodec/avcodec.h
+1
-0
codec_desc.c
libavcodec/codec_desc.c
+7
-0
version.h
libavcodec/version.h
+1
-1
wcmv.c
libavcodec/wcmv.c
+260
-0
riff.c
libavformat/riff.c
+1
-0
No files found.
Changelog
View file @
ad2ac1e7
...
@@ -20,6 +20,7 @@ version <next>:
...
@@ -20,6 +20,7 @@ version <next>:
- IMM4 video decoder
- IMM4 video decoder
- Brooktree ProSumer video decoder
- Brooktree ProSumer video decoder
- MatchWare Screen Capture Codec decoder
- MatchWare Screen Capture Codec decoder
- WinCam Motion Video decoder
version 4.0:
version 4.0:
...
...
configure
View file @
ad2ac1e7
...
@@ -2771,6 +2771,7 @@ vp6f_decoder_select="vp6_decoder"
...
@@ -2771,6 +2771,7 @@ vp6f_decoder_select="vp6_decoder"
vp7_decoder_select
=
"h264pred videodsp vp8dsp"
vp7_decoder_select
=
"h264pred videodsp vp8dsp"
vp8_decoder_select
=
"h264pred videodsp vp8dsp"
vp8_decoder_select
=
"h264pred videodsp vp8dsp"
vp9_decoder_select
=
"videodsp vp9_parser vp9_superframe_split_bsf"
vp9_decoder_select
=
"videodsp vp9_parser vp9_superframe_split_bsf"
wcmv_decoder_deps
=
"zlib"
webp_decoder_select
=
"vp8_decoder exif"
webp_decoder_select
=
"vp8_decoder exif"
wmalossless_decoder_select
=
"llauddsp"
wmalossless_decoder_select
=
"llauddsp"
wmapro_decoder_select
=
"mdct sinewin wma_freqs"
wmapro_decoder_select
=
"mdct sinewin wma_freqs"
...
...
libavcodec/Makefile
View file @
ad2ac1e7
...
@@ -677,6 +677,7 @@ OBJS-$(CONFIG_VP9_V4L2M2M_DECODER) += v4l2_m2m_dec.o
...
@@ -677,6 +677,7 @@ OBJS-$(CONFIG_VP9_V4L2M2M_DECODER) += v4l2_m2m_dec.o
OBJS-$(CONFIG_VQA_DECODER)
+=
vqavideo.o
OBJS-$(CONFIG_VQA_DECODER)
+=
vqavideo.o
OBJS-$(CONFIG_WAVPACK_DECODER)
+=
wavpack.o
OBJS-$(CONFIG_WAVPACK_DECODER)
+=
wavpack.o
OBJS-$(CONFIG_WAVPACK_ENCODER)
+=
wavpackenc.o
OBJS-$(CONFIG_WAVPACK_ENCODER)
+=
wavpackenc.o
OBJS-$(CONFIG_WCMV_DECODER)
+=
wcmv.o
OBJS-$(CONFIG_WEBP_DECODER)
+=
webp.o
OBJS-$(CONFIG_WEBP_DECODER)
+=
webp.o
OBJS-$(CONFIG_WEBVTT_DECODER)
+=
webvttdec.o
ass.o
OBJS-$(CONFIG_WEBVTT_DECODER)
+=
webvttdec.o
ass.o
OBJS-$(CONFIG_WEBVTT_ENCODER)
+=
webvttenc.o
ass_split.o
OBJS-$(CONFIG_WEBVTT_ENCODER)
+=
webvttenc.o
ass_split.o
...
...
libavcodec/allcodecs.c
View file @
ad2ac1e7
...
@@ -338,6 +338,7 @@ extern AVCodec ff_vp9_rkmpp_decoder;
...
@@ -338,6 +338,7 @@ extern AVCodec ff_vp9_rkmpp_decoder;
extern
AVCodec
ff_vp9_v4l2m2m_decoder
;
extern
AVCodec
ff_vp9_v4l2m2m_decoder
;
extern
AVCodec
ff_vqa_decoder
;
extern
AVCodec
ff_vqa_decoder
;
extern
AVCodec
ff_webp_decoder
;
extern
AVCodec
ff_webp_decoder
;
extern
AVCodec
ff_wcmv_decoder
;
extern
AVCodec
ff_wrapped_avframe_encoder
;
extern
AVCodec
ff_wrapped_avframe_encoder
;
extern
AVCodec
ff_wrapped_avframe_decoder
;
extern
AVCodec
ff_wrapped_avframe_decoder
;
extern
AVCodec
ff_wmv1_encoder
;
extern
AVCodec
ff_wmv1_encoder
;
...
...
libavcodec/avcodec.h
View file @
ad2ac1e7
...
@@ -450,6 +450,7 @@ enum AVCodecID {
...
@@ -450,6 +450,7 @@ enum AVCodecID {
AV_CODEC_ID_IMM4
,
AV_CODEC_ID_IMM4
,
AV_CODEC_ID_PROSUMER
,
AV_CODEC_ID_PROSUMER
,
AV_CODEC_ID_MWSC
,
AV_CODEC_ID_MWSC
,
AV_CODEC_ID_WCMV
,
/* various PCM "codecs" */
/* various PCM "codecs" */
AV_CODEC_ID_FIRST_AUDIO
=
0x10000
,
///< A dummy id pointing at the start of audio codecs
AV_CODEC_ID_FIRST_AUDIO
=
0x10000
,
///< A dummy id pointing at the start of audio codecs
...
...
libavcodec/codec_desc.c
View file @
ad2ac1e7
...
@@ -1675,6 +1675,13 @@ static const AVCodecDescriptor codec_descriptors[] = {
...
@@ -1675,6 +1675,13 @@ static const AVCodecDescriptor codec_descriptors[] = {
.
long_name
=
NULL_IF_CONFIG_SMALL
(
"MatchWare Screen Capture Codec"
),
.
long_name
=
NULL_IF_CONFIG_SMALL
(
"MatchWare Screen Capture Codec"
),
.
props
=
AV_CODEC_PROP_LOSSLESS
,
.
props
=
AV_CODEC_PROP_LOSSLESS
,
},
},
{
.
id
=
AV_CODEC_ID_WCMV
,
.
type
=
AVMEDIA_TYPE_VIDEO
,
.
name
=
"wcmv"
,
.
long_name
=
NULL_IF_CONFIG_SMALL
(
"WinCAM Motion Video"
),
.
props
=
AV_CODEC_PROP_LOSSLESS
,
},
/* various PCM "codecs" */
/* various PCM "codecs" */
{
{
...
...
libavcodec/version.h
View file @
ad2ac1e7
...
@@ -28,7 +28,7 @@
...
@@ -28,7 +28,7 @@
#include "libavutil/version.h"
#include "libavutil/version.h"
#define LIBAVCODEC_VERSION_MAJOR 58
#define LIBAVCODEC_VERSION_MAJOR 58
#define LIBAVCODEC_VERSION_MINOR 2
6
#define LIBAVCODEC_VERSION_MINOR 2
7
#define LIBAVCODEC_VERSION_MICRO 100
#define LIBAVCODEC_VERSION_MICRO 100
#define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \
#define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \
...
...
libavcodec/wcmv.c
0 → 100644
View file @
ad2ac1e7
/*
* WinCAM Motion Video decoder
*
* Copyright (c) 2018 Paul B Mahol
*
* This file is part of FFmpeg.
*
* FFmpeg is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* FFmpeg is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with FFmpeg; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "libavutil/imgutils.h"
#include "avcodec.h"
#include "bytestream.h"
#include "internal.h"
#include <zlib.h>
typedef
struct
WCMVContext
{
int
bpp
;
z_stream
zstream
;
AVFrame
*
prev_frame
;
uint8_t
block_data
[
65536
*
8
];
}
WCMVContext
;
static
int
decode_frame
(
AVCodecContext
*
avctx
,
void
*
data
,
int
*
got_frame
,
AVPacket
*
avpkt
)
{
WCMVContext
*
s
=
avctx
->
priv_data
;
AVFrame
*
frame
=
data
;
int
skip
,
blocks
,
zret
,
ret
,
intra
=
0
,
bpp
=
s
->
bpp
;
GetByteContext
gb
;
uint8_t
*
dst
;
ret
=
inflateReset
(
&
s
->
zstream
);
if
(
ret
!=
Z_OK
)
{
av_log
(
avctx
,
AV_LOG_ERROR
,
"Inflate reset error: %d
\n
"
,
ret
);
return
AVERROR_EXTERNAL
;
}
bytestream2_init
(
&
gb
,
avpkt
->
data
,
avpkt
->
size
);
if
((
ret
=
ff_get_buffer
(
avctx
,
frame
,
AV_GET_BUFFER_FLAG_REF
))
<
0
)
return
ret
;
if
(
s
->
prev_frame
->
data
[
0
])
{
ret
=
av_frame_copy
(
frame
,
s
->
prev_frame
);
if
(
ret
<
0
)
return
ret
;
}
else
{
ptrdiff_t
linesize
[
4
]
=
{
frame
->
linesize
[
0
],
0
,
0
,
0
};
av_image_fill_black
(
frame
->
data
,
linesize
,
avctx
->
pix_fmt
,
0
,
avctx
->
width
,
avctx
->
height
);
}
blocks
=
bytestream2_get_le16
(
&
gb
);
if
(
blocks
>
5
)
{
GetByteContext
bgb
;
int
x
=
0
,
size
;
if
(
blocks
*
8
>=
0xFFFF
)
size
=
bytestream2_get_le24
(
&
gb
);
else
if
(
blocks
*
8
>=
0xFF
)
size
=
bytestream2_get_le16
(
&
gb
);
else
size
=
bytestream2_get_byte
(
&
gb
);
skip
=
bytestream2_tell
(
&
gb
);
if
(
size
>
avpkt
->
size
-
skip
)
return
AVERROR_INVALIDDATA
;
s
->
zstream
.
next_in
=
avpkt
->
data
+
skip
;
s
->
zstream
.
avail_in
=
size
;
s
->
zstream
.
next_out
=
s
->
block_data
;
s
->
zstream
.
avail_out
=
sizeof
(
s
->
block_data
);
zret
=
inflate
(
&
s
->
zstream
,
Z_FINISH
);
if
(
zret
!=
Z_STREAM_END
)
{
av_log
(
avctx
,
AV_LOG_ERROR
,
"Inflate failed with return code: %d.
\n
"
,
zret
);
return
AVERROR_INVALIDDATA
;
}
ret
=
inflateReset
(
&
s
->
zstream
);
if
(
ret
!=
Z_OK
)
{
av_log
(
avctx
,
AV_LOG_ERROR
,
"Inflate reset error: %d
\n
"
,
ret
);
return
AVERROR_EXTERNAL
;
}
bytestream2_skip
(
&
gb
,
size
);
bytestream2_init
(
&
bgb
,
s
->
block_data
,
blocks
*
8
);
for
(
int
i
=
0
;
i
<
blocks
;
i
++
)
{
int
w
,
h
;
bytestream2_skip
(
&
bgb
,
4
);
w
=
bytestream2_get_le16
(
&
bgb
);
h
=
bytestream2_get_le16
(
&
bgb
);
x
+=
bpp
*
w
*
h
;
}
if
(
x
>=
0xFFFF
)
bytestream2_skip
(
&
gb
,
3
);
else
if
(
x
>=
0xFF
)
bytestream2_skip
(
&
gb
,
2
);
else
bytestream2_skip
(
&
gb
,
1
);
skip
=
bytestream2_tell
(
&
gb
);
s
->
zstream
.
next_in
=
avpkt
->
data
+
skip
;
s
->
zstream
.
avail_in
=
avpkt
->
size
-
skip
;
bytestream2_init
(
&
gb
,
s
->
block_data
,
blocks
*
8
);
}
else
if
(
blocks
)
{
int
x
=
0
;
bytestream2_seek
(
&
gb
,
2
,
SEEK_SET
);
for
(
int
i
=
0
;
i
<
blocks
;
i
++
)
{
int
w
,
h
;
bytestream2_skip
(
&
gb
,
4
);
w
=
bytestream2_get_le16
(
&
gb
);
h
=
bytestream2_get_le16
(
&
gb
);
x
+=
bpp
*
w
*
h
;
}
if
(
x
>=
0xFFFF
)
bytestream2_skip
(
&
gb
,
3
);
else
if
(
x
>=
0xFF
)
bytestream2_skip
(
&
gb
,
2
);
else
bytestream2_skip
(
&
gb
,
1
);
skip
=
bytestream2_tell
(
&
gb
);
s
->
zstream
.
next_in
=
avpkt
->
data
+
skip
;
s
->
zstream
.
avail_in
=
avpkt
->
size
-
skip
;
bytestream2_seek
(
&
gb
,
2
,
SEEK_SET
);
}
for
(
int
block
=
0
;
block
<
blocks
;
block
++
)
{
int
x
,
y
,
w
,
h
;
x
=
bytestream2_get_le16
(
&
gb
);
y
=
bytestream2_get_le16
(
&
gb
);
w
=
bytestream2_get_le16
(
&
gb
);
h
=
bytestream2_get_le16
(
&
gb
);
if
(
blocks
==
1
&&
x
==
0
&&
y
==
0
&&
w
==
avctx
->
width
&&
h
==
avctx
->
height
)
intra
=
1
;
if
(
x
+
w
>
avctx
->
width
||
y
+
h
>
avctx
->
height
)
return
AVERROR_INVALIDDATA
;
if
(
w
>
avctx
->
width
||
h
>
avctx
->
height
)
return
AVERROR_INVALIDDATA
;
dst
=
frame
->
data
[
0
]
+
(
avctx
->
height
-
y
-
1
)
*
frame
->
linesize
[
0
]
+
x
*
bpp
;
for
(
int
i
=
0
;
i
<
h
;
i
++
)
{
s
->
zstream
.
next_out
=
dst
;
s
->
zstream
.
avail_out
=
w
*
bpp
;
zret
=
inflate
(
&
s
->
zstream
,
Z_SYNC_FLUSH
);
if
(
zret
!=
Z_OK
&&
zret
!=
Z_STREAM_END
)
{
av_log
(
avctx
,
AV_LOG_ERROR
,
"Inflate failed with return code: %d.
\n
"
,
zret
);
return
AVERROR_INVALIDDATA
;
}
dst
-=
frame
->
linesize
[
0
];
}
}
frame
->
key_frame
=
intra
;
frame
->
pict_type
=
intra
?
AV_PICTURE_TYPE_I
:
AV_PICTURE_TYPE_P
;
av_frame_unref
(
s
->
prev_frame
);
if
((
ret
=
av_frame_ref
(
s
->
prev_frame
,
frame
))
<
0
)
return
ret
;
*
got_frame
=
1
;
return
avpkt
->
size
;
}
static
av_cold
int
decode_init
(
AVCodecContext
*
avctx
)
{
WCMVContext
*
s
=
avctx
->
priv_data
;
int
zret
;
switch
(
avctx
->
bits_per_coded_sample
)
{
case
16
:
avctx
->
pix_fmt
=
AV_PIX_FMT_RGB565
;
break
;
case
24
:
avctx
->
pix_fmt
=
AV_PIX_FMT_BGR24
;
break
;
case
32
:
avctx
->
pix_fmt
=
AV_PIX_FMT_BGRA
;
break
;
default:
av_log
(
avctx
,
AV_LOG_ERROR
,
"Unsupported bits_per_coded_sample: %d
\n
"
,
avctx
->
bits_per_coded_sample
);
return
AVERROR_PATCHWELCOME
;
}
s
->
bpp
=
avctx
->
bits_per_coded_sample
>>
3
;
s
->
zstream
.
zalloc
=
Z_NULL
;
s
->
zstream
.
zfree
=
Z_NULL
;
s
->
zstream
.
opaque
=
Z_NULL
;
zret
=
inflateInit
(
&
s
->
zstream
);
if
(
zret
!=
Z_OK
)
{
av_log
(
avctx
,
AV_LOG_ERROR
,
"Inflate init error: %d
\n
"
,
zret
);
return
AVERROR_EXTERNAL
;
}
s
->
prev_frame
=
av_frame_alloc
();
if
(
!
s
->
prev_frame
)
return
AVERROR
(
ENOMEM
);
return
0
;
}
static
av_cold
int
decode_close
(
AVCodecContext
*
avctx
)
{
WCMVContext
*
s
=
avctx
->
priv_data
;
av_frame_free
(
&
s
->
prev_frame
);
inflateEnd
(
&
s
->
zstream
);
return
0
;
}
AVCodec
ff_wcmv_decoder
=
{
.
name
=
"wcmv"
,
.
long_name
=
NULL_IF_CONFIG_SMALL
(
"WinCAM Motion Video"
),
.
type
=
AVMEDIA_TYPE_VIDEO
,
.
id
=
AV_CODEC_ID_WCMV
,
.
priv_data_size
=
sizeof
(
WCMVContext
),
.
init
=
decode_init
,
.
close
=
decode_close
,
.
decode
=
decode_frame
,
.
capabilities
=
AV_CODEC_CAP_DR1
,
.
caps_internal
=
FF_CODEC_CAP_INIT_THREADSAFE
|
FF_CODEC_CAP_INIT_CLEANUP
,
};
libavformat/riff.c
View file @
ad2ac1e7
...
@@ -473,6 +473,7 @@ const AVCodecTag ff_codec_bmp_tags[] = {
...
@@ -473,6 +473,7 @@ const AVCodecTag ff_codec_bmp_tags[] = {
{
AV_CODEC_ID_IMM4
,
MKTAG
(
'I'
,
'M'
,
'M'
,
'4'
)
},
{
AV_CODEC_ID_IMM4
,
MKTAG
(
'I'
,
'M'
,
'M'
,
'4'
)
},
{
AV_CODEC_ID_PROSUMER
,
MKTAG
(
'B'
,
'T'
,
'2'
,
'0'
)
},
{
AV_CODEC_ID_PROSUMER
,
MKTAG
(
'B'
,
'T'
,
'2'
,
'0'
)
},
{
AV_CODEC_ID_MWSC
,
MKTAG
(
'M'
,
'W'
,
'S'
,
'C'
)
},
{
AV_CODEC_ID_MWSC
,
MKTAG
(
'M'
,
'W'
,
'S'
,
'C'
)
},
{
AV_CODEC_ID_WCMV
,
MKTAG
(
'W'
,
'C'
,
'M'
,
'V'
)
},
{
AV_CODEC_ID_NONE
,
0
}
{
AV_CODEC_ID_NONE
,
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