Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
9b04c5fe
R
raspberrypi-kernel
项目概览
openeuler
/
raspberrypi-kernel
通知
13
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
raspberrypi-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
9b04c5fe
编写于
11月 25, 2011
作者:
C
Cong Wang
提交者:
Cong Wang
3月 20, 2012
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
mm: remove the second argument of k[un]map_atomic()
Signed-off-by:
N
Cong Wang
<
amwang@redhat.com
>
上级
c3eede8e
变更
7
隐藏空白更改
内联
并排
Showing
7 changed file
with
35 addition
and
35 deletion
+35
-35
mm/bounce.c
mm/bounce.c
+2
-2
mm/filemap.c
mm/filemap.c
+4
-4
mm/ksm.c
mm/ksm.c
+6
-6
mm/memory.c
mm/memory.c
+2
-2
mm/shmem.c
mm/shmem.c
+2
-2
mm/swapfile.c
mm/swapfile.c
+15
-15
mm/vmalloc.c
mm/vmalloc.c
+4
-4
未找到文件。
mm/bounce.c
浏览文件 @
9b04c5fe
...
...
@@ -50,9 +50,9 @@ static void bounce_copy_vec(struct bio_vec *to, unsigned char *vfrom)
unsigned
char
*
vto
;
local_irq_save
(
flags
);
vto
=
kmap_atomic
(
to
->
bv_page
,
KM_BOUNCE_READ
);
vto
=
kmap_atomic
(
to
->
bv_page
);
memcpy
(
vto
+
to
->
bv_offset
,
vfrom
,
to
->
bv_len
);
kunmap_atomic
(
vto
,
KM_BOUNCE_READ
);
kunmap_atomic
(
vto
);
local_irq_restore
(
flags
);
}
...
...
mm/filemap.c
浏览文件 @
9b04c5fe
...
...
@@ -1318,10 +1318,10 @@ int file_read_actor(read_descriptor_t *desc, struct page *page,
* taking the kmap.
*/
if
(
!
fault_in_pages_writeable
(
desc
->
arg
.
buf
,
size
))
{
kaddr
=
kmap_atomic
(
page
,
KM_USER0
);
kaddr
=
kmap_atomic
(
page
);
left
=
__copy_to_user_inatomic
(
desc
->
arg
.
buf
,
kaddr
+
offset
,
size
);
kunmap_atomic
(
kaddr
,
KM_USER0
);
kunmap_atomic
(
kaddr
);
if
(
left
==
0
)
goto
success
;
}
...
...
@@ -2045,7 +2045,7 @@ size_t iov_iter_copy_from_user_atomic(struct page *page,
size_t
copied
;
BUG_ON
(
!
in_atomic
());
kaddr
=
kmap_atomic
(
page
,
KM_USER0
);
kaddr
=
kmap_atomic
(
page
);
if
(
likely
(
i
->
nr_segs
==
1
))
{
int
left
;
char
__user
*
buf
=
i
->
iov
->
iov_base
+
i
->
iov_offset
;
...
...
@@ -2055,7 +2055,7 @@ size_t iov_iter_copy_from_user_atomic(struct page *page,
copied
=
__iovec_copy_from_user_inatomic
(
kaddr
+
offset
,
i
->
iov
,
i
->
iov_offset
,
bytes
);
}
kunmap_atomic
(
kaddr
,
KM_USER0
);
kunmap_atomic
(
kaddr
);
return
copied
;
}
...
...
mm/ksm.c
浏览文件 @
9b04c5fe
...
...
@@ -672,9 +672,9 @@ static int unmerge_and_remove_all_rmap_items(void)
static
u32
calc_checksum
(
struct
page
*
page
)
{
u32
checksum
;
void
*
addr
=
kmap_atomic
(
page
,
KM_USER0
);
void
*
addr
=
kmap_atomic
(
page
);
checksum
=
jhash2
(
addr
,
PAGE_SIZE
/
4
,
17
);
kunmap_atomic
(
addr
,
KM_USER0
);
kunmap_atomic
(
addr
);
return
checksum
;
}
...
...
@@ -683,11 +683,11 @@ static int memcmp_pages(struct page *page1, struct page *page2)
char
*
addr1
,
*
addr2
;
int
ret
;
addr1
=
kmap_atomic
(
page1
,
KM_USER0
);
addr2
=
kmap_atomic
(
page2
,
KM_USER1
);
addr1
=
kmap_atomic
(
page1
);
addr2
=
kmap_atomic
(
page2
);
ret
=
memcmp
(
addr1
,
addr2
,
PAGE_SIZE
);
kunmap_atomic
(
addr2
,
KM_USER1
);
kunmap_atomic
(
addr1
,
KM_USER0
);
kunmap_atomic
(
addr2
);
kunmap_atomic
(
addr1
);
return
ret
;
}
...
...
mm/memory.c
浏览文件 @
9b04c5fe
...
...
@@ -2447,7 +2447,7 @@ static inline void cow_user_page(struct page *dst, struct page *src, unsigned lo
* fails, we just zero-fill it. Live with it.
*/
if
(
unlikely
(
!
src
))
{
void
*
kaddr
=
kmap_atomic
(
dst
,
KM_USER0
);
void
*
kaddr
=
kmap_atomic
(
dst
);
void
__user
*
uaddr
=
(
void
__user
*
)(
va
&
PAGE_MASK
);
/*
...
...
@@ -2458,7 +2458,7 @@ static inline void cow_user_page(struct page *dst, struct page *src, unsigned lo
*/
if
(
__copy_from_user_inatomic
(
kaddr
,
uaddr
,
PAGE_SIZE
))
clear_page
(
kaddr
);
kunmap_atomic
(
kaddr
,
KM_USER0
);
kunmap_atomic
(
kaddr
);
flush_dcache_page
(
dst
);
}
else
copy_user_highpage
(
dst
,
src
,
va
,
vma
);
...
...
mm/shmem.c
浏览文件 @
9b04c5fe
...
...
@@ -1656,9 +1656,9 @@ static int shmem_symlink(struct inode *dir, struct dentry *dentry, const char *s
}
inode
->
i_mapping
->
a_ops
=
&
shmem_aops
;
inode
->
i_op
=
&
shmem_symlink_inode_operations
;
kaddr
=
kmap_atomic
(
page
,
KM_USER0
);
kaddr
=
kmap_atomic
(
page
);
memcpy
(
kaddr
,
symname
,
len
);
kunmap_atomic
(
kaddr
,
KM_USER0
);
kunmap_atomic
(
kaddr
);
set_page_dirty
(
page
);
unlock_page
(
page
);
page_cache_release
(
page
);
...
...
mm/swapfile.c
浏览文件 @
9b04c5fe
...
...
@@ -2427,9 +2427,9 @@ int add_swap_count_continuation(swp_entry_t entry, gfp_t gfp_mask)
if
(
!
(
count
&
COUNT_CONTINUED
))
goto
out
;
map
=
kmap_atomic
(
list_page
,
KM_USER0
)
+
offset
;
map
=
kmap_atomic
(
list_page
)
+
offset
;
count
=
*
map
;
kunmap_atomic
(
map
,
KM_USER0
);
kunmap_atomic
(
map
);
/*
* If this continuation count now has some space in it,
...
...
@@ -2472,7 +2472,7 @@ static bool swap_count_continued(struct swap_info_struct *si,
offset
&=
~
PAGE_MASK
;
page
=
list_entry
(
head
->
lru
.
next
,
struct
page
,
lru
);
map
=
kmap_atomic
(
page
,
KM_USER0
)
+
offset
;
map
=
kmap_atomic
(
page
)
+
offset
;
if
(
count
==
SWAP_MAP_MAX
)
/* initial increment from swap_map */
goto
init_map
;
/* jump over SWAP_CONT_MAX checks */
...
...
@@ -2482,26 +2482,26 @@ static bool swap_count_continued(struct swap_info_struct *si,
* Think of how you add 1 to 999
*/
while
(
*
map
==
(
SWAP_CONT_MAX
|
COUNT_CONTINUED
))
{
kunmap_atomic
(
map
,
KM_USER0
);
kunmap_atomic
(
map
);
page
=
list_entry
(
page
->
lru
.
next
,
struct
page
,
lru
);
BUG_ON
(
page
==
head
);
map
=
kmap_atomic
(
page
,
KM_USER0
)
+
offset
;
map
=
kmap_atomic
(
page
)
+
offset
;
}
if
(
*
map
==
SWAP_CONT_MAX
)
{
kunmap_atomic
(
map
,
KM_USER0
);
kunmap_atomic
(
map
);
page
=
list_entry
(
page
->
lru
.
next
,
struct
page
,
lru
);
if
(
page
==
head
)
return
false
;
/* add count continuation */
map
=
kmap_atomic
(
page
,
KM_USER0
)
+
offset
;
map
=
kmap_atomic
(
page
)
+
offset
;
init_map:
*
map
=
0
;
/* we didn't zero the page */
}
*
map
+=
1
;
kunmap_atomic
(
map
,
KM_USER0
);
kunmap_atomic
(
map
);
page
=
list_entry
(
page
->
lru
.
prev
,
struct
page
,
lru
);
while
(
page
!=
head
)
{
map
=
kmap_atomic
(
page
,
KM_USER0
)
+
offset
;
map
=
kmap_atomic
(
page
)
+
offset
;
*
map
=
COUNT_CONTINUED
;
kunmap_atomic
(
map
,
KM_USER0
);
kunmap_atomic
(
map
);
page
=
list_entry
(
page
->
lru
.
prev
,
struct
page
,
lru
);
}
return
true
;
/* incremented */
...
...
@@ -2512,22 +2512,22 @@ init_map: *map = 0; /* we didn't zero the page */
*/
BUG_ON
(
count
!=
COUNT_CONTINUED
);
while
(
*
map
==
COUNT_CONTINUED
)
{
kunmap_atomic
(
map
,
KM_USER0
);
kunmap_atomic
(
map
);
page
=
list_entry
(
page
->
lru
.
next
,
struct
page
,
lru
);
BUG_ON
(
page
==
head
);
map
=
kmap_atomic
(
page
,
KM_USER0
)
+
offset
;
map
=
kmap_atomic
(
page
)
+
offset
;
}
BUG_ON
(
*
map
==
0
);
*
map
-=
1
;
if
(
*
map
==
0
)
count
=
0
;
kunmap_atomic
(
map
,
KM_USER0
);
kunmap_atomic
(
map
);
page
=
list_entry
(
page
->
lru
.
prev
,
struct
page
,
lru
);
while
(
page
!=
head
)
{
map
=
kmap_atomic
(
page
,
KM_USER0
)
+
offset
;
map
=
kmap_atomic
(
page
)
+
offset
;
*
map
=
SWAP_CONT_MAX
|
count
;
count
=
COUNT_CONTINUED
;
kunmap_atomic
(
map
,
KM_USER0
);
kunmap_atomic
(
map
);
page
=
list_entry
(
page
->
lru
.
prev
,
struct
page
,
lru
);
}
return
count
==
COUNT_CONTINUED
;
...
...
mm/vmalloc.c
浏览文件 @
9b04c5fe
...
...
@@ -1906,9 +1906,9 @@ static int aligned_vread(char *buf, char *addr, unsigned long count)
* we can expect USER0 is not used (see vread/vwrite's
* function description)
*/
void
*
map
=
kmap_atomic
(
p
,
KM_USER0
);
void
*
map
=
kmap_atomic
(
p
);
memcpy
(
buf
,
map
+
offset
,
length
);
kunmap_atomic
(
map
,
KM_USER0
);
kunmap_atomic
(
map
);
}
else
memset
(
buf
,
0
,
length
);
...
...
@@ -1945,9 +1945,9 @@ static int aligned_vwrite(char *buf, char *addr, unsigned long count)
* we can expect USER0 is not used (see vread/vwrite's
* function description)
*/
void
*
map
=
kmap_atomic
(
p
,
KM_USER0
);
void
*
map
=
kmap_atomic
(
p
);
memcpy
(
map
+
offset
,
buf
,
length
);
kunmap_atomic
(
map
,
KM_USER0
);
kunmap_atomic
(
map
);
}
addr
+=
length
;
buf
+=
length
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录