X-Git-Url: https://git.camperquake.de/gitweb.cgi?a=blobdiff_plain;f=module%2Fzfs%2Fzpl_file.c;h=c8a3fedb7c8e7ba9719b29f1d760b1854067313d;hb=0d3ac5e7356d29fbb7d2880c0a0c457656355ca0;hp=ed6704bb2066de46b93b644bd790887651d4e035;hpb=7268e1bec8478639b7a1047e02ab931f30bc2f92;p=zfs.git diff --git a/module/zfs/zpl_file.c b/module/zfs/zpl_file.c index ed6704b..c8a3fed 100644 --- a/module/zfs/zpl_file.c +++ b/module/zfs/zpl_file.c @@ -30,16 +30,47 @@ static int +zpl_open(struct inode *ip, struct file *filp) +{ + cred_t *cr = CRED(); + int error; + + crhold(cr); + error = -zfs_open(ip, filp->f_mode, filp->f_flags, cr); + crfree(cr); + ASSERT3S(error, <=, 0); + + if (error) + return (error); + + return generic_file_open(ip, filp); +} + +static int +zpl_release(struct inode *ip, struct file *filp) +{ + cred_t *cr = CRED(); + int error; + + crhold(cr); + error = -zfs_close(ip, filp->f_flags, cr); + crfree(cr); + ASSERT3S(error, <=, 0); + + return (error); +} + +static int zpl_readdir(struct file *filp, void *dirent, filldir_t filldir) { struct dentry *dentry = filp->f_path.dentry; - cred_t *cr; + cred_t *cr = CRED(); int error; - cr = (cred_t *)get_current_cred(); + crhold(cr); error = -zfs_readdir(dentry->d_inode, dirent, filldir, &filp->f_pos, cr); - put_cred(cr); + crfree(cr); ASSERT3S(error, <=, 0); return (error); @@ -47,12 +78,12 @@ zpl_readdir(struct file *filp, void *dirent, filldir_t filldir) ZPL_FSYNC_PROTO(zpl_fsync, filp, unused_dentry, datasync) { - cred_t *cr; + cred_t *cr = CRED(); int error; - cr = (cred_t *)get_current_cred(); + crhold(cr); error = -zfs_fsync(filp->f_path.dentry->d_inode, datasync, cr); - put_cred(cr); + crfree(cr); ASSERT3S(error, <=, 0); return (error); @@ -86,13 +117,13 @@ zpl_read_common(struct inode *ip, const char *buf, size_t len, loff_t pos, static ssize_t zpl_read(struct file *filp, char __user *buf, size_t len, loff_t *ppos) { - cred_t *cr; + cred_t *cr = CRED(); ssize_t read; - cr = (cred_t *)get_current_cred(); + crhold(cr); read = zpl_read_common(filp->f_mapping->host, buf, len, *ppos, UIO_USERSPACE, filp->f_flags, cr); - put_cred(cr); + crfree(cr); if (read < 0) return (read); @@ -129,13 +160,13 @@ zpl_write_common(struct inode *ip, const char *buf, size_t len, loff_t pos, static ssize_t zpl_write(struct file *filp, const char __user *buf, size_t len, loff_t *ppos) { - cred_t *cr; + cred_t *cr = CRED(); ssize_t wrote; - cr = (cred_t *)get_current_cred(); + crhold(cr); wrote = zpl_write_common(filp->f_mapping->host, buf, len, *ppos, UIO_USERSPACE, filp->f_flags, cr); - put_cred(cr); + crfree(cr); if (wrote < 0) return (wrote); @@ -219,7 +250,7 @@ zpl_readpage(struct file *filp, struct page *pp) struct inode *ip; loff_t off, i_size; size_t len, wrote; - cred_t *cr; + cred_t *cr = CRED(); void *pb; int error = 0; @@ -229,7 +260,7 @@ zpl_readpage(struct file *filp, struct page *pp) i_size = i_size_read(ip); ASSERT3S(off, <, i_size); - cr = (cred_t *)get_current_cred(); + crhold(cr); len = MIN(PAGE_CACHE_SIZE, i_size - off); pb = kmap(pp); @@ -243,7 +274,7 @@ zpl_readpage(struct file *filp, struct page *pp) memset(pb + len, 0, PAGE_CACHE_SIZE - len); kunmap(pp); - put_cred(cr); + crfree(cr); if (error) { SetPageError(pp); @@ -275,7 +306,7 @@ zpl_writepage(struct page *pp, struct writeback_control *wbc) struct inode *ip; loff_t off, i_size; size_t len, read; - cred_t *cr; + cred_t *cr = CRED(); void *pb; int error = 0; @@ -284,7 +315,7 @@ zpl_writepage(struct page *pp, struct writeback_control *wbc) off = page_offset(pp); i_size = i_size_read(ip); - cr = (cred_t *)get_current_cred(); + crhold(cr); len = MIN(PAGE_CACHE_SIZE, i_size - off); pb = kmap(pp); @@ -295,7 +326,7 @@ zpl_writepage(struct page *pp, struct writeback_control *wbc) error = -EIO; kunmap(pp); - put_cred(cr); + crfree(cr); if (error) { SetPageError(pp); @@ -316,7 +347,8 @@ const struct address_space_operations zpl_address_space_operations = { }; const struct file_operations zpl_file_operations = { - .open = generic_file_open, + .open = zpl_open, + .release = zpl_release, .llseek = generic_file_llseek, .read = zpl_read, .write = zpl_write,