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
2de5f059
Commit
2de5f059
authored
May 22, 2013
by
Al Viro
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[readdir] convert ecryptfs
Signed-off-by:
Al Viro
<
viro@zeniv.linux.org.uk
>
parent
e924f251
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
15 additions
and
20 deletions
+15
-20
fs/ecryptfs/file.c
fs/ecryptfs/file.c
+15
-20
No files found.
fs/ecryptfs/file.c
View file @
2de5f059
...
...
@@ -69,9 +69,8 @@ static ssize_t ecryptfs_read_update_atime(struct kiocb *iocb,
struct
ecryptfs_getdents_callback
{
struct
dir_context
ctx
;
void
*
dirent
;
struct
dir_context
*
caller
;
struct
dentry
*
dentry
;
filldir_t
filldir
;
int
filldir_called
;
int
entries_written
;
};
...
...
@@ -97,9 +96,10 @@ ecryptfs_filldir(void *dirent, const char *lower_name, int lower_namelen,
rc
);
goto
out
;
}
rc
=
buf
->
filldir
(
buf
->
dirent
,
name
,
name_size
,
offset
,
ino
,
d_type
);
buf
->
caller
->
pos
=
buf
->
ctx
.
pos
;
rc
=
!
dir_emit
(
buf
->
caller
,
name
,
name_size
,
ino
,
d_type
);
kfree
(
name
);
if
(
rc
>=
0
)
if
(
!
rc
)
buf
->
entries_written
++
;
out:
return
rc
;
...
...
@@ -108,28 +108,23 @@ ecryptfs_filldir(void *dirent, const char *lower_name, int lower_namelen,
/**
* ecryptfs_readdir
* @file: The eCryptfs directory file
* @dirent: Directory entry handle
* @filldir: The filldir callback function
* @ctx: The actor to feed the entries to
*/
static
int
ecryptfs_readdir
(
struct
file
*
file
,
void
*
dirent
,
filldir_t
filldir
)
static
int
ecryptfs_readdir
(
struct
file
*
file
,
struct
dir_context
*
ctx
)
{
int
rc
;
struct
file
*
lower_file
;
struct
inode
*
inode
;
struct
ecryptfs_getdents_callback
buf
;
struct
ecryptfs_getdents_callback
buf
=
{
.
ctx
.
actor
=
ecryptfs_filldir
,
.
caller
=
ctx
,
.
dentry
=
file
->
f_path
.
dentry
};
lower_file
=
ecryptfs_file_to_lower
(
file
);
lower_file
->
f_pos
=
file
->
f_
pos
;
lower_file
->
f_pos
=
ctx
->
pos
;
inode
=
file_inode
(
file
);
memset
(
&
buf
,
0
,
sizeof
(
buf
));
buf
.
dirent
=
dirent
;
buf
.
dentry
=
file
->
f_path
.
dentry
;
buf
.
filldir
=
filldir
;
buf
.
filldir_called
=
0
;
buf
.
entries_written
=
0
;
buf
.
ctx
.
actor
=
ecryptfs_filldir
;
rc
=
iterate_dir
(
lower_file
,
&
buf
.
ctx
);
file
->
f_pos
=
lower_file
->
f_
pos
;
ctx
->
pos
=
buf
.
ctx
.
pos
;
if
(
rc
<
0
)
goto
out
;
if
(
buf
.
filldir_called
&&
!
buf
.
entries_written
)
...
...
@@ -346,7 +341,7 @@ ecryptfs_compat_ioctl(struct file *file, unsigned int cmd, unsigned long arg)
#endif
const
struct
file_operations
ecryptfs_dir_fops
=
{
.
readdir
=
ecryptfs_readdir
,
.
iterate
=
ecryptfs_readdir
,
.
read
=
generic_read_dir
,
.
unlocked_ioctl
=
ecryptfs_unlocked_ioctl
,
#ifdef CONFIG_COMPAT
...
...
@@ -367,7 +362,7 @@ const struct file_operations ecryptfs_main_fops = {
.
aio_read
=
ecryptfs_read_update_atime
,
.
write
=
do_sync_write
,
.
aio_write
=
generic_file_aio_write
,
.
readdir
=
ecryptfs_readdir
,
.
iterate
=
ecryptfs_readdir
,
.
unlocked_ioctl
=
ecryptfs_unlocked_ioctl
,
#ifdef CONFIG_COMPAT
.
compat_ioctl
=
ecryptfs_compat_ioctl
,
...
...
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