Fix O_APPEND for Linux 3.15 and older kernels
[zfs.git] / module / os / linux / zfs / zpl_inode.c
blob4f79265a085675b49ed3ad133d73e78a409fe650
1 /*
2 * CDDL HEADER START
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
19 * CDDL HEADER END
22 * Copyright (c) 2011, Lawrence Livermore National Security, LLC.
23 * Copyright (c) 2015 by Chunwei Chen. All rights reserved.
27 #include <sys/zfs_ctldir.h>
28 #include <sys/zfs_vfsops.h>
29 #include <sys/zfs_vnops.h>
30 #include <sys/zfs_znode.h>
31 #include <sys/dmu_objset.h>
32 #include <sys/vfs.h>
33 #include <sys/zpl.h>
34 #include <sys/file.h>
37 static struct dentry *
38 zpl_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
40 cred_t *cr = CRED();
41 struct inode *ip;
42 znode_t *zp;
43 int error;
44 fstrans_cookie_t cookie;
45 pathname_t *ppn = NULL;
46 pathname_t pn;
47 int zfs_flags = 0;
48 zfsvfs_t *zfsvfs = dentry->d_sb->s_fs_info;
50 if (dlen(dentry) >= ZAP_MAXNAMELEN)
51 return (ERR_PTR(-ENAMETOOLONG));
53 crhold(cr);
54 cookie = spl_fstrans_mark();
56 /* If we are a case insensitive fs, we need the real name */
57 if (zfsvfs->z_case == ZFS_CASE_INSENSITIVE) {
58 zfs_flags = FIGNORECASE;
59 pn_alloc(&pn);
60 ppn = &pn;
63 error = -zfs_lookup(ITOZ(dir), dname(dentry), &zp,
64 zfs_flags, cr, NULL, ppn);
65 spl_fstrans_unmark(cookie);
66 ASSERT3S(error, <=, 0);
67 crfree(cr);
69 spin_lock(&dentry->d_lock);
70 dentry->d_time = jiffies;
71 spin_unlock(&dentry->d_lock);
73 if (error) {
75 * If we have a case sensitive fs, we do not want to
76 * insert negative entries, so return NULL for ENOENT.
77 * Fall through if the error is not ENOENT. Also free memory.
79 if (ppn) {
80 pn_free(ppn);
81 if (error == -ENOENT)
82 return (NULL);
85 if (error == -ENOENT)
86 return (d_splice_alias(NULL, dentry));
87 else
88 return (ERR_PTR(error));
90 ip = ZTOI(zp);
93 * If we are case insensitive, call the correct function
94 * to install the name.
96 if (ppn) {
97 struct dentry *new_dentry;
98 struct qstr ci_name;
100 if (strcmp(dname(dentry), pn.pn_buf) == 0) {
101 new_dentry = d_splice_alias(ip, dentry);
102 } else {
103 ci_name.name = pn.pn_buf;
104 ci_name.len = strlen(pn.pn_buf);
105 new_dentry = d_add_ci(dentry, ip, &ci_name);
107 pn_free(ppn);
108 return (new_dentry);
109 } else {
110 return (d_splice_alias(ip, dentry));
114 void
115 zpl_vap_init(vattr_t *vap, struct inode *dir, umode_t mode, cred_t *cr)
117 vap->va_mask = ATTR_MODE;
118 vap->va_mode = mode;
119 vap->va_uid = crgetuid(cr);
121 if (dir && dir->i_mode & S_ISGID) {
122 vap->va_gid = KGID_TO_SGID(dir->i_gid);
123 if (S_ISDIR(mode))
124 vap->va_mode |= S_ISGID;
125 } else {
126 vap->va_gid = crgetgid(cr);
130 static int
131 #ifdef HAVE_IOPS_CREATE_USERNS
132 zpl_create(struct user_namespace *user_ns, struct inode *dir,
133 struct dentry *dentry, umode_t mode, bool flag)
134 #else
135 zpl_create(struct inode *dir, struct dentry *dentry, umode_t mode, bool flag)
136 #endif
138 cred_t *cr = CRED();
139 znode_t *zp;
140 vattr_t *vap;
141 int error;
142 fstrans_cookie_t cookie;
144 crhold(cr);
145 vap = kmem_zalloc(sizeof (vattr_t), KM_SLEEP);
146 zpl_vap_init(vap, dir, mode, cr);
148 cookie = spl_fstrans_mark();
149 error = -zfs_create(ITOZ(dir), dname(dentry), vap, 0,
150 mode, &zp, cr, 0, NULL);
151 if (error == 0) {
152 error = zpl_xattr_security_init(ZTOI(zp), dir, &dentry->d_name);
153 if (error == 0)
154 error = zpl_init_acl(ZTOI(zp), dir);
156 if (error) {
157 (void) zfs_remove(ITOZ(dir), dname(dentry), cr, 0);
158 remove_inode_hash(ZTOI(zp));
159 iput(ZTOI(zp));
160 } else {
161 d_instantiate(dentry, ZTOI(zp));
165 spl_fstrans_unmark(cookie);
166 kmem_free(vap, sizeof (vattr_t));
167 crfree(cr);
168 ASSERT3S(error, <=, 0);
170 return (error);
173 static int
174 #ifdef HAVE_IOPS_MKNOD_USERNS
175 zpl_mknod(struct user_namespace *user_ns, struct inode *dir,
176 struct dentry *dentry, umode_t mode,
177 #else
178 zpl_mknod(struct inode *dir, struct dentry *dentry, umode_t mode,
179 #endif
180 dev_t rdev)
182 cred_t *cr = CRED();
183 znode_t *zp;
184 vattr_t *vap;
185 int error;
186 fstrans_cookie_t cookie;
189 * We currently expect Linux to supply rdev=0 for all sockets
190 * and fifos, but we want to know if this behavior ever changes.
192 if (S_ISSOCK(mode) || S_ISFIFO(mode))
193 ASSERT(rdev == 0);
195 crhold(cr);
196 vap = kmem_zalloc(sizeof (vattr_t), KM_SLEEP);
197 zpl_vap_init(vap, dir, mode, cr);
198 vap->va_rdev = rdev;
200 cookie = spl_fstrans_mark();
201 error = -zfs_create(ITOZ(dir), dname(dentry), vap, 0,
202 mode, &zp, cr, 0, NULL);
203 if (error == 0) {
204 error = zpl_xattr_security_init(ZTOI(zp), dir, &dentry->d_name);
205 if (error == 0)
206 error = zpl_init_acl(ZTOI(zp), dir);
208 if (error) {
209 (void) zfs_remove(ITOZ(dir), dname(dentry), cr, 0);
210 remove_inode_hash(ZTOI(zp));
211 iput(ZTOI(zp));
212 } else {
213 d_instantiate(dentry, ZTOI(zp));
217 spl_fstrans_unmark(cookie);
218 kmem_free(vap, sizeof (vattr_t));
219 crfree(cr);
220 ASSERT3S(error, <=, 0);
222 return (error);
225 #ifdef HAVE_TMPFILE
226 static int
227 #ifdef HAVE_TMPFILE_USERNS
228 zpl_tmpfile(struct user_namespace *userns, struct inode *dir,
229 struct dentry *dentry, umode_t mode)
230 #else
231 zpl_tmpfile(struct inode *dir, struct dentry *dentry, umode_t mode)
232 #endif
234 cred_t *cr = CRED();
235 struct inode *ip;
236 vattr_t *vap;
237 int error;
238 fstrans_cookie_t cookie;
240 crhold(cr);
241 vap = kmem_zalloc(sizeof (vattr_t), KM_SLEEP);
243 * The VFS does not apply the umask, therefore it is applied here
244 * when POSIX ACLs are not enabled.
246 if (!IS_POSIXACL(dir))
247 mode &= ~current_umask();
248 zpl_vap_init(vap, dir, mode, cr);
250 cookie = spl_fstrans_mark();
251 error = -zfs_tmpfile(dir, vap, 0, mode, &ip, cr, 0, NULL);
252 if (error == 0) {
253 /* d_tmpfile will do drop_nlink, so we should set it first */
254 set_nlink(ip, 1);
255 d_tmpfile(dentry, ip);
257 error = zpl_xattr_security_init(ip, dir, &dentry->d_name);
258 if (error == 0)
259 error = zpl_init_acl(ip, dir);
261 * don't need to handle error here, file is already in
262 * unlinked set.
266 spl_fstrans_unmark(cookie);
267 kmem_free(vap, sizeof (vattr_t));
268 crfree(cr);
269 ASSERT3S(error, <=, 0);
271 return (error);
273 #endif
275 static int
276 zpl_unlink(struct inode *dir, struct dentry *dentry)
278 cred_t *cr = CRED();
279 int error;
280 fstrans_cookie_t cookie;
281 zfsvfs_t *zfsvfs = dentry->d_sb->s_fs_info;
283 crhold(cr);
284 cookie = spl_fstrans_mark();
285 error = -zfs_remove(ITOZ(dir), dname(dentry), cr, 0);
288 * For a CI FS we must invalidate the dentry to prevent the
289 * creation of negative entries.
291 if (error == 0 && zfsvfs->z_case == ZFS_CASE_INSENSITIVE)
292 d_invalidate(dentry);
294 spl_fstrans_unmark(cookie);
295 crfree(cr);
296 ASSERT3S(error, <=, 0);
298 return (error);
301 static int
302 #ifdef HAVE_IOPS_MKDIR_USERNS
303 zpl_mkdir(struct user_namespace *user_ns, struct inode *dir,
304 struct dentry *dentry, umode_t mode)
305 #else
306 zpl_mkdir(struct inode *dir, struct dentry *dentry, umode_t mode)
307 #endif
309 cred_t *cr = CRED();
310 vattr_t *vap;
311 znode_t *zp;
312 int error;
313 fstrans_cookie_t cookie;
315 crhold(cr);
316 vap = kmem_zalloc(sizeof (vattr_t), KM_SLEEP);
317 zpl_vap_init(vap, dir, mode | S_IFDIR, cr);
319 cookie = spl_fstrans_mark();
320 error = -zfs_mkdir(ITOZ(dir), dname(dentry), vap, &zp, cr, 0, NULL);
321 if (error == 0) {
322 error = zpl_xattr_security_init(ZTOI(zp), dir, &dentry->d_name);
323 if (error == 0)
324 error = zpl_init_acl(ZTOI(zp), dir);
326 if (error) {
327 (void) zfs_rmdir(ITOZ(dir), dname(dentry), NULL, cr, 0);
328 remove_inode_hash(ZTOI(zp));
329 iput(ZTOI(zp));
330 } else {
331 d_instantiate(dentry, ZTOI(zp));
335 spl_fstrans_unmark(cookie);
336 kmem_free(vap, sizeof (vattr_t));
337 crfree(cr);
338 ASSERT3S(error, <=, 0);
340 return (error);
343 static int
344 zpl_rmdir(struct inode *dir, struct dentry *dentry)
346 cred_t *cr = CRED();
347 int error;
348 fstrans_cookie_t cookie;
349 zfsvfs_t *zfsvfs = dentry->d_sb->s_fs_info;
351 crhold(cr);
352 cookie = spl_fstrans_mark();
353 error = -zfs_rmdir(ITOZ(dir), dname(dentry), NULL, cr, 0);
356 * For a CI FS we must invalidate the dentry to prevent the
357 * creation of negative entries.
359 if (error == 0 && zfsvfs->z_case == ZFS_CASE_INSENSITIVE)
360 d_invalidate(dentry);
362 spl_fstrans_unmark(cookie);
363 crfree(cr);
364 ASSERT3S(error, <=, 0);
366 return (error);
369 static int
370 #ifdef HAVE_USERNS_IOPS_GETATTR
371 zpl_getattr_impl(struct user_namespace *user_ns,
372 const struct path *path, struct kstat *stat, u32 request_mask,
373 unsigned int query_flags)
374 #else
375 zpl_getattr_impl(const struct path *path, struct kstat *stat, u32 request_mask,
376 unsigned int query_flags)
377 #endif
379 int error;
380 fstrans_cookie_t cookie;
381 struct inode *ip = path->dentry->d_inode;
382 znode_t *zp __maybe_unused = ITOZ(ip);
384 cookie = spl_fstrans_mark();
387 * XXX query_flags currently ignored.
390 #ifdef HAVE_USERNS_IOPS_GETATTR
391 error = -zfs_getattr_fast(user_ns, ip, stat);
392 #else
393 error = -zfs_getattr_fast(kcred->user_ns, ip, stat);
394 #endif
396 #ifdef STATX_BTIME
397 if (request_mask & STATX_BTIME) {
398 stat->btime = zp->z_btime;
399 stat->result_mask |= STATX_BTIME;
401 #endif
403 #ifdef STATX_ATTR_IMMUTABLE
404 if (zp->z_pflags & ZFS_IMMUTABLE)
405 stat->attributes |= STATX_ATTR_IMMUTABLE;
406 stat->attributes_mask |= STATX_ATTR_IMMUTABLE;
407 #endif
409 #ifdef STATX_ATTR_APPEND
410 if (zp->z_pflags & ZFS_APPENDONLY)
411 stat->attributes |= STATX_ATTR_APPEND;
412 stat->attributes_mask |= STATX_ATTR_APPEND;
413 #endif
415 #ifdef STATX_ATTR_NODUMP
416 if (zp->z_pflags & ZFS_NODUMP)
417 stat->attributes |= STATX_ATTR_NODUMP;
418 stat->attributes_mask |= STATX_ATTR_NODUMP;
419 #endif
421 spl_fstrans_unmark(cookie);
422 ASSERT3S(error, <=, 0);
424 return (error);
426 ZPL_GETATTR_WRAPPER(zpl_getattr);
428 static int
429 #ifdef HAVE_SETATTR_PREPARE_USERNS
430 zpl_setattr(struct user_namespace *user_ns, struct dentry *dentry,
431 struct iattr *ia)
432 #else
433 zpl_setattr(struct dentry *dentry, struct iattr *ia)
434 #endif
436 struct inode *ip = dentry->d_inode;
437 cred_t *cr = CRED();
438 vattr_t *vap;
439 int error;
440 fstrans_cookie_t cookie;
442 error = zpl_setattr_prepare(kcred->user_ns, dentry, ia);
443 if (error)
444 return (error);
446 crhold(cr);
447 vap = kmem_zalloc(sizeof (vattr_t), KM_SLEEP);
448 vap->va_mask = ia->ia_valid & ATTR_IATTR_MASK;
449 vap->va_mode = ia->ia_mode;
450 vap->va_uid = KUID_TO_SUID(ia->ia_uid);
451 vap->va_gid = KGID_TO_SGID(ia->ia_gid);
452 vap->va_size = ia->ia_size;
453 vap->va_atime = ia->ia_atime;
454 vap->va_mtime = ia->ia_mtime;
455 vap->va_ctime = ia->ia_ctime;
457 if (vap->va_mask & ATTR_ATIME)
458 ip->i_atime = zpl_inode_timestamp_truncate(ia->ia_atime, ip);
460 cookie = spl_fstrans_mark();
461 error = -zfs_setattr(ITOZ(ip), vap, 0, cr);
462 if (!error && (ia->ia_valid & ATTR_MODE))
463 error = zpl_chmod_acl(ip);
465 spl_fstrans_unmark(cookie);
466 kmem_free(vap, sizeof (vattr_t));
467 crfree(cr);
468 ASSERT3S(error, <=, 0);
470 return (error);
473 static int
474 #ifdef HAVE_IOPS_RENAME_USERNS
475 zpl_rename2(struct user_namespace *user_ns, struct inode *sdip,
476 struct dentry *sdentry, struct inode *tdip, struct dentry *tdentry,
477 unsigned int flags)
478 #else
479 zpl_rename2(struct inode *sdip, struct dentry *sdentry,
480 struct inode *tdip, struct dentry *tdentry, unsigned int flags)
481 #endif
483 cred_t *cr = CRED();
484 int error;
485 fstrans_cookie_t cookie;
487 /* We don't have renameat2(2) support */
488 if (flags)
489 return (-EINVAL);
491 crhold(cr);
492 cookie = spl_fstrans_mark();
493 error = -zfs_rename(ITOZ(sdip), dname(sdentry), ITOZ(tdip),
494 dname(tdentry), cr, 0);
495 spl_fstrans_unmark(cookie);
496 crfree(cr);
497 ASSERT3S(error, <=, 0);
499 return (error);
502 #if !defined(HAVE_RENAME_WANTS_FLAGS) && !defined(HAVE_IOPS_RENAME_USERNS)
503 static int
504 zpl_rename(struct inode *sdip, struct dentry *sdentry,
505 struct inode *tdip, struct dentry *tdentry)
507 return (zpl_rename2(sdip, sdentry, tdip, tdentry, 0));
509 #endif
511 static int
512 #ifdef HAVE_IOPS_SYMLINK_USERNS
513 zpl_symlink(struct user_namespace *user_ns, struct inode *dir,
514 struct dentry *dentry, const char *name)
515 #else
516 zpl_symlink(struct inode *dir, struct dentry *dentry, const char *name)
517 #endif
519 cred_t *cr = CRED();
520 vattr_t *vap;
521 znode_t *zp;
522 int error;
523 fstrans_cookie_t cookie;
525 crhold(cr);
526 vap = kmem_zalloc(sizeof (vattr_t), KM_SLEEP);
527 zpl_vap_init(vap, dir, S_IFLNK | S_IRWXUGO, cr);
529 cookie = spl_fstrans_mark();
530 error = -zfs_symlink(ITOZ(dir), dname(dentry), vap,
531 (char *)name, &zp, cr, 0);
532 if (error == 0) {
533 error = zpl_xattr_security_init(ZTOI(zp), dir, &dentry->d_name);
534 if (error) {
535 (void) zfs_remove(ITOZ(dir), dname(dentry), cr, 0);
536 remove_inode_hash(ZTOI(zp));
537 iput(ZTOI(zp));
538 } else {
539 d_instantiate(dentry, ZTOI(zp));
543 spl_fstrans_unmark(cookie);
544 kmem_free(vap, sizeof (vattr_t));
545 crfree(cr);
546 ASSERT3S(error, <=, 0);
548 return (error);
551 #if defined(HAVE_PUT_LINK_COOKIE)
552 static void
553 zpl_put_link(struct inode *unused, void *cookie)
555 kmem_free(cookie, MAXPATHLEN);
557 #elif defined(HAVE_PUT_LINK_NAMEIDATA)
558 static void
559 zpl_put_link(struct dentry *dentry, struct nameidata *nd, void *ptr)
561 const char *link = nd_get_link(nd);
563 if (!IS_ERR(link))
564 kmem_free(link, MAXPATHLEN);
566 #elif defined(HAVE_PUT_LINK_DELAYED)
567 static void
568 zpl_put_link(void *ptr)
570 kmem_free(ptr, MAXPATHLEN);
572 #endif
574 static int
575 zpl_get_link_common(struct dentry *dentry, struct inode *ip, char **link)
577 fstrans_cookie_t cookie;
578 cred_t *cr = CRED();
579 int error;
581 crhold(cr);
582 *link = NULL;
584 struct iovec iov;
585 iov.iov_len = MAXPATHLEN;
586 iov.iov_base = kmem_zalloc(MAXPATHLEN, KM_SLEEP);
588 zfs_uio_t uio;
589 zfs_uio_iovec_init(&uio, &iov, 1, 0, UIO_SYSSPACE, MAXPATHLEN - 1, 0);
591 cookie = spl_fstrans_mark();
592 error = -zfs_readlink(ip, &uio, cr);
593 spl_fstrans_unmark(cookie);
594 crfree(cr);
596 if (error)
597 kmem_free(iov.iov_base, MAXPATHLEN);
598 else
599 *link = iov.iov_base;
601 return (error);
604 #if defined(HAVE_GET_LINK_DELAYED)
605 static const char *
606 zpl_get_link(struct dentry *dentry, struct inode *inode,
607 struct delayed_call *done)
609 char *link = NULL;
610 int error;
612 if (!dentry)
613 return (ERR_PTR(-ECHILD));
615 error = zpl_get_link_common(dentry, inode, &link);
616 if (error)
617 return (ERR_PTR(error));
619 set_delayed_call(done, zpl_put_link, link);
621 return (link);
623 #elif defined(HAVE_GET_LINK_COOKIE)
624 static const char *
625 zpl_get_link(struct dentry *dentry, struct inode *inode, void **cookie)
627 char *link = NULL;
628 int error;
630 if (!dentry)
631 return (ERR_PTR(-ECHILD));
633 error = zpl_get_link_common(dentry, inode, &link);
634 if (error)
635 return (ERR_PTR(error));
637 return (*cookie = link);
639 #elif defined(HAVE_FOLLOW_LINK_COOKIE)
640 static const char *
641 zpl_follow_link(struct dentry *dentry, void **cookie)
643 char *link = NULL;
644 int error;
646 error = zpl_get_link_common(dentry, dentry->d_inode, &link);
647 if (error)
648 return (ERR_PTR(error));
650 return (*cookie = link);
652 #elif defined(HAVE_FOLLOW_LINK_NAMEIDATA)
653 static void *
654 zpl_follow_link(struct dentry *dentry, struct nameidata *nd)
656 char *link = NULL;
657 int error;
659 error = zpl_get_link_common(dentry, dentry->d_inode, &link);
660 if (error)
661 nd_set_link(nd, ERR_PTR(error));
662 else
663 nd_set_link(nd, link);
665 return (NULL);
667 #endif
669 static int
670 zpl_link(struct dentry *old_dentry, struct inode *dir, struct dentry *dentry)
672 cred_t *cr = CRED();
673 struct inode *ip = old_dentry->d_inode;
674 int error;
675 fstrans_cookie_t cookie;
677 if (ip->i_nlink >= ZFS_LINK_MAX)
678 return (-EMLINK);
680 crhold(cr);
681 ip->i_ctime = current_time(ip);
682 /* Must have an existing ref, so igrab() cannot return NULL */
683 VERIFY3P(igrab(ip), !=, NULL);
685 cookie = spl_fstrans_mark();
686 error = -zfs_link(ITOZ(dir), ITOZ(ip), dname(dentry), cr, 0);
687 if (error) {
688 iput(ip);
689 goto out;
692 d_instantiate(dentry, ip);
693 out:
694 spl_fstrans_unmark(cookie);
695 crfree(cr);
696 ASSERT3S(error, <=, 0);
698 return (error);
701 static int
702 #ifdef HAVE_D_REVALIDATE_NAMEIDATA
703 zpl_revalidate(struct dentry *dentry, struct nameidata *nd)
705 unsigned int flags = (nd ? nd->flags : 0);
706 #else
707 zpl_revalidate(struct dentry *dentry, unsigned int flags)
709 #endif /* HAVE_D_REVALIDATE_NAMEIDATA */
710 /* CSTYLED */
711 zfsvfs_t *zfsvfs = dentry->d_sb->s_fs_info;
712 int error;
714 if (flags & LOOKUP_RCU)
715 return (-ECHILD);
718 * After a rollback negative dentries created before the rollback
719 * time must be invalidated. Otherwise they can obscure files which
720 * are only present in the rolled back dataset.
722 if (dentry->d_inode == NULL) {
723 spin_lock(&dentry->d_lock);
724 error = time_before(dentry->d_time, zfsvfs->z_rollback_time);
725 spin_unlock(&dentry->d_lock);
727 if (error)
728 return (0);
732 * The dentry may reference a stale inode if a mounted file system
733 * was rolled back to a point in time where the object didn't exist.
735 if (dentry->d_inode && ITOZ(dentry->d_inode)->z_is_stale)
736 return (0);
738 return (1);
741 const struct inode_operations zpl_inode_operations = {
742 .setattr = zpl_setattr,
743 .getattr = zpl_getattr,
744 #ifdef HAVE_GENERIC_SETXATTR
745 .setxattr = generic_setxattr,
746 .getxattr = generic_getxattr,
747 .removexattr = generic_removexattr,
748 #endif
749 .listxattr = zpl_xattr_list,
750 #if defined(CONFIG_FS_POSIX_ACL)
751 #if defined(HAVE_SET_ACL)
752 .set_acl = zpl_set_acl,
753 #endif /* HAVE_SET_ACL */
754 .get_acl = zpl_get_acl,
755 #endif /* CONFIG_FS_POSIX_ACL */
758 const struct inode_operations zpl_dir_inode_operations = {
759 .create = zpl_create,
760 .lookup = zpl_lookup,
761 .link = zpl_link,
762 .unlink = zpl_unlink,
763 .symlink = zpl_symlink,
764 .mkdir = zpl_mkdir,
765 .rmdir = zpl_rmdir,
766 .mknod = zpl_mknod,
767 #if defined(HAVE_RENAME_WANTS_FLAGS) || defined(HAVE_IOPS_RENAME_USERNS)
768 .rename = zpl_rename2,
769 #else
770 .rename = zpl_rename,
771 #endif
772 #ifdef HAVE_TMPFILE
773 .tmpfile = zpl_tmpfile,
774 #endif
775 .setattr = zpl_setattr,
776 .getattr = zpl_getattr,
777 #ifdef HAVE_GENERIC_SETXATTR
778 .setxattr = generic_setxattr,
779 .getxattr = generic_getxattr,
780 .removexattr = generic_removexattr,
781 #endif
782 .listxattr = zpl_xattr_list,
783 #if defined(CONFIG_FS_POSIX_ACL)
784 #if defined(HAVE_SET_ACL)
785 .set_acl = zpl_set_acl,
786 #endif /* HAVE_SET_ACL */
787 .get_acl = zpl_get_acl,
788 #endif /* CONFIG_FS_POSIX_ACL */
791 const struct inode_operations zpl_symlink_inode_operations = {
792 #ifdef HAVE_GENERIC_READLINK
793 .readlink = generic_readlink,
794 #endif
795 #if defined(HAVE_GET_LINK_DELAYED) || defined(HAVE_GET_LINK_COOKIE)
796 .get_link = zpl_get_link,
797 #elif defined(HAVE_FOLLOW_LINK_COOKIE) || defined(HAVE_FOLLOW_LINK_NAMEIDATA)
798 .follow_link = zpl_follow_link,
799 #endif
800 #if defined(HAVE_PUT_LINK_COOKIE) || defined(HAVE_PUT_LINK_NAMEIDATA)
801 .put_link = zpl_put_link,
802 #endif
803 .setattr = zpl_setattr,
804 .getattr = zpl_getattr,
805 #ifdef HAVE_GENERIC_SETXATTR
806 .setxattr = generic_setxattr,
807 .getxattr = generic_getxattr,
808 .removexattr = generic_removexattr,
809 #endif
810 .listxattr = zpl_xattr_list,
813 const struct inode_operations zpl_special_inode_operations = {
814 .setattr = zpl_setattr,
815 .getattr = zpl_getattr,
816 #ifdef HAVE_GENERIC_SETXATTR
817 .setxattr = generic_setxattr,
818 .getxattr = generic_getxattr,
819 .removexattr = generic_removexattr,
820 #endif
821 .listxattr = zpl_xattr_list,
822 #if defined(CONFIG_FS_POSIX_ACL)
823 #if defined(HAVE_SET_ACL)
824 .set_acl = zpl_set_acl,
825 #endif /* HAVE_SET_ACL */
826 .get_acl = zpl_get_acl,
827 #endif /* CONFIG_FS_POSIX_ACL */
830 dentry_operations_t zpl_dentry_operations = {
831 .d_revalidate = zpl_revalidate,