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
203bc643
Commit
203bc643
authored
May 11, 2015
by
Al Viro
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
update Documentation/filesystems/ regarding the follow_link/put_link changes
Signed-off-by:
Al Viro
<
viro@zeniv.linux.org.uk
>
parent
8f47a016
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
27 additions
and
8 deletions
+27
-8
Documentation/filesystems/porting
Documentation/filesystems/porting
+17
-0
Documentation/filesystems/vfs.txt
Documentation/filesystems/vfs.txt
+10
-8
No files found.
Documentation/filesystems/porting
View file @
203bc643
...
@@ -483,3 +483,20 @@ in your dentry operations instead.
...
@@ -483,3 +483,20 @@ in your dentry operations instead.
--
--
[mandatory]
[mandatory]
->aio_read/->aio_write are gone. Use ->read_iter/->write_iter.
->aio_read/->aio_write are gone. Use ->read_iter/->write_iter.
---
[recommended]
for embedded ("fast") symlinks just set inode->i_link to wherever the
symlink body is and use simple_follow_link() as ->follow_link().
--
[mandatory]
calling conventions for ->follow_link() have changed. Instead of returning
cookie and using nd_set_link() to store the body to traverse, we return
the body to traverse and store the cookie using explicit void ** argument.
nameidata isn't passed at all - nd_jump_link() doesn't need it and
nd_[gs]et_link() is gone.
--
[mandatory]
calling conventions for ->put_link() have changed. It gets inode instead of
dentry, it does not get nameidata at all and it gets called only when cookie
is non-NULL. Note that link body isn't available anymore, so if you need it,
store it as cookie.
Documentation/filesystems/vfs.txt
View file @
203bc643
...
@@ -436,16 +436,18 @@ otherwise noted.
...
@@ -436,16 +436,18 @@ otherwise noted.
follow_link: called by the VFS to follow a symbolic link to the
follow_link: called by the VFS to follow a symbolic link to the
inode it points to. Only required if you want to support
inode it points to. Only required if you want to support
symbolic links. This method returns a void pointer cookie
symbolic links. This method returns the symlink body
that is passed to put_link().
to traverse (and possibly resets the current position with
nd_jump_link()). If the body won't go away until the inode
is gone, nothing else is needed; if it needs to be otherwise
pinned, the data needed to release whatever we'd grabbed
is to be stored in void * variable passed by address to
follow_link() instance.
put_link: called by the VFS to release resources allocated by
put_link: called by the VFS to release resources allocated by
follow_link(). The cookie returned by follow_link() is passed
follow_link(). The cookie stored by follow_link() is passed
to this method as the last parameter. It is used by
to this method as the last parameter; only called when
filesystems such as NFS where page cache is not stable
cookie isn't NULL.
(i.e. page that was installed when the symbolic link walk
started might not be in the page cache at the end of the
walk).
permission: called by the VFS to check for access rights on a POSIX-like
permission: called by the VFS to check for access rights on a POSIX-like
filesystem.
filesystem.
...
...
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