Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
小白菜888
Ffmpeg
提交
2d3b21ff
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,发现更多精彩内容 >>
提交
2d3b21ff
编写于
3月 23, 2011
作者:
M
Mans Rullgard
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
ARM: NEON optimised apply_window_int16()
Signed-off-by:
N
Mans Rullgard
<
mans@mansr.com
>
上级
245c7831
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
28 addition
and
0 deletion
+28
-0
libavcodec/arm/dsputil_init_neon.c
libavcodec/arm/dsputil_init_neon.c
+5
-0
libavcodec/arm/dsputil_neon.S
libavcodec/arm/dsputil_neon.S
+23
-0
未找到文件。
libavcodec/arm/dsputil_init_neon.c
浏览文件 @
2d3b21ff
...
...
@@ -168,6 +168,9 @@ int32_t ff_scalarproduct_int16_neon(const int16_t *v1, const int16_t *v2, int le
int32_t
ff_scalarproduct_and_madd_int16_neon
(
int16_t
*
v1
,
const
int16_t
*
v2
,
const
int16_t
*
v3
,
int
len
,
int
mul
);
void
ff_apply_window_int16_neon
(
int16_t
*
dst
,
const
int16_t
*
src
,
const
int16_t
*
window
,
int
n
);
void
ff_dsputil_init_neon
(
DSPContext
*
c
,
AVCodecContext
*
avctx
)
{
if
(
!
avctx
->
lowres
)
{
...
...
@@ -319,4 +322,6 @@ void ff_dsputil_init_neon(DSPContext *c, AVCodecContext *avctx)
c
->
scalarproduct_int16
=
ff_scalarproduct_int16_neon
;
c
->
scalarproduct_and_madd_int16
=
ff_scalarproduct_and_madd_int16_neon
;
c
->
apply_window_int16
=
ff_apply_window_int16_neon
;
}
libavcodec/arm/dsputil_neon.S
浏览文件 @
2d3b21ff
...
...
@@ -789,3 +789,26 @@ NOVFP ldr r2, [sp]
vst1.f32
{
q9
},[
r0
,:
128
]!
bx
lr
endfunc
function
ff_apply_window_int16_neon
,
export
=
1
push
{
r4
,
lr
}
add
r4
,
r1
,
r3
,
lsl
#
1
add
lr
,
r0
,
r3
,
lsl
#
1
sub
r4
,
r4
,
#
16
sub
lr
,
lr
,
#
16
mov
r12
,
#-
16
1
:
vld1.16
{
q0
},
[
r1
,:
128
]!
vld1.16
{
q2
},
[
r2
,:
128
]!
vld1.16
{
q1
},
[
r4
,:
128
],
r12
vrev64.16
q3
,
q2
vqrdmulh.s16
q0
,
q0
,
q2
vqrdmulh.s16
d2
,
d2
,
d7
vqrdmulh.s16
d3
,
d3
,
d6
vst1.16
{
q0
},
[
r0
,:
128
]!
vst1.16
{
q1
},
[
lr
,:
128
],
r12
subs
r3
,
r3
,
#
16
bgt
1
b
pop
{
r4
,
pc
}
endfunc
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录