Export symbols for the VFS API
Export all symbols already marked extern in the zfs_vfsops.h header. Several non-static symbols have also been added to the header and exportewd. This allows external modules to more easily create and manipulate properly created ZFS filesystem type datasets. Rename zfsvfs_teardown() to zfs_sb_teardown and export it. This is done simply for consistency with the rest of the code base. All other zfsvfs_* functions have already been renamed. Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
This commit is contained in:
parent
3646c3f2b5
commit
86f35f34f4
|
@ -2123,7 +2123,7 @@ ztest_zil_remount(ztest_ds_t *zd, uint64_t id)
|
||||||
|
|
||||||
(void) rw_enter(&zd->zd_zilog_lock, RW_WRITER);
|
(void) rw_enter(&zd->zd_zilog_lock, RW_WRITER);
|
||||||
|
|
||||||
/* zfsvfs_teardown() */
|
/* zfs_sb_teardown() */
|
||||||
zil_close(zd->zd_zilog);
|
zil_close(zd->zd_zilog);
|
||||||
|
|
||||||
/* zfsvfs_setup() */
|
/* zfsvfs_setup() */
|
||||||
|
|
|
@ -179,8 +179,12 @@ extern boolean_t zfs_owner_overquota(zfs_sb_t *zsb, struct znode *,
|
||||||
extern boolean_t zfs_fuid_overquota(zfs_sb_t *zsb, boolean_t isgroup,
|
extern boolean_t zfs_fuid_overquota(zfs_sb_t *zsb, boolean_t isgroup,
|
||||||
uint64_t fuid);
|
uint64_t fuid);
|
||||||
extern int zfs_set_version(zfs_sb_t *zsb, uint64_t newvers);
|
extern int zfs_set_version(zfs_sb_t *zsb, uint64_t newvers);
|
||||||
|
extern int zfs_get_zplprop(objset_t *os, zfs_prop_t prop,
|
||||||
|
uint64_t *value);
|
||||||
extern int zfs_sb_create(const char *name, zfs_sb_t **zsbp);
|
extern int zfs_sb_create(const char *name, zfs_sb_t **zsbp);
|
||||||
|
extern int zfs_sb_setup(zfs_sb_t *zsb, boolean_t mounting);
|
||||||
extern void zfs_sb_free(zfs_sb_t *zsb);
|
extern void zfs_sb_free(zfs_sb_t *zsb);
|
||||||
|
extern int zfs_sb_teardown(zfs_sb_t *zsb, boolean_t unmounting);
|
||||||
extern int zfs_check_global_label(const char *dsname, const char *hexsl);
|
extern int zfs_check_global_label(const char *dsname, const char *hexsl);
|
||||||
extern boolean_t zfs_is_readonly(zfs_sb_t *zsb);
|
extern boolean_t zfs_is_readonly(zfs_sb_t *zsb);
|
||||||
|
|
||||||
|
|
|
@ -715,8 +715,9 @@ out:
|
||||||
kmem_free(zsb, sizeof (zfs_sb_t));
|
kmem_free(zsb, sizeof (zfs_sb_t));
|
||||||
return (error);
|
return (error);
|
||||||
}
|
}
|
||||||
|
EXPORT_SYMBOL(zfs_sb_create);
|
||||||
|
|
||||||
static int
|
int
|
||||||
zfs_sb_setup(zfs_sb_t *zsb, boolean_t mounting)
|
zfs_sb_setup(zfs_sb_t *zsb, boolean_t mounting)
|
||||||
{
|
{
|
||||||
int error;
|
int error;
|
||||||
|
@ -797,6 +798,7 @@ zfs_sb_setup(zfs_sb_t *zsb, boolean_t mounting)
|
||||||
|
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
EXPORT_SYMBOL(zfs_sb_setup);
|
||||||
|
|
||||||
void
|
void
|
||||||
zfs_sb_free(zfs_sb_t *zsb)
|
zfs_sb_free(zfs_sb_t *zsb)
|
||||||
|
@ -816,6 +818,7 @@ zfs_sb_free(zfs_sb_t *zsb)
|
||||||
mutex_destroy(&zsb->z_hold_mtx[i]);
|
mutex_destroy(&zsb->z_hold_mtx[i]);
|
||||||
kmem_free(zsb, sizeof (zfs_sb_t));
|
kmem_free(zsb, sizeof (zfs_sb_t));
|
||||||
}
|
}
|
||||||
|
EXPORT_SYMBOL(zfs_sb_free);
|
||||||
|
|
||||||
static void
|
static void
|
||||||
zfs_set_fuid_feature(zfs_sb_t *zsb)
|
zfs_set_fuid_feature(zfs_sb_t *zsb)
|
||||||
|
@ -899,6 +902,7 @@ zfs_check_global_label(const char *dsname, const char *hexsl)
|
||||||
}
|
}
|
||||||
return (EACCES);
|
return (EACCES);
|
||||||
}
|
}
|
||||||
|
EXPORT_SYMBOL(zfs_check_global_label);
|
||||||
#endif /* HAVE_MLSLABEL */
|
#endif /* HAVE_MLSLABEL */
|
||||||
|
|
||||||
int
|
int
|
||||||
|
@ -986,7 +990,7 @@ EXPORT_SYMBOL(zfs_root);
|
||||||
* and 'z_teardown_inactive_lock' held.
|
* and 'z_teardown_inactive_lock' held.
|
||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
zfsvfs_teardown(zfs_sb_t *zsb, boolean_t unmounting)
|
zfs_sb_teardown(zfs_sb_t *zsb, boolean_t unmounting)
|
||||||
{
|
{
|
||||||
znode_t *zp;
|
znode_t *zp;
|
||||||
|
|
||||||
|
@ -1083,6 +1087,7 @@ zfsvfs_teardown(zfs_sb_t *zsb, boolean_t unmounting)
|
||||||
|
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
EXPORT_SYMBOL(zfs_sb_teardown);
|
||||||
|
|
||||||
#ifdef HAVE_BDI
|
#ifdef HAVE_BDI
|
||||||
static atomic_long_t bdi_seq = ATOMIC_LONG_INIT(0);
|
static atomic_long_t bdi_seq = ATOMIC_LONG_INIT(0);
|
||||||
|
@ -1185,7 +1190,7 @@ zfs_umount(struct super_block *sb)
|
||||||
zfs_sb_t *zsb = sb->s_fs_info;
|
zfs_sb_t *zsb = sb->s_fs_info;
|
||||||
objset_t *os;
|
objset_t *os;
|
||||||
|
|
||||||
VERIFY(zfsvfs_teardown(zsb, B_TRUE) == 0);
|
VERIFY(zfs_sb_teardown(zsb, B_TRUE) == 0);
|
||||||
os = zsb->z_os;
|
os = zsb->z_os;
|
||||||
|
|
||||||
if (bdi_get_sb(sb)) {
|
if (bdi_get_sb(sb)) {
|
||||||
|
@ -1332,7 +1337,7 @@ zfs_suspend_fs(zfs_sb_t *zsb)
|
||||||
{
|
{
|
||||||
int error;
|
int error;
|
||||||
|
|
||||||
if ((error = zfsvfs_teardown(zsb, B_FALSE)) != 0)
|
if ((error = zfs_sb_teardown(zsb, B_FALSE)) != 0)
|
||||||
return (error);
|
return (error);
|
||||||
dmu_objset_disown(zsb->z_os, zsb);
|
dmu_objset_disown(zsb->z_os, zsb);
|
||||||
|
|
||||||
|
@ -1512,6 +1517,7 @@ zfs_get_zplprop(objset_t *os, zfs_prop_t prop, uint64_t *value)
|
||||||
}
|
}
|
||||||
return (error);
|
return (error);
|
||||||
}
|
}
|
||||||
|
EXPORT_SYMBOL(zfs_get_zplprop);
|
||||||
|
|
||||||
void
|
void
|
||||||
zfs_init(void)
|
zfs_init(void)
|
||||||
|
|
Loading…
Reference in New Issue