Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
01b812bc
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
160
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看板
提交
01b812bc
编写于
1月 18, 2013
作者:
V
Vineet Gupta
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
ARC: Futex support
Signed-off-by:
N
Vineet Gupta
<
vgupta@synopsys.com
>
上级
547f1125
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
151 addition
and
0 deletion
+151
-0
arch/arc/include/asm/futex.h
arch/arc/include/asm/futex.h
+151
-0
未找到文件。
arch/arc/include/asm/futex.h
0 → 100644
浏览文件 @
01b812bc
/*
* Copyright (C) 2004, 2007-2010, 2011-2012 Synopsys, Inc. (www.synopsys.com)
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*
* Vineetg: August 2010: From Android kernel work
*/
#ifndef _ASM_FUTEX_H
#define _ASM_FUTEX_H
#include <linux/futex.h>
#include <linux/preempt.h>
#include <linux/uaccess.h>
#include <asm/errno.h>
#define __futex_atomic_op(insn, ret, oldval, uaddr, oparg)\
\
__asm__ __volatile__( \
"1: ld %1, [%2] \n" \
insn "\n" \
"2: st %0, [%2] \n" \
" mov %0, 0 \n" \
"3: \n" \
" .section .fixup,\"ax\" \n" \
" .align 4 \n" \
"4: mov %0, %4 \n" \
" b 3b \n" \
" .previous \n" \
" .section __ex_table,\"a\" \n" \
" .align 4 \n" \
" .word 1b, 4b \n" \
" .word 2b, 4b \n" \
" .previous \n" \
\
: "=&r" (ret), "=&r" (oldval) \
: "r" (uaddr), "r" (oparg), "ir" (-EFAULT) \
: "cc", "memory")
static
inline
int
futex_atomic_op_inuser
(
int
encoded_op
,
u32
__user
*
uaddr
)
{
int
op
=
(
encoded_op
>>
28
)
&
7
;
int
cmp
=
(
encoded_op
>>
24
)
&
15
;
int
oparg
=
(
encoded_op
<<
8
)
>>
20
;
int
cmparg
=
(
encoded_op
<<
20
)
>>
20
;
int
oldval
=
0
,
ret
;
if
(
encoded_op
&
(
FUTEX_OP_OPARG_SHIFT
<<
28
))
oparg
=
1
<<
oparg
;
if
(
!
access_ok
(
VERIFY_WRITE
,
uaddr
,
sizeof
(
int
)))
return
-
EFAULT
;
pagefault_disable
();
/* implies preempt_disable() */
switch
(
op
)
{
case
FUTEX_OP_SET
:
__futex_atomic_op
(
"mov %0, %3"
,
ret
,
oldval
,
uaddr
,
oparg
);
break
;
case
FUTEX_OP_ADD
:
__futex_atomic_op
(
"add %0, %1, %3"
,
ret
,
oldval
,
uaddr
,
oparg
);
break
;
case
FUTEX_OP_OR
:
__futex_atomic_op
(
"or %0, %1, %3"
,
ret
,
oldval
,
uaddr
,
oparg
);
break
;
case
FUTEX_OP_ANDN
:
__futex_atomic_op
(
"bic %0, %1, %3"
,
ret
,
oldval
,
uaddr
,
oparg
);
break
;
case
FUTEX_OP_XOR
:
__futex_atomic_op
(
"xor %0, %1, %3"
,
ret
,
oldval
,
uaddr
,
oparg
);
break
;
default:
ret
=
-
ENOSYS
;
}
pagefault_enable
();
/* subsumes preempt_enable() */
if
(
!
ret
)
{
switch
(
cmp
)
{
case
FUTEX_OP_CMP_EQ
:
ret
=
(
oldval
==
cmparg
);
break
;
case
FUTEX_OP_CMP_NE
:
ret
=
(
oldval
!=
cmparg
);
break
;
case
FUTEX_OP_CMP_LT
:
ret
=
(
oldval
<
cmparg
);
break
;
case
FUTEX_OP_CMP_GE
:
ret
=
(
oldval
>=
cmparg
);
break
;
case
FUTEX_OP_CMP_LE
:
ret
=
(
oldval
<=
cmparg
);
break
;
case
FUTEX_OP_CMP_GT
:
ret
=
(
oldval
>
cmparg
);
break
;
default:
ret
=
-
ENOSYS
;
}
}
return
ret
;
}
/* Compare-xchg with preemption disabled.
* Notes:
* -Best-Effort: Exchg happens only if compare succeeds.
* If compare fails, returns; leaving retry/looping to upper layers
* -successful cmp-xchg: return orig value in @addr (same as cmp val)
* -Compare fails: return orig value in @addr
* -user access r/w fails: return -EFAULT
*/
static
inline
int
futex_atomic_cmpxchg_inatomic
(
u32
*
uval
,
u32
__user
*
uaddr
,
u32
oldval
,
u32
newval
)
{
u32
val
;
if
(
!
access_ok
(
VERIFY_WRITE
,
uaddr
,
sizeof
(
int
)))
return
-
EFAULT
;
pagefault_disable
();
/* implies preempt_disable() */
/* TBD : can use llock/scond */
__asm__
__volatile__
(
"1: ld %0, [%3]
\n
"
" brne %0, %1, 3f
\n
"
"2: st %2, [%3]
\n
"
"3:
\n
"
" .section .fixup,
\"
ax
\"
\n
"
"4: mov %0, %4
\n
"
" b 3b
\n
"
" .previous
\n
"
" .section __ex_table,
\"
a
\"
\n
"
" .align 4
\n
"
" .word 1b, 4b
\n
"
" .word 2b, 4b
\n
"
" .previous
\n
"
:
"=&r"
(
val
)
:
"r"
(
oldval
),
"r"
(
newval
),
"r"
(
uaddr
),
"ir"
(
-
EFAULT
)
:
"cc"
,
"memory"
);
pagefault_enable
();
/* subsumes preempt_enable() */
*
uval
=
val
;
return
val
;
}
#endif
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录