Print this page
11083 support NFS server in zone
Portions contributed by: Dan Kruchinin <dan.kruchinin@nexenta.com>
Portions contributed by: Stepan Zastupov <stepan.zastupov@gmail.com>
Portions contributed by: Joyce McIntosh <joyce.mcintosh@nexenta.com>
Portions contributed by: Mike Zeller <mike@mikezeller.net>
Portions contributed by: Dan McDonald <danmcd@joyent.com>
Portions contributed by: Gordon Ross <gordon.w.ross@gmail.com>
Portions contributed by: Vitaliy Gusev <gusev.vitaliy@gmail.com>
Reviewed by: Rick McNeal <rick.mcneal@nexenta.com>
Reviewed by: Rob Gittins <rob.gittins@nexenta.com>
Reviewed by: Sanjay Nadkarni <sanjay.nadkarni@nexenta.com>
Reviewed by: Jason King <jbk@joyent.com>
Reviewed by: C Fraire <cfraire@me.com>
Change-Id: I22f289d357503f9b48a0bc2482cc4328a6d43d16

*** 22,36 **** /* * Copyright 2007 Sun Microsystems, Inc. All rights reserved. * Use is subject to license terms. */ #ifndef _SHAREFS_SHAREFS_H #define _SHAREFS_SHAREFS_H - #pragma ident "%Z%%M% %I% %E% SMI" - /* * This header provides service for the sharefs module. */ #include <sys/modctl.h> --- 22,38 ---- /* * Copyright 2007 Sun Microsystems, Inc. All rights reserved. * Use is subject to license terms. */ + /* + * Copyright 2018 Nexenta Systems, Inc. + */ + #ifndef _SHAREFS_SHAREFS_H #define _SHAREFS_SHAREFS_H /* * This header provides service for the sharefs module. */ #include <sys/modctl.h>
*** 65,92 **** vnode_t *sharefs_vfs_root; } sharefs_vfs_t; #define SHAREFS_NAME_MAX MAXNAMELEN ! /* * The lock ordering whenever sharefs_lock and sharetab_lock both * need to be held is: sharefs_lock and then sharetab_lock. */ ! extern krwlock_t sharefs_lock; /* lock for the vnode ops */ ! extern sharetab_t *sharefs_sharetab; /* The sharetab. */ ! extern uint_t sharetab_count; /* How many shares? */ ! extern krwlock_t sharetab_lock; /* lock for the cached sharetab */ ! extern size_t sharetab_size; /* How big is the sharetab file? */ ! extern timestruc_t sharetab_mtime; /* Last mod to sharetab */ ! extern timestruc_t sharetab_snap_time; /* Last snap */ ! extern uint_t sharetab_generation; /* Which copy is it? */ #define SHAREFS_INO_FILE 0x80 extern vnode_t *sharefs_create_root_file(vfs_t *); /* * Sharetab file * * Note that even though the sharetab code does not explictly --- 67,97 ---- vnode_t *sharefs_vfs_root; } sharefs_vfs_t; #define SHAREFS_NAME_MAX MAXNAMELEN ! typedef struct sharetab_globals { ! /* * The lock ordering whenever sharefs_lock and sharetab_lock both * need to be held is: sharefs_lock and then sharetab_lock. */ ! krwlock_t sharefs_lock; /* lock for the vnode ops */ ! sharetab_t *sharefs_sharetab; /* The sharetab. */ ! uint_t sharetab_count; /* How many shares? */ ! krwlock_t sharetab_lock; /* lock for the cached sharetab */ ! size_t sharetab_size; /* How big is the sharetab file? */ ! timestruc_t sharetab_mtime; /* Last mod to sharetab */ ! timestruc_t sharetab_snap_time; /* Last snap */ ! uint_t sharetab_generation; /* Which copy is it? */ ! } sharetab_globals_t; #define SHAREFS_INO_FILE 0x80 extern vnode_t *sharefs_create_root_file(vfs_t *); + extern sharetab_globals_t *sharetab_get_globals(zone_t *zone); /* * Sharetab file * * Note that even though the sharetab code does not explictly