Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
小白菜888
Ffmpeg
提交
5a2f421a
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,发现更多精彩内容 >>
提交
5a2f421a
编写于
5月 09, 2007
作者:
R
Ramiro Polla
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Use bytestream
Originally committed as revision 8964 to
svn://svn.ffmpeg.org/ffmpeg/trunk
上级
a32c2ce4
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
11 addition
and
27 deletion
+11
-27
libavcodec/pcm.c
libavcodec/pcm.c
+11
-27
未找到文件。
libavcodec/pcm.c
浏览文件 @
5a2f421a
...
...
@@ -26,6 +26,7 @@
#include "avcodec.h"
#include "bitstream.h" // for ff_reverse
#include "bytestream.h"
/* from g711.c by SUN microsystems (unrestricted use) */
...
...
@@ -248,46 +249,34 @@ static int pcm_encode_frame(AVCodecContext *avctx,
uint32_t
tmp
=
ff_reverse
[
*
samples
>>
8
]
+
(
ff_reverse
[
*
samples
&
0xff
]
<<
8
);
tmp
<<=
4
;
// sync flags would go here
dst
[
2
]
=
tmp
&
0xff
;
tmp
>>=
8
;
dst
[
1
]
=
tmp
&
0xff
;
dst
[
0
]
=
tmp
>>
8
;
bytestream_put_be24
(
&
dst
,
tmp
);
samples
++
;
dst
+=
3
;
}
break
;
case
CODEC_ID_PCM_S16LE
:
for
(;
n
>
0
;
n
--
)
{
v
=
*
samples
++
;
dst
[
0
]
=
v
&
0xff
;
dst
[
1
]
=
v
>>
8
;
dst
+=
2
;
bytestream_put_le16
(
&
dst
,
v
);
}
break
;
case
CODEC_ID_PCM_S16BE
:
for
(;
n
>
0
;
n
--
)
{
v
=
*
samples
++
;
dst
[
0
]
=
v
>>
8
;
dst
[
1
]
=
v
;
dst
+=
2
;
bytestream_put_be16
(
&
dst
,
v
);
}
break
;
case
CODEC_ID_PCM_U16LE
:
for
(;
n
>
0
;
n
--
)
{
v
=
*
samples
++
;
v
+=
0x8000
;
dst
[
0
]
=
v
&
0xff
;
dst
[
1
]
=
v
>>
8
;
dst
+=
2
;
bytestream_put_le16
(
&
dst
,
v
);
}
break
;
case
CODEC_ID_PCM_U16BE
:
for
(;
n
>
0
;
n
--
)
{
v
=
*
samples
++
;
v
+=
0x8000
;
dst
[
0
]
=
v
>>
8
;
dst
[
1
]
=
v
;
dst
+=
2
;
bytestream_put_be16
(
&
dst
,
v
);
}
break
;
case
CODEC_ID_PCM_S8
:
...
...
@@ -425,39 +414,34 @@ static int pcm_decode_frame(AVCodecContext *avctx,
case
CODEC_ID_PCM_S24DAUD
:
n
=
buf_size
/
3
;
for
(;
n
>
0
;
n
--
)
{
uint32_t
v
=
src
[
0
]
<<
16
|
src
[
1
]
<<
8
|
src
[
2
]
;
uint32_t
v
=
bytestream_get_be24
(
&
src
)
;
v
>>=
4
;
// sync flags are here
*
samples
++
=
ff_reverse
[(
v
>>
8
)
&
0xff
]
+
(
ff_reverse
[
v
&
0xff
]
<<
8
);
src
+=
3
;
}
break
;
case
CODEC_ID_PCM_S16LE
:
n
=
buf_size
>>
1
;
for
(;
n
>
0
;
n
--
)
{
*
samples
++
=
src
[
0
]
|
(
src
[
1
]
<<
8
);
src
+=
2
;
*
samples
++
=
bytestream_get_le16
(
&
src
);
}
break
;
case
CODEC_ID_PCM_S16BE
:
n
=
buf_size
>>
1
;
for
(;
n
>
0
;
n
--
)
{
*
samples
++
=
(
src
[
0
]
<<
8
)
|
src
[
1
];
src
+=
2
;
*
samples
++
=
bytestream_get_be16
(
&
src
);
}
break
;
case
CODEC_ID_PCM_U16LE
:
n
=
buf_size
>>
1
;
for
(;
n
>
0
;
n
--
)
{
*
samples
++
=
(
src
[
0
]
|
(
src
[
1
]
<<
8
))
-
0x8000
;
src
+=
2
;
*
samples
++
=
bytestream_get_le16
(
&
src
)
-
0x8000
;
}
break
;
case
CODEC_ID_PCM_U16BE
:
n
=
buf_size
>>
1
;
for
(;
n
>
0
;
n
--
)
{
*
samples
++
=
((
src
[
0
]
<<
8
)
|
src
[
1
])
-
0x8000
;
src
+=
2
;
*
samples
++
=
bytestream_get_be16
(
&
src
)
-
0x8000
;
}
break
;
case
CODEC_ID_PCM_S8
:
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录