Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
kernel_linux
提交
48f666c9
K
kernel_linux
项目概览
OpenHarmony
/
kernel_linux
上一次同步 4 年多
通知
15
Star
8
Fork
2
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
kernel_linux
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
48f666c9
编写于
3月 21, 2017
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
frv: switch to RAW_COPY_USER
Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
9a7513cf
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
24 addition
and
34 deletion
+24
-34
arch/frv/Kconfig
arch/frv/Kconfig
+1
-0
arch/frv/include/asm/uaccess.h
arch/frv/include/asm/uaccess.h
+23
-34
未找到文件。
arch/frv/Kconfig
浏览文件 @
48f666c9
...
@@ -16,6 +16,7 @@ config FRV
...
@@ -16,6 +16,7 @@ config FRV
select OLD_SIGACTION
select OLD_SIGACTION
select HAVE_DEBUG_STACKOVERFLOW
select HAVE_DEBUG_STACKOVERFLOW
select ARCH_NO_COHERENT_DMA_MMAP
select ARCH_NO_COHERENT_DMA_MMAP
select ARCH_HAS_RAW_COPY_USER
config ZONE_DMA
config ZONE_DMA
bool
bool
...
...
arch/frv/include/asm/uaccess.h
浏览文件 @
48f666c9
...
@@ -233,61 +233,50 @@ do { \
...
@@ -233,61 +233,50 @@ do { \
/*
/*
*
*
*/
*/
#define ____force(x) (__force void *)(void __user *)(x)
#define ____force(x) (__force void *)(void __user *)(x)
#ifdef CONFIG_MMU
#ifdef CONFIG_MMU
extern
long
__memset_user
(
void
*
dst
,
unsigned
long
count
);
extern
long
__memset_user
(
void
*
dst
,
unsigned
long
count
);
extern
long
__memcpy_user
(
void
*
dst
,
const
void
*
src
,
unsigned
long
count
);
extern
long
__memcpy_user
(
void
*
dst
,
const
void
*
src
,
unsigned
long
count
);
#define __clear_user(dst,count) __memset_user(____force(dst), (count))
#define __clear_user(dst,count) __memset_user(____force(dst), (count))
#define __copy_from_user_inatomic(to, from, n) __memcpy_user((to), ____force(from), (n))
#define __copy_to_user_inatomic(to, from, n) __memcpy_user(____force(to), (from), (n))
#else
#else
#define __clear_user(dst,count) (memset(____force(dst), 0, (count)), 0)
#define __clear_user(dst,count) (memset(____force(dst), 0, (count)), 0)
#define __copy_from_user_inatomic(to, from, n) (memcpy((to), ____force(from), (n)), 0)
#define __copy_to_user_inatomic(to, from, n) (memcpy(____force(to), (from), (n)), 0)
#endif
#endif
static
inline
unsigned
long
__must_check
clear_user
(
void
__user
*
to
,
unsigned
long
n
)
{
if
(
likely
(
__access_ok
(
to
,
n
)))
n
=
__clear_user
(
to
,
n
);
return
n
;
}
static
inline
unsigned
long
__must_check
__copy_to_user
(
void
__user
*
to
,
const
void
*
from
,
unsigned
long
n
)
{
might_fault
();
return
__copy_to_user_inatomic
(
to
,
from
,
n
);
}
static
inline
unsigned
long
static
inline
unsigned
long
_
_copy_from_user
(
void
*
to
,
const
void
__user
*
from
,
unsigned
long
n
)
raw
_copy_from_user
(
void
*
to
,
const
void
__user
*
from
,
unsigned
long
n
)
{
{
might_fault
();
#ifdef CONFIG_MMU
return
__copy_from_user_inatomic
(
to
,
from
,
n
);
return
__memcpy_user
(
to
,
(
__force
const
void
*
)
from
,
n
);
#else
memcpy
(
to
,
(
__force
const
void
*
)
from
,
n
);
return
0
;
#endif
}
}
static
inline
long
copy_from_user
(
void
*
to
,
const
void
__user
*
from
,
unsigned
long
n
)
static
inline
unsigned
long
raw_copy_to_user
(
void
__user
*
to
,
const
void
*
from
,
unsigned
long
n
)
{
{
unsigned
long
ret
=
n
;
#ifdef CONFIG_MMU
return
__memcpy_user
((
__force
void
*
)
to
,
from
,
n
);
if
(
likely
(
__access_ok
(
from
,
n
)))
#else
ret
=
__copy_from_user
(
to
,
from
,
n
);
memcpy
((
__force
void
*
)
to
,
from
,
n
);
return
0
;
if
(
unlikely
(
ret
!=
0
))
#endif
memset
(
to
+
(
n
-
ret
),
0
,
ret
);
return
ret
;
}
}
#define INLINE_COPY_TO_USER
#define INLINE_COPY_FROM_USER
static
inline
long
copy_to_user
(
void
__user
*
to
,
const
void
*
from
,
unsigned
long
n
)
static
inline
unsigned
long
__must_check
clear_user
(
void
__user
*
to
,
unsigned
long
n
)
{
{
return
likely
(
__access_ok
(
to
,
n
))
?
__copy_to_user
(
to
,
from
,
n
)
:
n
;
if
(
likely
(
__access_ok
(
to
,
n
)))
n
=
__clear_user
(
to
,
n
);
return
n
;
}
}
extern
long
strncpy_from_user
(
char
*
dst
,
const
char
__user
*
src
,
long
count
);
extern
long
strncpy_from_user
(
char
*
dst
,
const
char
__user
*
src
,
long
count
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录