Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
742fd1bc
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
161
Star
36
Fork
7
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
10
列表
看板
标记
里程碑
合并请求
2
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
cloud-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
10
Issue
10
列表
看板
标记
里程碑
合并请求
2
合并请求
2
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
742fd1bc
编写于
16年前
作者:
P
Paul Mundt
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
sh: Provide movli.l/movco.l-based bitops.
Signed-off-by:
N
Paul Mundt
<
lethal@linux-sh.org
>
上级
7686ad56
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
146 addition
and
0 deletion
+146
-0
arch/sh/include/asm/bitops-llsc.h
arch/sh/include/asm/bitops-llsc.h
+144
-0
arch/sh/include/asm/bitops.h
arch/sh/include/asm/bitops.h
+2
-0
未找到文件。
arch/sh/include/asm/bitops-llsc.h
0 → 100644
浏览文件 @
742fd1bc
#ifndef __ASM_SH_BITOPS_LLSC_H
#define __ASM_SH_BITOPS_LLSC_H
static
inline
void
set_bit
(
int
nr
,
volatile
void
*
addr
)
{
int
mask
;
volatile
unsigned
int
*
a
=
addr
;
unsigned
long
tmp
;
a
+=
nr
>>
5
;
mask
=
1
<<
(
nr
&
0x1f
);
__asm__
__volatile__
(
"1:
\n\t
"
"movli.l @%1, %0 ! set_bit
\n\t
"
"or %3, %0
\n\t
"
"movco.l %0, @%1
\n\t
"
"bf 1b
\n\t
"
:
"=&z"
(
tmp
),
"=r"
(
a
)
:
"1"
(
a
),
"r"
(
mask
)
:
"t"
,
"memory"
);
}
static
inline
void
clear_bit
(
int
nr
,
volatile
void
*
addr
)
{
int
mask
;
volatile
unsigned
int
*
a
=
addr
;
unsigned
long
tmp
;
a
+=
nr
>>
5
;
mask
=
1
<<
(
nr
&
0x1f
);
__asm__
__volatile__
(
"1:
\n\t
"
"movli.l @%1, %0 ! clear_bit
\n\t
"
"and %3, %0
\n\t
"
"movco.l %0, @%1
\n\t
"
"bf 1b
\n\t
"
:
"=&z"
(
tmp
),
"=r"
(
a
)
:
"1"
(
a
),
"r"
(
~
mask
)
:
"t"
,
"memory"
);
}
static
inline
void
change_bit
(
int
nr
,
volatile
void
*
addr
)
{
int
mask
;
volatile
unsigned
int
*
a
=
addr
;
unsigned
long
tmp
;
a
+=
nr
>>
5
;
mask
=
1
<<
(
nr
&
0x1f
);
__asm__
__volatile__
(
"1:
\n\t
"
"movli.l @%1, %0 ! change_bit
\n\t
"
"xor %3, %0
\n\t
"
"movco.l %0, @%1
\n\t
"
"bf 1b
\n\t
"
:
"=&z"
(
tmp
),
"=r"
(
a
)
:
"1"
(
a
),
"r"
(
mask
)
:
"t"
,
"memory"
);
}
static
inline
int
test_and_set_bit
(
int
nr
,
volatile
void
*
addr
)
{
int
mask
,
retval
;
volatile
unsigned
int
*
a
=
addr
;
unsigned
long
tmp
;
a
+=
nr
>>
5
;
mask
=
1
<<
(
nr
&
0x1f
);
__asm__
__volatile__
(
"1:
\n\t
"
"movli.l @%1, %0 ! test_and_set_bit
\n\t
"
"mov %0, %2
\n\t
"
"or %4, %0
\n\t
"
"movco.l %0, @%1
\n\t
"
"bf 1b
\n\t
"
"and %4, %2
\n\t
"
:
"=&z"
(
tmp
),
"=r"
(
a
),
"=&r"
(
retval
)
:
"1"
(
a
),
"r"
(
mask
)
:
"t"
,
"memory"
);
return
retval
!=
0
;
}
static
inline
int
test_and_clear_bit
(
int
nr
,
volatile
void
*
addr
)
{
int
mask
,
retval
;
volatile
unsigned
int
*
a
=
addr
;
unsigned
long
tmp
;
a
+=
nr
>>
5
;
mask
=
1
<<
(
nr
&
0x1f
);
__asm__
__volatile__
(
"1:
\n\t
"
"movli.l @%1, %0 ! test_and_clear_bit
\n\t
"
"mov %0, %2
\n\t
"
"and %5, %0
\n\t
"
"movco.l %0, @%1
\n\t
"
"bf 1b
\n\t
"
"and %4, %2
\n\t
"
"synco
\n\t
"
:
"=&z"
(
tmp
),
"=r"
(
a
),
"=&r"
(
retval
)
:
"1"
(
a
),
"r"
(
mask
),
"r"
(
~
mask
)
:
"t"
,
"memory"
);
return
retval
!=
0
;
}
static
inline
int
test_and_change_bit
(
int
nr
,
volatile
void
*
addr
)
{
int
mask
,
retval
;
volatile
unsigned
int
*
a
=
addr
;
unsigned
long
tmp
;
a
+=
nr
>>
5
;
mask
=
1
<<
(
nr
&
0x1f
);
__asm__
__volatile__
(
"1:
\n\t
"
"movli.l @%1, %0 ! test_and_change_bit
\n\t
"
"mov %0, %2
\n\t
"
"xor %4, %0
\n\t
"
"movco.l %0, @%1
\n\t
"
"bf 1b
\n\t
"
"and %4, %2
\n\t
"
"synco
\n\t
"
:
"=&z"
(
tmp
),
"=r"
(
a
),
"=&r"
(
retval
)
:
"1"
(
a
),
"r"
(
mask
)
:
"t"
,
"memory"
);
return
retval
!=
0
;
}
#endif
/* __ASM_SH_BITOPS_LLSC_H */
This diff is collapsed.
Click to expand it.
arch/sh/include/asm/bitops.h
浏览文件 @
742fd1bc
...
...
@@ -13,6 +13,8 @@
#ifdef CONFIG_GUSA_RB
#include <asm/bitops-grb.h>
#elif defined(CONFIG_CPU_SH4A)
#include <asm/bitops-llsc.h>
#else
#include <asm/bitops-irq.h>
#endif
...
...
This diff is collapsed.
Click to expand it.
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录