diff options
Diffstat (limited to 'fs/hugetlbfs/inode.c')
| -rw-r--r-- | fs/hugetlbfs/inode.c | 56 | 
1 files changed, 18 insertions, 38 deletions
| diff --git a/fs/hugetlbfs/inode.c b/fs/hugetlbfs/inode.c index d508c7844681..346a146c7617 100644 --- a/fs/hugetlbfs/inode.c +++ b/fs/hugetlbfs/inode.c @@ -411,6 +411,7 @@ static void remove_inode_hugepages(struct inode *inode, loff_t lstart,  	bool truncate_op = (lend == LLONG_MAX);  	memset(&pseudo_vma, 0, sizeof(struct vm_area_struct)); +	vma_init(&pseudo_vma, current->mm);  	pseudo_vma.vm_flags = (VM_HUGETLB | VM_MAYSHARE | VM_SHARED);  	pagevec_init(&pvec);  	next = start; @@ -595,6 +596,7 @@ static long hugetlbfs_fallocate(struct file *file, int mode, loff_t offset,  	 * as input to create an allocation policy.  	 */  	memset(&pseudo_vma, 0, sizeof(struct vm_area_struct)); +	vma_init(&pseudo_vma, mm);  	pseudo_vma.vm_flags = (VM_HUGETLB | VM_MAYSHARE | VM_SHARED);  	pseudo_vma.vm_file = file; @@ -1308,10 +1310,6 @@ static int get_hstate_idx(int page_size_log)  	return h - hstates;  } -static const struct dentry_operations anon_ops = { -	.d_dname = simple_dname -}; -  /*   * Note that size should be aligned to proper hugepage size in caller side,   * otherwise hugetlb_reserve_pages reserves one less hugepages than intended. @@ -1320,19 +1318,18 @@ struct file *hugetlb_file_setup(const char *name, size_t size,  				vm_flags_t acctflag, struct user_struct **user,  				int creat_flags, int page_size_log)  { -	struct file *file = ERR_PTR(-ENOMEM);  	struct inode *inode; -	struct path path; -	struct super_block *sb; -	struct qstr quick_string; +	struct vfsmount *mnt;  	int hstate_idx; +	struct file *file;  	hstate_idx = get_hstate_idx(page_size_log);  	if (hstate_idx < 0)  		return ERR_PTR(-ENODEV);  	*user = NULL; -	if (!hugetlbfs_vfsmount[hstate_idx]) +	mnt = hugetlbfs_vfsmount[hstate_idx]; +	if (!mnt)  		return ERR_PTR(-ENOENT);  	if (creat_flags == HUGETLB_SHMFS_INODE && !can_do_hugetlb_shm()) { @@ -1348,45 +1345,28 @@ struct file *hugetlb_file_setup(const char *name, size_t size,  		}  	} -	sb = hugetlbfs_vfsmount[hstate_idx]->mnt_sb; -	quick_string.name = name; -	quick_string.len = strlen(quick_string.name); -	quick_string.hash = 0; -	path.dentry = d_alloc_pseudo(sb, &quick_string); -	if (!path.dentry) -		goto out_shm_unlock; - -	d_set_d_op(path.dentry, &anon_ops); -	path.mnt = mntget(hugetlbfs_vfsmount[hstate_idx]);  	file = ERR_PTR(-ENOSPC); -	inode = hugetlbfs_get_inode(sb, NULL, S_IFREG | S_IRWXUGO, 0); +	inode = hugetlbfs_get_inode(mnt->mnt_sb, NULL, S_IFREG | S_IRWXUGO, 0);  	if (!inode) -		goto out_dentry; +		goto out;  	if (creat_flags == HUGETLB_SHMFS_INODE)  		inode->i_flags |= S_PRIVATE; -	file = ERR_PTR(-ENOMEM); -	if (hugetlb_reserve_pages(inode, 0, -			size >> huge_page_shift(hstate_inode(inode)), NULL, -			acctflag)) -		goto out_inode; - -	d_instantiate(path.dentry, inode);  	inode->i_size = size;  	clear_nlink(inode); -	file = alloc_file(&path, FMODE_WRITE | FMODE_READ, -			&hugetlbfs_file_operations); -	if (IS_ERR(file)) -		goto out_dentry; /* inode is already attached */ - -	return file; +	if (hugetlb_reserve_pages(inode, 0, +			size >> huge_page_shift(hstate_inode(inode)), NULL, +			acctflag)) +		file = ERR_PTR(-ENOMEM); +	else +		file = alloc_file_pseudo(inode, mnt, name, O_RDWR, +					&hugetlbfs_file_operations); +	if (!IS_ERR(file)) +		return file; -out_inode:  	iput(inode); -out_dentry: -	path_put(&path); -out_shm_unlock: +out:  	if (*user) {  		user_shm_unlock(size, *user);  		*user = NULL; |