Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
50bc9b65
Commit
50bc9b65
authored
Nov 25, 2011
by
Cong Wang
Committed by
Cong Wang
Mar 20, 2012
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
logfs: remove the second argument of k[un]map_atomic()
Signed-off-by:
Cong Wang
<
amwang@redhat.com
>
parent
303a8f2a
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
30 additions
and
30 deletions
+30
-30
fs/logfs/dir.c
fs/logfs/dir.c
+9
-9
fs/logfs/readwrite.c
fs/logfs/readwrite.c
+19
-19
fs/logfs/segment.c
fs/logfs/segment.c
+2
-2
No files found.
fs/logfs/dir.c
View file @
50bc9b65
...
@@ -177,17 +177,17 @@ static struct page *logfs_get_dd_page(struct inode *dir, struct dentry *dentry)
...
@@ -177,17 +177,17 @@ static struct page *logfs_get_dd_page(struct inode *dir, struct dentry *dentry)
(
filler_t
*
)
logfs_readpage
,
NULL
);
(
filler_t
*
)
logfs_readpage
,
NULL
);
if
(
IS_ERR
(
page
))
if
(
IS_ERR
(
page
))
return
page
;
return
page
;
dd
=
kmap_atomic
(
page
,
KM_USER0
);
dd
=
kmap_atomic
(
page
);
BUG_ON
(
dd
->
namelen
==
0
);
BUG_ON
(
dd
->
namelen
==
0
);
if
(
name
->
len
!=
be16_to_cpu
(
dd
->
namelen
)
||
if
(
name
->
len
!=
be16_to_cpu
(
dd
->
namelen
)
||
memcmp
(
name
->
name
,
dd
->
name
,
name
->
len
))
{
memcmp
(
name
->
name
,
dd
->
name
,
name
->
len
))
{
kunmap_atomic
(
dd
,
KM_USER0
);
kunmap_atomic
(
dd
);
page_cache_release
(
page
);
page_cache_release
(
page
);
continue
;
continue
;
}
}
kunmap_atomic
(
dd
,
KM_USER0
);
kunmap_atomic
(
dd
);
return
page
;
return
page
;
}
}
return
NULL
;
return
NULL
;
...
@@ -365,9 +365,9 @@ static struct dentry *logfs_lookup(struct inode *dir, struct dentry *dentry,
...
@@ -365,9 +365,9 @@ static struct dentry *logfs_lookup(struct inode *dir, struct dentry *dentry,
return
NULL
;
return
NULL
;
}
}
index
=
page
->
index
;
index
=
page
->
index
;
dd
=
kmap_atomic
(
page
,
KM_USER0
);
dd
=
kmap_atomic
(
page
);
ino
=
be64_to_cpu
(
dd
->
ino
);
ino
=
be64_to_cpu
(
dd
->
ino
);
kunmap_atomic
(
dd
,
KM_USER0
);
kunmap_atomic
(
dd
);
page_cache_release
(
page
);
page_cache_release
(
page
);
inode
=
logfs_iget
(
dir
->
i_sb
,
ino
);
inode
=
logfs_iget
(
dir
->
i_sb
,
ino
);
...
@@ -402,12 +402,12 @@ static int logfs_write_dir(struct inode *dir, struct dentry *dentry,
...
@@ -402,12 +402,12 @@ static int logfs_write_dir(struct inode *dir, struct dentry *dentry,
if
(
!
page
)
if
(
!
page
)
return
-
ENOMEM
;
return
-
ENOMEM
;
dd
=
kmap_atomic
(
page
,
KM_USER0
);
dd
=
kmap_atomic
(
page
);
memset
(
dd
,
0
,
sizeof
(
*
dd
));
memset
(
dd
,
0
,
sizeof
(
*
dd
));
dd
->
ino
=
cpu_to_be64
(
inode
->
i_ino
);
dd
->
ino
=
cpu_to_be64
(
inode
->
i_ino
);
dd
->
type
=
logfs_type
(
inode
);
dd
->
type
=
logfs_type
(
inode
);
logfs_set_name
(
dd
,
&
dentry
->
d_name
);
logfs_set_name
(
dd
,
&
dentry
->
d_name
);
kunmap_atomic
(
dd
,
KM_USER0
);
kunmap_atomic
(
dd
);
err
=
logfs_write_buf
(
dir
,
page
,
WF_LOCK
);
err
=
logfs_write_buf
(
dir
,
page
,
WF_LOCK
);
unlock_page
(
page
);
unlock_page
(
page
);
...
@@ -579,9 +579,9 @@ static int logfs_get_dd(struct inode *dir, struct dentry *dentry,
...
@@ -579,9 +579,9 @@ static int logfs_get_dd(struct inode *dir, struct dentry *dentry,
if
(
IS_ERR
(
page
))
if
(
IS_ERR
(
page
))
return
PTR_ERR
(
page
);
return
PTR_ERR
(
page
);
*
pos
=
page
->
index
;
*
pos
=
page
->
index
;
map
=
kmap_atomic
(
page
,
KM_USER0
);
map
=
kmap_atomic
(
page
);
memcpy
(
dd
,
map
,
sizeof
(
*
dd
));
memcpy
(
dd
,
map
,
sizeof
(
*
dd
));
kunmap_atomic
(
map
,
KM_USER0
);
kunmap_atomic
(
map
);
page_cache_release
(
page
);
page_cache_release
(
page
);
return
0
;
return
0
;
}
}
...
...
fs/logfs/readwrite.c
View file @
50bc9b65
...
@@ -517,9 +517,9 @@ static int indirect_write_alias(struct super_block *sb,
...
@@ -517,9 +517,9 @@ static int indirect_write_alias(struct super_block *sb,
ino
=
page
->
mapping
->
host
->
i_ino
;
ino
=
page
->
mapping
->
host
->
i_ino
;
logfs_unpack_index
(
page
->
index
,
&
bix
,
&
level
);
logfs_unpack_index
(
page
->
index
,
&
bix
,
&
level
);
child
=
kmap_atomic
(
page
,
KM_USER0
);
child
=
kmap_atomic
(
page
);
val
=
child
[
pos
];
val
=
child
[
pos
];
kunmap_atomic
(
child
,
KM_USER0
);
kunmap_atomic
(
child
);
err
=
write_one_alias
(
sb
,
ino
,
bix
,
level
,
pos
,
val
);
err
=
write_one_alias
(
sb
,
ino
,
bix
,
level
,
pos
,
val
);
if
(
err
)
if
(
err
)
return
err
;
return
err
;
...
@@ -673,9 +673,9 @@ static void alloc_indirect_block(struct inode *inode, struct page *page,
...
@@ -673,9 +673,9 @@ static void alloc_indirect_block(struct inode *inode, struct page *page,
alloc_data_block
(
inode
,
page
);
alloc_data_block
(
inode
,
page
);
block
=
logfs_block
(
page
);
block
=
logfs_block
(
page
);
array
=
kmap_atomic
(
page
,
KM_USER0
);
array
=
kmap_atomic
(
page
);
initialize_block_counters
(
page
,
block
,
array
,
page_is_empty
);
initialize_block_counters
(
page
,
block
,
array
,
page_is_empty
);
kunmap_atomic
(
array
,
KM_USER0
);
kunmap_atomic
(
array
);
}
}
static
void
block_set_pointer
(
struct
page
*
page
,
int
index
,
u64
ptr
)
static
void
block_set_pointer
(
struct
page
*
page
,
int
index
,
u64
ptr
)
...
@@ -685,10 +685,10 @@ static void block_set_pointer(struct page *page, int index, u64 ptr)
...
@@ -685,10 +685,10 @@ static void block_set_pointer(struct page *page, int index, u64 ptr)
u64
oldptr
;
u64
oldptr
;
BUG_ON
(
!
block
);
BUG_ON
(
!
block
);
array
=
kmap_atomic
(
page
,
KM_USER0
);
array
=
kmap_atomic
(
page
);
oldptr
=
be64_to_cpu
(
array
[
index
]);
oldptr
=
be64_to_cpu
(
array
[
index
]);
array
[
index
]
=
cpu_to_be64
(
ptr
);
array
[
index
]
=
cpu_to_be64
(
ptr
);
kunmap_atomic
(
array
,
KM_USER0
);
kunmap_atomic
(
array
);
SetPageUptodate
(
page
);
SetPageUptodate
(
page
);
block
->
full
+=
!!
(
ptr
&
LOGFS_FULLY_POPULATED
)
block
->
full
+=
!!
(
ptr
&
LOGFS_FULLY_POPULATED
)
...
@@ -701,9 +701,9 @@ static u64 block_get_pointer(struct page *page, int index)
...
@@ -701,9 +701,9 @@ static u64 block_get_pointer(struct page *page, int index)
__be64
*
block
;
__be64
*
block
;
u64
ptr
;
u64
ptr
;
block
=
kmap_atomic
(
page
,
KM_USER0
);
block
=
kmap_atomic
(
page
);
ptr
=
be64_to_cpu
(
block
[
index
]);
ptr
=
be64_to_cpu
(
block
[
index
]);
kunmap_atomic
(
block
,
KM_USER0
);
kunmap_atomic
(
block
);
return
ptr
;
return
ptr
;
}
}
...
@@ -850,7 +850,7 @@ static u64 seek_holedata_loop(struct inode *inode, u64 bix, int data)
...
@@ -850,7 +850,7 @@ static u64 seek_holedata_loop(struct inode *inode, u64 bix, int data)
}
}
slot
=
get_bits
(
bix
,
SUBLEVEL
(
level
));
slot
=
get_bits
(
bix
,
SUBLEVEL
(
level
));
rblock
=
kmap_atomic
(
page
,
KM_USER0
);
rblock
=
kmap_atomic
(
page
);
while
(
slot
<
LOGFS_BLOCK_FACTOR
)
{
while
(
slot
<
LOGFS_BLOCK_FACTOR
)
{
if
(
data
&&
(
rblock
[
slot
]
!=
0
))
if
(
data
&&
(
rblock
[
slot
]
!=
0
))
break
;
break
;
...
@@ -861,12 +861,12 @@ static u64 seek_holedata_loop(struct inode *inode, u64 bix, int data)
...
@@ -861,12 +861,12 @@ static u64 seek_holedata_loop(struct inode *inode, u64 bix, int data)
bix
&=
~
(
increment
-
1
);
bix
&=
~
(
increment
-
1
);
}
}
if
(
slot
>=
LOGFS_BLOCK_FACTOR
)
{
if
(
slot
>=
LOGFS_BLOCK_FACTOR
)
{
kunmap_atomic
(
rblock
,
KM_USER0
);
kunmap_atomic
(
rblock
);
logfs_put_read_page
(
page
);
logfs_put_read_page
(
page
);
return
bix
;
return
bix
;
}
}
bofs
=
be64_to_cpu
(
rblock
[
slot
]);
bofs
=
be64_to_cpu
(
rblock
[
slot
]);
kunmap_atomic
(
rblock
,
KM_USER0
);
kunmap_atomic
(
rblock
);
logfs_put_read_page
(
page
);
logfs_put_read_page
(
page
);
if
(
!
bofs
)
{
if
(
!
bofs
)
{
BUG_ON
(
data
);
BUG_ON
(
data
);
...
@@ -1961,9 +1961,9 @@ int logfs_read_inode(struct inode *inode)
...
@@ -1961,9 +1961,9 @@ int logfs_read_inode(struct inode *inode)
if
(
IS_ERR
(
page
))
if
(
IS_ERR
(
page
))
return
PTR_ERR
(
page
);
return
PTR_ERR
(
page
);
di
=
kmap_atomic
(
page
,
KM_USER0
);
di
=
kmap_atomic
(
page
);
logfs_disk_to_inode
(
di
,
inode
);
logfs_disk_to_inode
(
di
,
inode
);
kunmap_atomic
(
di
,
KM_USER0
);
kunmap_atomic
(
di
);
move_page_to_inode
(
inode
,
page
);
move_page_to_inode
(
inode
,
page
);
page_cache_release
(
page
);
page_cache_release
(
page
);
return
0
;
return
0
;
...
@@ -1982,9 +1982,9 @@ static struct page *inode_to_page(struct inode *inode)
...
@@ -1982,9 +1982,9 @@ static struct page *inode_to_page(struct inode *inode)
if
(
!
page
)
if
(
!
page
)
return
NULL
;
return
NULL
;
di
=
kmap_atomic
(
page
,
KM_USER0
);
di
=
kmap_atomic
(
page
);
logfs_inode_to_disk
(
inode
,
di
);
logfs_inode_to_disk
(
inode
,
di
);
kunmap_atomic
(
di
,
KM_USER0
);
kunmap_atomic
(
di
);
move_inode_to_page
(
page
,
inode
);
move_inode_to_page
(
page
,
inode
);
return
page
;
return
page
;
}
}
...
@@ -2041,13 +2041,13 @@ static void logfs_mod_segment_entry(struct super_block *sb, u32 segno,
...
@@ -2041,13 +2041,13 @@ static void logfs_mod_segment_entry(struct super_block *sb, u32 segno,
if
(
write
)
if
(
write
)
alloc_indirect_block
(
inode
,
page
,
0
);
alloc_indirect_block
(
inode
,
page
,
0
);
se
=
kmap_atomic
(
page
,
KM_USER0
);
se
=
kmap_atomic
(
page
);
change_se
(
se
+
child_no
,
arg
);
change_se
(
se
+
child_no
,
arg
);
if
(
write
)
{
if
(
write
)
{
logfs_set_alias
(
sb
,
logfs_block
(
page
),
child_no
);
logfs_set_alias
(
sb
,
logfs_block
(
page
),
child_no
);
BUG_ON
((
int
)
be32_to_cpu
(
se
[
child_no
].
valid
)
>
super
->
s_segsize
);
BUG_ON
((
int
)
be32_to_cpu
(
se
[
child_no
].
valid
)
>
super
->
s_segsize
);
}
}
kunmap_atomic
(
se
,
KM_USER0
);
kunmap_atomic
(
se
);
logfs_put_write_page
(
page
);
logfs_put_write_page
(
page
);
}
}
...
@@ -2245,10 +2245,10 @@ int logfs_inode_write(struct inode *inode, const void *buf, size_t count,
...
@@ -2245,10 +2245,10 @@ int logfs_inode_write(struct inode *inode, const void *buf, size_t count,
if
(
!
page
)
if
(
!
page
)
return
-
ENOMEM
;
return
-
ENOMEM
;
pagebuf
=
kmap_atomic
(
page
,
KM_USER0
);
pagebuf
=
kmap_atomic
(
page
);
memcpy
(
pagebuf
,
buf
,
count
);
memcpy
(
pagebuf
,
buf
,
count
);
flush_dcache_page
(
page
);
flush_dcache_page
(
page
);
kunmap_atomic
(
pagebuf
,
KM_USER0
);
kunmap_atomic
(
pagebuf
);
if
(
i_size_read
(
inode
)
<
pos
+
LOGFS_BLOCKSIZE
)
if
(
i_size_read
(
inode
)
<
pos
+
LOGFS_BLOCKSIZE
)
i_size_write
(
inode
,
pos
+
LOGFS_BLOCKSIZE
);
i_size_write
(
inode
,
pos
+
LOGFS_BLOCKSIZE
);
...
...
fs/logfs/segment.c
View file @
50bc9b65
...
@@ -543,9 +543,9 @@ void move_page_to_btree(struct page *page)
...
@@ -543,9 +543,9 @@ void move_page_to_btree(struct page *page)
BUG_ON
(
!
item
);
/* mempool empty */
BUG_ON
(
!
item
);
/* mempool empty */
memset
(
item
,
0
,
sizeof
(
*
item
));
memset
(
item
,
0
,
sizeof
(
*
item
));
child
=
kmap_atomic
(
page
,
KM_USER0
);
child
=
kmap_atomic
(
page
);
item
->
val
=
child
[
pos
];
item
->
val
=
child
[
pos
];
kunmap_atomic
(
child
,
KM_USER0
);
kunmap_atomic
(
child
);
item
->
child_no
=
pos
;
item
->
child_no
=
pos
;
list_add
(
&
item
->
list
,
&
block
->
item_list
);
list_add
(
&
item
->
list
,
&
block
->
item_list
);
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment