d_add(path.dentry, inode);
 
        file = alloc_file(&path, FMODE_READ, &pfm_file_ops);
-       if (!file) {
+       if (IS_ERR(file)) {
                path_put(&path);
-               return ERR_PTR(-ENFILE);
+               return file;
        }
 
        file->f_flags = O_RDONLY;
 
        struct qstr this;
        struct path path;
        struct file *file;
-       int error;
 
        if (IS_ERR(anon_inode_inode))
                return ERR_PTR(-ENODEV);
         * Link the inode to a directory entry by creating a unique name
         * using the inode sequence number.
         */
-       error = -ENOMEM;
+       file = ERR_PTR(-ENOMEM);
        this.name = name;
        this.len = strlen(name);
        this.hash = 0;
 
        d_instantiate(path.dentry, anon_inode_inode);
 
-       error = -ENFILE;
        file = alloc_file(&path, OPEN_FMODE(flags), fops);
-       if (!file)
+       if (IS_ERR(file))
                goto err_dput;
        file->f_mapping = anon_inode_inode->i_mapping;
 
        path_put(&path);
 err_module:
        module_put(fops->owner);
-       return ERR_PTR(error);
+       return file;
 }
 EXPORT_SYMBOL_GPL(anon_inode_getfile);
 
 
 
        file = get_empty_filp();
        if (IS_ERR(file))
-               return NULL;
+               return file;
 
        file->f_path = *path;
        file->f_mapping = path->dentry->d_inode->i_mapping;
 
                                struct user_struct **user,
                                int creat_flags, int page_size_log)
 {
-       int error = -ENOMEM;
-       struct file *file;
+       struct file *file = ERR_PTR(-ENOMEM);
        struct inode *inode;
        struct path path;
        struct dentry *root;
                goto out_shm_unlock;
 
        path.mnt = mntget(hugetlbfs_vfsmount[hstate_idx]);
-       error = -ENOSPC;
+       file = ERR_PTR(-ENOSPC);
        inode = hugetlbfs_get_inode(root->d_sb, NULL, S_IFREG | S_IRWXUGO, 0);
        if (!inode)
                goto out_dentry;
        size += addr & ~huge_page_mask(hstate);
        num_pages = ALIGN(size, huge_page_size(hstate)) >>
                        huge_page_shift(hstate);
-       error = -ENOMEM;
+       file = ERR_PTR(-ENOMEM);
        if (hugetlb_reserve_pages(inode, 0, num_pages, NULL, acctflag))
                goto out_inode;
 
        inode->i_size = size;
        clear_nlink(inode);
 
-       error = -ENFILE;
        file = alloc_file(&path, FMODE_WRITE | FMODE_READ,
                        &hugetlbfs_file_operations);
-       if (!file)
+       if (IS_ERR(file))
                goto out_dentry; /* inode is already attached */
 
        return file;
                user_shm_unlock(size, *user);
                *user = NULL;
        }
-       return ERR_PTR(error);
+       return file;
 }
 
 static int __init init_hugetlbfs_fs(void)
 
 
        err = -ENFILE;
        f = alloc_file(&path, FMODE_WRITE, &write_pipefifo_fops);
-       if (!f)
+       if (IS_ERR(f))
                goto err_dentry;
 
        f->f_flags = O_WRONLY | (flags & (O_NONBLOCK | O_DIRECT));
 
        res[0] = alloc_file(&path, FMODE_READ, &read_pipefifo_fops);
-       if (!res[0])
+       if (IS_ERR(res[0]))
                goto err_file;
 
        path_get(&path);
 
                          is_file_hugepages(shp->shm_file) ?
                                &shm_file_operations_huge :
                                &shm_file_operations);
-       if (!file)
+       err = PTR_ERR(file);
+       if (IS_ERR(file))
                goto out_free;
 
        file->private_data = sfd;
 
                goto put_dentry;
 #endif
 
-       error = -ENFILE;
        file = alloc_file(&path, FMODE_WRITE | FMODE_READ,
                  &shmem_file_operations);
-       if (!file)
+       error = PTR_ERR(file);
+       if (IS_ERR(file))
                goto put_dentry;
 
        return file;
 
 
        file = alloc_file(&path, FMODE_READ | FMODE_WRITE,
                  &socket_file_ops);
-       if (unlikely(!file)) {
+       if (unlikely(IS_ERR(file))) {
                /* drop dentry, keep inode */
                ihold(path.dentry->d_inode);
                path_put(&path);
-               return ERR_PTR(-ENFILE);
+               return file;
        }
 
        sock->file = file;