| 1 | /* SPDX-License-Identifier: GPL-2.0 */ | 
|---|
| 2 | /* | 
|---|
| 3 | * include/linux/nfs_ssc.h | 
|---|
| 4 | * | 
|---|
| 5 | * Author: Dai Ngo <dai.ngo@oracle.com> | 
|---|
| 6 | * | 
|---|
| 7 | * Copyright (c) 2020, Oracle and/or its affiliates. | 
|---|
| 8 | */ | 
|---|
| 9 |  | 
|---|
| 10 | #include <linux/nfs_fs.h> | 
|---|
| 11 | #include <linux/sunrpc/svc.h> | 
|---|
| 12 |  | 
|---|
| 13 | extern struct nfs_ssc_client_ops_tbl nfs_ssc_client_tbl; | 
|---|
| 14 |  | 
|---|
| 15 | /* | 
|---|
| 16 | * NFS_V4 | 
|---|
| 17 | */ | 
|---|
| 18 | struct nfs4_ssc_client_ops { | 
|---|
| 19 | struct file *(*sco_open)(struct vfsmount *ss_mnt, | 
|---|
| 20 | struct nfs_fh *src_fh, nfs4_stateid *stateid); | 
|---|
| 21 | void (*sco_close)(struct file *filep); | 
|---|
| 22 | }; | 
|---|
| 23 |  | 
|---|
| 24 | /* | 
|---|
| 25 | * NFS_FS | 
|---|
| 26 | */ | 
|---|
| 27 | struct nfs_ssc_client_ops { | 
|---|
| 28 | void (*sco_sb_deactive)(struct super_block *sb); | 
|---|
| 29 | }; | 
|---|
| 30 |  | 
|---|
| 31 | struct nfs_ssc_client_ops_tbl { | 
|---|
| 32 | const struct nfs4_ssc_client_ops *ssc_nfs4_ops; | 
|---|
| 33 | const struct nfs_ssc_client_ops *ssc_nfs_ops; | 
|---|
| 34 | }; | 
|---|
| 35 |  | 
|---|
| 36 | extern void nfs42_ssc_register_ops(void); | 
|---|
| 37 | extern void nfs42_ssc_unregister_ops(void); | 
|---|
| 38 |  | 
|---|
| 39 | extern void nfs42_ssc_register(const struct nfs4_ssc_client_ops *ops); | 
|---|
| 40 | extern void nfs42_ssc_unregister(const struct nfs4_ssc_client_ops *ops); | 
|---|
| 41 |  | 
|---|
| 42 | #ifdef CONFIG_NFSD_V4_2_INTER_SSC | 
|---|
| 43 | static inline struct file *nfs42_ssc_open(struct vfsmount *ss_mnt, | 
|---|
| 44 | struct nfs_fh *src_fh, nfs4_stateid *stateid) | 
|---|
| 45 | { | 
|---|
| 46 | if (nfs_ssc_client_tbl.ssc_nfs4_ops) | 
|---|
| 47 | return (*nfs_ssc_client_tbl.ssc_nfs4_ops->sco_open)(ss_mnt, src_fh, stateid); | 
|---|
| 48 | return ERR_PTR(-EIO); | 
|---|
| 49 | } | 
|---|
| 50 |  | 
|---|
| 51 | static inline void nfs42_ssc_close(struct file *filep) | 
|---|
| 52 | { | 
|---|
| 53 | if (nfs_ssc_client_tbl.ssc_nfs4_ops) | 
|---|
| 54 | (*nfs_ssc_client_tbl.ssc_nfs4_ops->sco_close)(filep); | 
|---|
| 55 | } | 
|---|
| 56 | #endif | 
|---|
| 57 |  | 
|---|
| 58 | struct nfsd4_ssc_umount_item { | 
|---|
| 59 | struct list_head nsui_list; | 
|---|
| 60 | bool nsui_busy; | 
|---|
| 61 | /* | 
|---|
| 62 | * nsui_refcnt inited to 2, 1 on list and 1 for consumer. Entry | 
|---|
| 63 | * is removed when refcnt drops to 1 and nsui_expire expires. | 
|---|
| 64 | */ | 
|---|
| 65 | refcount_t nsui_refcnt; | 
|---|
| 66 | unsigned long nsui_expire; | 
|---|
| 67 | struct vfsmount *nsui_vfsmount; | 
|---|
| 68 | char nsui_ipaddr[RPC_MAX_ADDRBUFLEN + 1]; | 
|---|
| 69 | }; | 
|---|
| 70 |  | 
|---|
| 71 | /* | 
|---|
| 72 | * NFS_FS | 
|---|
| 73 | */ | 
|---|
| 74 | extern void nfs_ssc_register(const struct nfs_ssc_client_ops *ops); | 
|---|
| 75 | extern void nfs_ssc_unregister(const struct nfs_ssc_client_ops *ops); | 
|---|
| 76 |  | 
|---|
| 77 | static inline void nfs_do_sb_deactive(struct super_block *sb) | 
|---|
| 78 | { | 
|---|
| 79 | if (nfs_ssc_client_tbl.ssc_nfs_ops) | 
|---|
| 80 | (*nfs_ssc_client_tbl.ssc_nfs_ops->sco_sb_deactive)(sb); | 
|---|
| 81 | } | 
|---|
| 82 |  | 
|---|