int error;
umode_t mode = S_IFDIR| S_IRWXU | S_IRUGO | S_IXUGO;
struct dentry *p = dentry->d_parent;
+ struct inode *p_inode = d_inode(p);
struct inode *inode;
BUG_ON(!item);
/* directory inodes start off with i_nlink == 2 (for "." entry) */
inc_nlink(inode);
d_make_persistent(dentry, inode);
- inc_nlink(d_inode(p));
+ inc_nlink(p_inode);
+ inode_set_mtime_to_ts(p_inode, inode_set_ctime_current(p_inode));
item->ci_dentry = dentry;
return 0;
int err = 0;
umode_t mode = S_IFLNK | S_IRWXUGO;
struct configfs_dirent *p = parent->d_fsdata;
+ struct inode *p_inode = d_inode(parent);
struct inode *inode;
err = configfs_make_dirent(p, dentry, target, mode, CONFIGFS_ITEM_LINK,
inode->i_link = body;
inode->i_op = &configfs_symlink_inode_operations;
d_make_persistent(dentry, inode);
+ inode_set_mtime_to_ts(p_inode, inode_set_ctime_current(p_inode));
return 0;
out_remove:
{
struct inode *inode = NULL;
struct configfs_dirent *sd;
- struct inode *p_inode;
if (!dentry)
return ERR_PTR(-ENOENT);
if (!inode)
return ERR_PTR(-ENOMEM);
- p_inode = d_inode(dentry->d_parent);
- inode_set_mtime_to_ts(p_inode, inode_set_ctime_current(p_inode));
configfs_set_inode_lock_class(sd, inode);
return inode;
}