Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
小白菜888
Ffmpeg
提交
db1e403c
F
Ffmpeg
项目概览
小白菜888
/
Ffmpeg
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
F
Ffmpeg
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
db1e403c
编写于
4月 08, 2012
作者:
D
Diego Biurrun
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
vcr1: cosmetics: K&R prettyprinting, typos, parentheses, dead code, comments
上级
59cbc4ee
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
72 addition
and
72 deletion
+72
-72
libavcodec/vcr1.c
libavcodec/vcr1.c
+72
-72
未找到文件。
libavcodec/vcr1.c
浏览文件 @
db1e403c
...
@@ -21,92 +21,88 @@
...
@@ -21,92 +21,88 @@
/**
/**
* @file
* @file
*
ati vcr1 codec.
*
ATI VCR1 codec
*/
*/
#include "avcodec.h"
#include "avcodec.h"
#include "dsputil.h"
#include "dsputil.h"
//#undef NDEBUG
//#include <assert.h>
/* Disable the encoder. */
/* Disable the encoder. */
#undef CONFIG_VCR1_ENCODER
#undef CONFIG_VCR1_ENCODER
#define CONFIG_VCR1_ENCODER 0
#define CONFIG_VCR1_ENCODER 0
typedef
struct
VCR1Context
{
typedef
struct
VCR1Context
{
AVCodecContext
*
avctx
;
AVCodecContext
*
avctx
;
AVFrame
picture
;
AVFrame
picture
;
int
delta
[
16
];
int
delta
[
16
];
int
offset
[
4
];
int
offset
[
4
];
}
VCR1Context
;
}
VCR1Context
;
static
int
decode_frame
(
AVCodecContext
*
avctx
,
static
int
decode_frame
(
AVCodecContext
*
avctx
,
void
*
data
,
void
*
data
,
int
*
data_size
,
int
*
data_size
,
AVPacket
*
avpkt
)
AVPacket
*
avpkt
)
{
{
const
uint8_t
*
buf
=
avpkt
->
data
;
const
uint8_t
*
buf
=
avpkt
->
data
;
int
buf_size
=
avpkt
->
size
;
int
buf_size
=
avpkt
->
size
;
VCR1Context
*
const
a
=
avctx
->
priv_data
;
VCR1Context
*
const
a
=
avctx
->
priv_data
;
AVFrame
*
picture
=
data
;
AVFrame
*
picture
=
data
;
AVFrame
*
const
p
=
&
a
->
picture
;
AVFrame
*
const
p
=
&
a
->
picture
;
const
uint8_t
*
bytestream
=
buf
;
const
uint8_t
*
bytestream
=
buf
;
int
i
,
x
,
y
;
int
i
,
x
,
y
;
if
(
p
->
data
[
0
])
if
(
p
->
data
[
0
])
avctx
->
release_buffer
(
avctx
,
p
);
avctx
->
release_buffer
(
avctx
,
p
);
p
->
reference
=
0
;
p
->
reference
=
0
;
if
(
avctx
->
get_buffer
(
avctx
,
p
)
<
0
)
{
if
(
avctx
->
get_buffer
(
avctx
,
p
)
<
0
)
{
av_log
(
avctx
,
AV_LOG_ERROR
,
"get_buffer() failed
\n
"
);
av_log
(
avctx
,
AV_LOG_ERROR
,
"get_buffer() failed
\n
"
);
return
-
1
;
return
-
1
;
}
}
p
->
pict_type
=
AV_PICTURE_TYPE_I
;
p
->
pict_type
=
AV_PICTURE_TYPE_I
;
p
->
key_frame
=
1
;
p
->
key_frame
=
1
;
for
(
i
=
0
;
i
<
16
;
i
++
)
{
for
(
i
=
0
;
i
<
16
;
i
++
)
{
a
->
delta
[
i
]
=
*
(
bytestream
++
)
;
a
->
delta
[
i
]
=
*
bytestream
++
;
bytestream
++
;
bytestream
++
;
}
}
for
(
y
=
0
;
y
<
avctx
->
height
;
y
++
)
{
for
(
y
=
0
;
y
<
avctx
->
height
;
y
++
)
{
int
offset
;
int
offset
;
uint8_t
*
luma
=
&
a
->
picture
.
data
[
0
][
y
*
a
->
picture
.
linesize
[
0
]
];
uint8_t
*
luma
=
&
a
->
picture
.
data
[
0
][
y
*
a
->
picture
.
linesize
[
0
]
];
if
((
y
&
3
)
==
0
)
{
if
((
y
&
3
)
==
0
)
{
uint8_t
*
cb
=
&
a
->
picture
.
data
[
1
][
(
y
>>
2
)
*
a
->
picture
.
linesize
[
1
]
];
uint8_t
*
cb
=
&
a
->
picture
.
data
[
1
][(
y
>>
2
)
*
a
->
picture
.
linesize
[
1
]
];
uint8_t
*
cr
=
&
a
->
picture
.
data
[
2
][
(
y
>>
2
)
*
a
->
picture
.
linesize
[
2
]
];
uint8_t
*
cr
=
&
a
->
picture
.
data
[
2
][(
y
>>
2
)
*
a
->
picture
.
linesize
[
2
]
];
for
(
i
=
0
;
i
<
4
;
i
++
)
for
(
i
=
0
;
i
<
4
;
i
++
)
a
->
offset
[
i
]
=
*
(
bytestream
++
)
;
a
->
offset
[
i
]
=
*
bytestream
++
;
offset
=
a
->
offset
[
0
]
-
a
->
delta
[
bytestream
[
2
]
&
0xF
];
offset
=
a
->
offset
[
0
]
-
a
->
delta
[
bytestream
[
2
]
&
0xF
];
for
(
x
=
0
;
x
<
avctx
->
width
;
x
+=
4
)
{
for
(
x
=
0
;
x
<
avctx
->
width
;
x
+=
4
)
{
luma
[
0
]
=
(
offset
+=
a
->
delta
[
bytestream
[
2
]
&
0xF
])
;
luma
[
0
]
=
offset
+=
a
->
delta
[
bytestream
[
2
]
&
0xF
]
;
luma
[
1
]
=
(
offset
+=
a
->
delta
[
bytestream
[
2
]
>>
4
])
;
luma
[
1
]
=
offset
+=
a
->
delta
[
bytestream
[
2
]
>>
4
]
;
luma
[
2
]
=
(
offset
+=
a
->
delta
[
bytestream
[
0
]
&
0xF
])
;
luma
[
2
]
=
offset
+=
a
->
delta
[
bytestream
[
0
]
&
0xF
]
;
luma
[
3
]
=
(
offset
+=
a
->
delta
[
bytestream
[
0
]
>>
4
])
;
luma
[
3
]
=
offset
+=
a
->
delta
[
bytestream
[
0
]
>>
4
]
;
luma
+=
4
;
luma
+=
4
;
*
(
cb
++
)
=
bytestream
[
3
];
*
cb
++
=
bytestream
[
3
];
*
(
cr
++
)
=
bytestream
[
1
];
*
cr
++
=
bytestream
[
1
];
bytestream
+=
4
;
bytestream
+=
4
;
}
}
}
else
{
}
else
{
offset
=
a
->
offset
[
y
&
3
]
-
a
->
delta
[
bytestream
[
2
]
&
0xF
];
offset
=
a
->
offset
[
y
&
3
]
-
a
->
delta
[
bytestream
[
2
]
&
0xF
];
for
(
x
=
0
;
x
<
avctx
->
width
;
x
+=
8
)
{
for
(
x
=
0
;
x
<
avctx
->
width
;
x
+=
8
)
{
luma
[
0
]
=
(
offset
+=
a
->
delta
[
bytestream
[
2
]
&
0xF
])
;
luma
[
0
]
=
offset
+=
a
->
delta
[
bytestream
[
2
]
&
0xF
]
;
luma
[
1
]
=
(
offset
+=
a
->
delta
[
bytestream
[
2
]
>>
4
])
;
luma
[
1
]
=
offset
+=
a
->
delta
[
bytestream
[
2
]
>>
4
]
;
luma
[
2
]
=
(
offset
+=
a
->
delta
[
bytestream
[
3
]
&
0xF
])
;
luma
[
2
]
=
offset
+=
a
->
delta
[
bytestream
[
3
]
&
0xF
]
;
luma
[
3
]
=
(
offset
+=
a
->
delta
[
bytestream
[
3
]
>>
4
])
;
luma
[
3
]
=
offset
+=
a
->
delta
[
bytestream
[
3
]
>>
4
]
;
luma
[
4
]
=
(
offset
+=
a
->
delta
[
bytestream
[
0
]
&
0xF
])
;
luma
[
4
]
=
offset
+=
a
->
delta
[
bytestream
[
0
]
&
0xF
]
;
luma
[
5
]
=
(
offset
+=
a
->
delta
[
bytestream
[
0
]
>>
4
])
;
luma
[
5
]
=
offset
+=
a
->
delta
[
bytestream
[
0
]
>>
4
]
;
luma
[
6
]
=
(
offset
+=
a
->
delta
[
bytestream
[
1
]
&
0xF
])
;
luma
[
6
]
=
offset
+=
a
->
delta
[
bytestream
[
1
]
&
0xF
]
;
luma
[
7
]
=
(
offset
+=
a
->
delta
[
bytestream
[
1
]
>>
4
])
;
luma
[
7
]
=
offset
+=
a
->
delta
[
bytestream
[
1
]
>>
4
]
;
luma
+=
8
;
luma
+=
8
;
bytestream
+=
4
;
bytestream
+=
4
;
}
}
}
}
}
}
...
@@ -118,43 +114,47 @@ static int decode_frame(AVCodecContext *avctx,
...
@@ -118,43 +114,47 @@ static int decode_frame(AVCodecContext *avctx,
}
}
#if CONFIG_VCR1_ENCODER
#if CONFIG_VCR1_ENCODER
static
int
encode_frame
(
AVCodecContext
*
avctx
,
unsigned
char
*
buf
,
int
buf_size
,
void
*
data
){
static
int
encode_frame
(
AVCodecContext
*
avctx
,
unsigned
char
*
buf
,
VCR1Context
*
const
a
=
avctx
->
priv_data
;
int
buf_size
,
void
*
data
)
AVFrame
*
pict
=
data
;
{
AVFrame
*
const
p
=
&
a
->
picture
;
VCR1Context
*
const
a
=
avctx
->
priv_data
;
AVFrame
*
pict
=
data
;
AVFrame
*
const
p
=
&
a
->
picture
;
int
size
;
int
size
;
*
p
=
*
pict
;
*
p
=
*
pict
;
p
->
pict_type
=
AV_PICTURE_TYPE_I
;
p
->
pict_type
=
AV_PICTURE_TYPE_I
;
p
->
key_frame
=
1
;
p
->
key_frame
=
1
;
avpriv_align_put_bits
(
&
a
->
pb
);
avpriv_align_put_bits
(
&
a
->
pb
);
while
(
get_bit_count
(
&
a
->
pb
)
&
31
)
while
(
get_bit_count
(
&
a
->
pb
)
&
31
)
put_bits
(
&
a
->
pb
,
8
,
0
);
put_bits
(
&
a
->
pb
,
8
,
0
);
size
=
get_bit_count
(
&
a
->
pb
)
/
32
;
size
=
get_bit_count
(
&
a
->
pb
)
/
32
;
return
size
*
4
;
return
size
*
4
;
}
}
#endif
#endif
static
av_cold
void
common_init
(
AVCodecContext
*
avctx
){
static
av_cold
void
common_init
(
AVCodecContext
*
avctx
)
VCR1Context
*
const
a
=
avctx
->
priv_data
;
{
VCR1Context
*
const
a
=
avctx
->
priv_data
;
avctx
->
coded_frame
=
&
a
->
picture
;
avctx
->
coded_frame
=
&
a
->
picture
;
a
->
avctx
=
avctx
;
a
->
avctx
=
avctx
;
}
}
static
av_cold
int
decode_init
(
AVCodecContext
*
avctx
)
{
static
av_cold
int
decode_init
(
AVCodecContext
*
avctx
)
{
common_init
(
avctx
);
common_init
(
avctx
);
avctx
->
pix_fmt
=
PIX_FMT_YUV410P
;
avctx
->
pix_fmt
=
PIX_FMT_YUV410P
;
return
0
;
return
0
;
}
}
static
av_cold
int
decode_end
(
AVCodecContext
*
avctx
){
static
av_cold
int
decode_end
(
AVCodecContext
*
avctx
)
{
VCR1Context
*
s
=
avctx
->
priv_data
;
VCR1Context
*
s
=
avctx
->
priv_data
;
if
(
s
->
picture
.
data
[
0
])
if
(
s
->
picture
.
data
[
0
])
...
@@ -164,8 +164,8 @@ static av_cold int decode_end(AVCodecContext *avctx){
...
@@ -164,8 +164,8 @@ static av_cold int decode_end(AVCodecContext *avctx){
}
}
#if CONFIG_VCR1_ENCODER
#if CONFIG_VCR1_ENCODER
static
av_cold
int
encode_init
(
AVCodecContext
*
avctx
)
{
static
av_cold
int
encode_init
(
AVCodecContext
*
avctx
)
{
common_init
(
avctx
);
common_init
(
avctx
);
return
0
;
return
0
;
...
@@ -194,4 +194,4 @@ AVCodec ff_vcr1_encoder = {
...
@@ -194,4 +194,4 @@ AVCodec ff_vcr1_encoder = {
.
encode
=
encode_frame
,
.
encode
=
encode_frame
,
.
long_name
=
NULL_IF_CONFIG_SMALL
(
"ATI VCR1"
),
.
long_name
=
NULL_IF_CONFIG_SMALL
(
"ATI VCR1"
),
};
};
#endif
#endif
/* CONFIG_VCR1_ENCODER */
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录