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
Kirill Smelkov
linux
Commits
b8227554
Commit
b8227554
authored
May 22, 2013
by
Al Viro
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[readdir] convert xfs
Signed-off-by:
Al Viro
<
viro@zeniv.linux.org.uk
>
parent
9cdda8d3
Changes
7
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
44 additions
and
61 deletions
+44
-61
fs/xfs/xfs_dir2.c
fs/xfs/xfs_dir2.c
+5
-8
fs/xfs/xfs_dir2_block.c
fs/xfs/xfs_dir2_block.c
+7
-10
fs/xfs/xfs_dir2_leaf.c
fs/xfs/xfs_dir2_leaf.c
+8
-10
fs/xfs/xfs_dir2_priv.h
fs/xfs/xfs_dir2_priv.h
+5
-6
fs/xfs/xfs_dir2_sf.c
fs/xfs/xfs_dir2_sf.c
+13
-18
fs/xfs/xfs_file.c
fs/xfs/xfs_file.c
+5
-7
fs/xfs/xfs_vnodeops.h
fs/xfs/xfs_vnodeops.h
+1
-2
No files found.
fs/xfs/xfs_dir2.c
View file @
b8227554
...
...
@@ -368,10 +368,8 @@ xfs_dir_removename(
int
xfs_readdir
(
xfs_inode_t
*
dp
,
void
*
dirent
,
size_t
bufsize
,
xfs_off_t
*
offset
,
filldir_t
filldir
)
struct
dir_context
*
ctx
,
size_t
bufsize
)
{
int
rval
;
/* return value */
int
v
;
/* type-checking value */
...
...
@@ -385,14 +383,13 @@ xfs_readdir(
XFS_STATS_INC
(
xs_dir_getdents
);
if
(
dp
->
i_d
.
di_format
==
XFS_DINODE_FMT_LOCAL
)
rval
=
xfs_dir2_sf_getdents
(
dp
,
dirent
,
offset
,
filldir
);
rval
=
xfs_dir2_sf_getdents
(
dp
,
ctx
);
else
if
((
rval
=
xfs_dir2_isblock
(
NULL
,
dp
,
&
v
)))
;
else
if
(
v
)
rval
=
xfs_dir2_block_getdents
(
dp
,
dirent
,
offset
,
filldir
);
rval
=
xfs_dir2_block_getdents
(
dp
,
ctx
);
else
rval
=
xfs_dir2_leaf_getdents
(
dp
,
dirent
,
bufsize
,
offset
,
filldir
);
rval
=
xfs_dir2_leaf_getdents
(
dp
,
ctx
,
bufsize
);
return
rval
;
}
...
...
fs/xfs/xfs_dir2_block.c
View file @
b8227554
...
...
@@ -569,9 +569,7 @@ xfs_dir2_block_addname(
int
/* error */
xfs_dir2_block_getdents
(
xfs_inode_t
*
dp
,
/* incore inode */
void
*
dirent
,
xfs_off_t
*
offset
,
filldir_t
filldir
)
struct
dir_context
*
ctx
)
{
xfs_dir2_data_hdr_t
*
hdr
;
/* block header */
struct
xfs_buf
*
bp
;
/* buffer for block */
...
...
@@ -589,7 +587,7 @@ xfs_dir2_block_getdents(
/*
* If the block number in the offset is out of range, we're done.
*/
if
(
xfs_dir2_dataptr_to_db
(
mp
,
*
offset
)
>
mp
->
m_dirdatablk
)
if
(
xfs_dir2_dataptr_to_db
(
mp
,
ctx
->
pos
)
>
mp
->
m_dirdatablk
)
return
0
;
error
=
xfs_dir3_block_read
(
NULL
,
dp
,
&
bp
);
...
...
@@ -600,7 +598,7 @@ xfs_dir2_block_getdents(
* Extract the byte offset we start at from the seek pointer.
* We'll skip entries before this.
*/
wantoff
=
xfs_dir2_dataptr_to_off
(
mp
,
*
offset
);
wantoff
=
xfs_dir2_dataptr_to_off
(
mp
,
ctx
->
pos
);
hdr
=
bp
->
b_addr
;
xfs_dir3_data_check
(
dp
,
bp
);
/*
...
...
@@ -639,13 +637,12 @@ xfs_dir2_block_getdents(
cook
=
xfs_dir2_db_off_to_dataptr
(
mp
,
mp
->
m_dirdatablk
,
(
char
*
)
dep
-
(
char
*
)
hdr
);
ctx
->
pos
=
cook
&
0x7fffffff
;
/*
* If it didn't fit, set the final offset to here & return.
*/
if
(
filldir
(
dirent
,
(
char
*
)
dep
->
name
,
dep
->
namelen
,
cook
&
0x7fffffff
,
be64_to_cpu
(
dep
->
inumber
),
DT_UNKNOWN
))
{
*
offset
=
cook
&
0x7fffffff
;
if
(
!
dir_emit
(
ctx
,
(
char
*
)
dep
->
name
,
dep
->
namelen
,
be64_to_cpu
(
dep
->
inumber
),
DT_UNKNOWN
))
{
xfs_trans_brelse
(
NULL
,
bp
);
return
0
;
}
...
...
@@ -655,7 +652,7 @@ xfs_dir2_block_getdents(
* Reached the end of the block.
* Set the offset to a non-existent block 1 and return.
*/
*
offset
=
xfs_dir2_db_off_to_dataptr
(
mp
,
mp
->
m_dirdatablk
+
1
,
0
)
&
ctx
->
pos
=
xfs_dir2_db_off_to_dataptr
(
mp
,
mp
->
m_dirdatablk
+
1
,
0
)
&
0x7fffffff
;
xfs_trans_brelse
(
NULL
,
bp
);
return
0
;
...
...
fs/xfs/xfs_dir2_leaf.c
View file @
b8227554
...
...
@@ -1300,10 +1300,8 @@ xfs_dir2_leaf_readbuf(
int
/* error */
xfs_dir2_leaf_getdents
(
xfs_inode_t
*
dp
,
/* incore directory inode */
void
*
dirent
,
size_t
bufsize
,
xfs_off_t
*
offset
,
filldir_t
filldir
)
struct
dir_context
*
ctx
,
size_t
bufsize
)
{
struct
xfs_buf
*
bp
=
NULL
;
/* data block buffer */
xfs_dir2_data_hdr_t
*
hdr
;
/* data block header */
...
...
@@ -1322,7 +1320,7 @@ xfs_dir2_leaf_getdents(
* If the offset is at or past the largest allowed value,
* give up right away.
*/
if
(
*
offset
>=
XFS_DIR2_MAX_DATAPTR
)
if
(
ctx
->
pos
>=
XFS_DIR2_MAX_DATAPTR
)
return
0
;
mp
=
dp
->
i_mount
;
...
...
@@ -1343,7 +1341,7 @@ xfs_dir2_leaf_getdents(
* Inside the loop we keep the main offset value as a byte offset
* in the directory file.
*/
curoff
=
xfs_dir2_dataptr_to_byte
(
mp
,
*
offset
);
curoff
=
xfs_dir2_dataptr_to_byte
(
mp
,
ctx
->
pos
);
/*
* Force this conversion through db so we truncate the offset
...
...
@@ -1444,8 +1442,8 @@ xfs_dir2_leaf_getdents(
dep
=
(
xfs_dir2_data_entry_t
*
)
ptr
;
length
=
xfs_dir2_data_entsize
(
dep
->
namelen
);
if
(
filldir
(
dirent
,
(
char
*
)
dep
->
name
,
dep
->
namelen
,
xfs_dir2_byte_to_dataptr
(
mp
,
curoff
)
&
0x7fffffff
,
ctx
->
pos
=
xfs_dir2_byte_to_dataptr
(
mp
,
curoff
)
&
0x7fffffff
;
if
(
!
dir_emit
(
ctx
,
(
char
*
)
dep
->
name
,
dep
->
namelen
,
be64_to_cpu
(
dep
->
inumber
),
DT_UNKNOWN
))
break
;
...
...
@@ -1462,9 +1460,9 @@ xfs_dir2_leaf_getdents(
* All done. Set output offset value to current offset.
*/
if
(
curoff
>
xfs_dir2_dataptr_to_byte
(
mp
,
XFS_DIR2_MAX_DATAPTR
))
*
offset
=
XFS_DIR2_MAX_DATAPTR
&
0x7fffffff
;
ctx
->
pos
=
XFS_DIR2_MAX_DATAPTR
&
0x7fffffff
;
else
*
offset
=
xfs_dir2_byte_to_dataptr
(
mp
,
curoff
)
&
0x7fffffff
;
ctx
->
pos
=
xfs_dir2_byte_to_dataptr
(
mp
,
curoff
)
&
0x7fffffff
;
kmem_free
(
map_info
);
if
(
bp
)
xfs_trans_brelse
(
NULL
,
bp
);
...
...
fs/xfs/xfs_dir2_priv.h
View file @
b8227554
...
...
@@ -33,8 +33,8 @@ extern int xfs_dir_cilookup_result(struct xfs_da_args *args,
extern
const
struct
xfs_buf_ops
xfs_dir3_block_buf_ops
;
extern
int
xfs_dir2_block_addname
(
struct
xfs_da_args
*
args
);
extern
int
xfs_dir2_block_getdents
(
struct
xfs_inode
*
dp
,
void
*
dirent
,
xfs_off_t
*
offset
,
filldir_t
filldir
);
extern
int
xfs_dir2_block_getdents
(
struct
xfs_inode
*
dp
,
struct
dir_context
*
ctx
);
extern
int
xfs_dir2_block_lookup
(
struct
xfs_da_args
*
args
);
extern
int
xfs_dir2_block_removename
(
struct
xfs_da_args
*
args
);
extern
int
xfs_dir2_block_replace
(
struct
xfs_da_args
*
args
);
...
...
@@ -91,8 +91,8 @@ extern void xfs_dir3_leaf_compact(struct xfs_da_args *args,
extern
void
xfs_dir3_leaf_compact_x1
(
struct
xfs_dir3_icleaf_hdr
*
leafhdr
,
struct
xfs_dir2_leaf_entry
*
ents
,
int
*
indexp
,
int
*
lowstalep
,
int
*
highstalep
,
int
*
lowlogp
,
int
*
highlogp
);
extern
int
xfs_dir2_leaf_getdents
(
struct
xfs_inode
*
dp
,
void
*
dirent
,
size_t
bufsize
,
xfs_off_t
*
offset
,
filldir_t
filldir
);
extern
int
xfs_dir2_leaf_getdents
(
struct
xfs_inode
*
dp
,
struct
dir_context
*
ctx
,
size_t
bufsize
);
extern
int
xfs_dir3_leaf_get_buf
(
struct
xfs_da_args
*
args
,
xfs_dir2_db_t
bno
,
struct
xfs_buf
**
bpp
,
__uint16_t
magic
);
extern
void
xfs_dir3_leaf_log_ents
(
struct
xfs_trans
*
tp
,
struct
xfs_buf
*
bp
,
...
...
@@ -153,8 +153,7 @@ extern int xfs_dir2_block_to_sf(struct xfs_da_args *args, struct xfs_buf *bp,
int
size
,
xfs_dir2_sf_hdr_t
*
sfhp
);
extern
int
xfs_dir2_sf_addname
(
struct
xfs_da_args
*
args
);
extern
int
xfs_dir2_sf_create
(
struct
xfs_da_args
*
args
,
xfs_ino_t
pino
);
extern
int
xfs_dir2_sf_getdents
(
struct
xfs_inode
*
dp
,
void
*
dirent
,
xfs_off_t
*
offset
,
filldir_t
filldir
);
extern
int
xfs_dir2_sf_getdents
(
struct
xfs_inode
*
dp
,
struct
dir_context
*
ctx
);
extern
int
xfs_dir2_sf_lookup
(
struct
xfs_da_args
*
args
);
extern
int
xfs_dir2_sf_removename
(
struct
xfs_da_args
*
args
);
extern
int
xfs_dir2_sf_replace
(
struct
xfs_da_args
*
args
);
...
...
fs/xfs/xfs_dir2_sf.c
View file @
b8227554
...
...
@@ -768,9 +768,7 @@ xfs_dir2_sf_create(
int
/* error */
xfs_dir2_sf_getdents
(
xfs_inode_t
*
dp
,
/* incore directory inode */
void
*
dirent
,
xfs_off_t
*
offset
,
filldir_t
filldir
)
struct
dir_context
*
ctx
)
{
int
i
;
/* shortform entry number */
xfs_mount_t
*
mp
;
/* filesystem mount point */
...
...
@@ -802,7 +800,7 @@ xfs_dir2_sf_getdents(
/*
* If the block number in the offset is out of range, we're done.
*/
if
(
xfs_dir2_dataptr_to_db
(
mp
,
*
offset
)
>
mp
->
m_dirdatablk
)
if
(
xfs_dir2_dataptr_to_db
(
mp
,
ctx
->
pos
)
>
mp
->
m_dirdatablk
)
return
0
;
/*
...
...
@@ -819,23 +817,21 @@ xfs_dir2_sf_getdents(
/*
* Put . entry unless we're starting past it.
*/
if
(
*
offset
<=
dot_offset
)
{
if
(
filldir
(
dirent
,
"."
,
1
,
dot_offset
&
0x7fffffff
,
dp
->
i_ino
,
DT_DIR
))
{
*
offset
=
dot_offset
&
0x7fffffff
;
if
(
ctx
->
pos
<=
dot_offset
)
{
ctx
->
pos
=
dot_offset
&
0x7fffffff
;
if
(
!
dir_emit
(
ctx
,
"."
,
1
,
dp
->
i_ino
,
DT_DIR
))
return
0
;
}
}
/*
* Put .. entry unless we're starting past it.
*/
if
(
*
offset
<=
dotdot_offset
)
{
if
(
ctx
->
pos
<=
dotdot_offset
)
{
ino
=
xfs_dir2_sf_get_parent_ino
(
sfp
);
if
(
filldir
(
dirent
,
".."
,
2
,
dotdot_offset
&
0x7fffffff
,
ino
,
DT_DIR
))
{
*
offset
=
dotdot_offset
&
0x7fffffff
;
ctx
->
pos
=
dotdot_offset
&
0x7fffffff
;
if
(
!
dir_emit
(
ctx
,
".."
,
2
,
ino
,
DT_DIR
))
return
0
;
}
}
/*
* Loop while there are more entries and put'ing works.
...
...
@@ -845,21 +841,20 @@ xfs_dir2_sf_getdents(
off
=
xfs_dir2_db_off_to_dataptr
(
mp
,
mp
->
m_dirdatablk
,
xfs_dir2_sf_get_offset
(
sfep
));
if
(
*
offset
>
off
)
{
if
(
ctx
->
pos
>
off
)
{
sfep
=
xfs_dir2_sf_nextentry
(
sfp
,
sfep
);
continue
;
}
ino
=
xfs_dir2_sfe_get_ino
(
sfp
,
sfep
);
if
(
filldir
(
dirent
,
(
char
*
)
sfep
->
name
,
sfep
->
namelen
,
off
&
0x7fffffff
,
ino
,
DT_UNKNOWN
))
{
*
offset
=
off
&
0x7fffffff
;
ctx
->
pos
=
off
&
0x7fffffff
;
if
(
!
dir_emit
(
ctx
,
(
char
*
)
sfep
->
name
,
sfep
->
namelen
,
ino
,
DT_UNKNOWN
))
return
0
;
}
sfep
=
xfs_dir2_sf_nextentry
(
sfp
,
sfep
);
}
*
offset
=
xfs_dir2_db_off_to_dataptr
(
mp
,
mp
->
m_dirdatablk
+
1
,
0
)
&
ctx
->
pos
=
xfs_dir2_db_off_to_dataptr
(
mp
,
mp
->
m_dirdatablk
+
1
,
0
)
&
0x7fffffff
;
return
0
;
}
...
...
fs/xfs/xfs_file.c
View file @
b8227554
...
...
@@ -906,11 +906,10 @@ xfs_file_release(
STATIC
int
xfs_file_readdir
(
struct
file
*
filp
,
void
*
dirent
,
filldir_t
filldir
)
struct
file
*
file
,
struct
dir_context
*
ctx
)
{
struct
inode
*
inode
=
file_inode
(
fil
p
);
struct
inode
*
inode
=
file_inode
(
fil
e
);
xfs_inode_t
*
ip
=
XFS_I
(
inode
);
int
error
;
size_t
bufsize
;
...
...
@@ -929,8 +928,7 @@ xfs_file_readdir(
*/
bufsize
=
(
size_t
)
min_t
(
loff_t
,
32768
,
ip
->
i_d
.
di_size
);
error
=
xfs_readdir
(
ip
,
dirent
,
bufsize
,
(
xfs_off_t
*
)
&
filp
->
f_pos
,
filldir
);
error
=
xfs_readdir
(
ip
,
ctx
,
bufsize
);
if
(
error
)
return
-
error
;
return
0
;
...
...
@@ -1432,7 +1430,7 @@ const struct file_operations xfs_file_operations = {
const
struct
file_operations
xfs_dir_file_operations
=
{
.
open
=
xfs_dir_open
,
.
read
=
generic_read_dir
,
.
readdir
=
xfs_file_readdir
,
.
iterate
=
xfs_file_readdir
,
.
llseek
=
generic_file_llseek
,
.
unlocked_ioctl
=
xfs_file_ioctl
,
#ifdef CONFIG_COMPAT
...
...
fs/xfs/xfs_vnodeops.h
View file @
b8227554
...
...
@@ -31,8 +31,7 @@ int xfs_remove(struct xfs_inode *dp, struct xfs_name *name,
struct
xfs_inode
*
ip
);
int
xfs_link
(
struct
xfs_inode
*
tdp
,
struct
xfs_inode
*
sip
,
struct
xfs_name
*
target_name
);
int
xfs_readdir
(
struct
xfs_inode
*
dp
,
void
*
dirent
,
size_t
bufsize
,
xfs_off_t
*
offset
,
filldir_t
filldir
);
int
xfs_readdir
(
struct
xfs_inode
*
dp
,
struct
dir_context
*
ctx
,
size_t
bufsize
);
int
xfs_symlink
(
struct
xfs_inode
*
dp
,
struct
xfs_name
*
link_name
,
const
char
*
target_path
,
umode_t
mode
,
struct
xfs_inode
**
ipp
);
int
xfs_set_dmattrs
(
struct
xfs_inode
*
ip
,
u_int
evmask
,
u_int16_t
state
);
...
...
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