struct nameidata *nd)
{
struct inode *inode = dentry->d_inode;
-#ifdef HAVE_VFS_INTENT_PATCHES
- struct lookup_intent *it = ll_nd2it(nd);
-#endif
struct ptlrpc_request *request = NULL;
int rc;
char *symname;
ENTRY;
-#ifdef HAVE_VFS_INTENT_PATCHES
- if (it != NULL) {
- int op = it->it_op;
- int mode = it->it_create_mode;
-
- ll_intent_release(it);
- it->it_op = op;
- it->it_create_mode = mode;
- }
-#endif
-
CDEBUG(D_VFSTRACE, "VFS Op\n");
/* Limit the recursive symlink depth to 5 instead of default
* 8 links when kernel has 4k stack to prevent stack overflow.
GOTO(out, rc);
}
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,8))
- rc = vfs_follow_link(nd, symname);
-#else
#ifdef HAVE_COOKIE_FOLLOW_LINK
nd_set_link(nd, symname);
/* @symname may contain a pointer to the request message buffer,
nd_set_link(nd, symname);
RETURN(0);
#endif
-#endif
out:
ptlrpc_req_finished(request);
#ifdef HAVE_COOKIE_FOLLOW_LINK
struct inode_operations ll_fast_symlink_inode_operations = {
.readlink = ll_readlink,
.setattr = ll_setattr,
-#ifdef HAVE_VFS_INTENT_PATCHES
- .setattr_raw = ll_setattr_raw,
-#endif
.follow_link = ll_follow_link,
#ifdef HAVE_COOKIE_FOLLOW_LINK
.put_link = ll_put_link,