213 lines
6.5 KiB
C
213 lines
6.5 KiB
C
|
/*
|
||
|
* CDDL HEADER SART
|
||
|
*
|
||
|
* The contents of this file are subject to the terms of the
|
||
|
* Common Development and Distribution License (the "License").
|
||
|
* You may not use this file except in compliance with the License.
|
||
|
*
|
||
|
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
|
||
|
* or http://www.opensolaris.org/os/licensing.
|
||
|
* See the License for the specific language governing permissions
|
||
|
* and limitations under the License.
|
||
|
*
|
||
|
* When distributing Covered Code, include this CDDL HEADER in each
|
||
|
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
|
||
|
* If applicable, add the following below this CDDL HEADER, with the
|
||
|
* fields enclosed by brackets "[]" replaced with your own identifying
|
||
|
* information: Portions Copyright [yyyy] [name of copyright owner]
|
||
|
*
|
||
|
* CDDL HEADER END
|
||
|
*/
|
||
|
|
||
|
/*
|
||
|
* Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
|
||
|
* Copyright (c) 2011, 2017 by Delphix. All rights reserved.
|
||
|
* Copyright (c) 2018 Datto Inc.
|
||
|
*/
|
||
|
|
||
|
#ifndef _LIBZFS_IMPL_H
|
||
|
#define _LIBZFS_IMPL_H
|
||
|
|
||
|
#include <sys/fs/zfs.h>
|
||
|
#include <sys/spa.h>
|
||
|
#include <sys/nvpair.h>
|
||
|
#include <sys/dmu.h>
|
||
|
#include <sys/zfs_ioctl.h>
|
||
|
|
||
|
#include <libuutil.h>
|
||
|
#include <libzfs.h>
|
||
|
#include <libshare.h>
|
||
|
#include <libzfs_core.h>
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
struct libzfs_handle {
|
||
|
int libzfs_error;
|
||
|
int libzfs_fd;
|
||
|
FILE *libzfs_mnttab;
|
||
|
FILE *libzfs_sharetab;
|
||
|
zpool_handle_t *libzfs_pool_handles;
|
||
|
uu_avl_pool_t *libzfs_ns_avlpool;
|
||
|
uu_avl_t *libzfs_ns_avl;
|
||
|
uint64_t libzfs_ns_gen;
|
||
|
int libzfs_desc_active;
|
||
|
char libzfs_action[1024];
|
||
|
char libzfs_desc[1024];
|
||
|
int libzfs_printerr;
|
||
|
int libzfs_storeerr; /* stuff error messages into buffer */
|
||
|
void *libzfs_sharehdl; /* libshare handle */
|
||
|
uint_t libzfs_shareflags;
|
||
|
boolean_t libzfs_mnttab_enable;
|
||
|
/*
|
||
|
* We need a lock to handle the case where parallel mount
|
||
|
* threads are populating the mnttab cache simultaneously. The
|
||
|
* lock only protects the integrity of the avl tree, and does
|
||
|
* not protect the contents of the mnttab entries themselves.
|
||
|
*/
|
||
|
pthread_mutex_t libzfs_mnttab_cache_lock;
|
||
|
avl_tree_t libzfs_mnttab_cache;
|
||
|
int libzfs_pool_iter;
|
||
|
char libzfs_chassis_id[256];
|
||
|
boolean_t libzfs_prop_debug;
|
||
|
};
|
||
|
|
||
|
#define ZFSSHARE_MISS 0x01 /* Didn't find entry in cache */
|
||
|
|
||
|
struct zfs_handle {
|
||
|
libzfs_handle_t *zfs_hdl;
|
||
|
zpool_handle_t *zpool_hdl;
|
||
|
char zfs_name[ZFS_MAX_DATASET_NAME_LEN];
|
||
|
zfs_type_t zfs_type; /* type including snapshot */
|
||
|
zfs_type_t zfs_head_type; /* type excluding snapshot */
|
||
|
dmu_objset_stats_t zfs_dmustats;
|
||
|
nvlist_t *zfs_props;
|
||
|
nvlist_t *zfs_user_props;
|
||
|
nvlist_t *zfs_recvd_props;
|
||
|
boolean_t zfs_mntcheck;
|
||
|
char *zfs_mntopts;
|
||
|
uint8_t *zfs_props_table;
|
||
|
};
|
||
|
|
||
|
/*
|
||
|
* This is different from checking zfs_type, because it will also catch
|
||
|
* snapshots of volumes.
|
||
|
*/
|
||
|
#define ZFS_IS_VOLUME(zhp) ((zhp)->zfs_head_type == ZFS_TYPE_VOLUME)
|
||
|
|
||
|
struct zpool_handle {
|
||
|
libzfs_handle_t *zpool_hdl;
|
||
|
zpool_handle_t *zpool_next;
|
||
|
char zpool_name[ZFS_MAX_DATASET_NAME_LEN];
|
||
|
int zpool_state;
|
||
|
size_t zpool_config_size;
|
||
|
nvlist_t *zpool_config;
|
||
|
nvlist_t *zpool_old_config;
|
||
|
nvlist_t *zpool_props;
|
||
|
diskaddr_t zpool_start_block;
|
||
|
};
|
||
|
|
||
|
typedef enum {
|
||
|
PROTO_NFS = 0,
|
||
|
PROTO_SMB = 1,
|
||
|
PROTO_END = 2
|
||
|
} zfs_share_proto_t;
|
||
|
|
||
|
/*
|
||
|
* The following can be used as a bitmask and any new values
|
||
|
* added must preserve that capability.
|
||
|
*/
|
||
|
typedef enum {
|
||
|
SHARED_NOT_SHARED = 0x0,
|
||
|
SHARED_NFS = 0x2,
|
||
|
SHARED_SMB = 0x4
|
||
|
} zfs_share_type_t;
|
||
|
|
||
|
#define CONFIG_BUF_MINSIZE 262144
|
||
|
|
||
|
int zfs_error(libzfs_handle_t *, int, const char *);
|
||
|
int zfs_error_fmt(libzfs_handle_t *, int, const char *, ...);
|
||
|
void zfs_error_aux(libzfs_handle_t *, const char *, ...);
|
||
|
void *zfs_alloc(libzfs_handle_t *, size_t);
|
||
|
void *zfs_realloc(libzfs_handle_t *, void *, size_t, size_t);
|
||
|
char *zfs_asprintf(libzfs_handle_t *, const char *, ...);
|
||
|
char *zfs_strdup(libzfs_handle_t *, const char *);
|
||
|
int no_memory(libzfs_handle_t *);
|
||
|
|
||
|
int zfs_standard_error(libzfs_handle_t *, int, const char *);
|
||
|
int zfs_standard_error_fmt(libzfs_handle_t *, int, const char *, ...);
|
||
|
int zpool_standard_error(libzfs_handle_t *, int, const char *);
|
||
|
int zpool_standard_error_fmt(libzfs_handle_t *, int, const char *, ...);
|
||
|
|
||
|
zfs_handle_t *make_dataset_handle_zc(libzfs_handle_t *, zfs_cmd_t *);
|
||
|
zfs_handle_t *make_dataset_simple_handle_zc(zfs_handle_t *, zfs_cmd_t *);
|
||
|
|
||
|
int zprop_parse_value(libzfs_handle_t *, nvpair_t *, int, zfs_type_t,
|
||
|
nvlist_t *, char **, uint64_t *, const char *);
|
||
|
int zprop_expand_list(libzfs_handle_t *hdl, zprop_list_t **plp,
|
||
|
zfs_type_t type);
|
||
|
|
||
|
/*
|
||
|
* Use this changelist_gather() flag to force attempting mounts
|
||
|
* on each change node regardless of whether or not it is currently
|
||
|
* mounted.
|
||
|
*/
|
||
|
#define CL_GATHER_MOUNT_ALWAYS 1
|
||
|
/*
|
||
|
* changelist_gather() flag to force it to iterate on mounted datasets only
|
||
|
*/
|
||
|
#define CL_GATHER_ITER_MOUNTED 2
|
||
|
|
||
|
typedef struct prop_changelist prop_changelist_t;
|
||
|
|
||
|
int zcmd_alloc_dst_nvlist(libzfs_handle_t *, zfs_cmd_t *, size_t);
|
||
|
int zcmd_write_src_nvlist(libzfs_handle_t *, zfs_cmd_t *, nvlist_t *);
|
||
|
int zcmd_write_conf_nvlist(libzfs_handle_t *, zfs_cmd_t *, nvlist_t *);
|
||
|
int zcmd_expand_dst_nvlist(libzfs_handle_t *, zfs_cmd_t *);
|
||
|
int zcmd_read_dst_nvlist(libzfs_handle_t *, zfs_cmd_t *, nvlist_t **);
|
||
|
void zcmd_free_nvlists(zfs_cmd_t *);
|
||
|
|
||
|
int changelist_prefix(prop_changelist_t *);
|
||
|
int changelist_postfix(prop_changelist_t *);
|
||
|
void changelist_rename(prop_changelist_t *, const char *, const char *);
|
||
|
void changelist_remove(prop_changelist_t *, const char *);
|
||
|
void changelist_free(prop_changelist_t *);
|
||
|
prop_changelist_t *changelist_gather(zfs_handle_t *, zfs_prop_t, int, int);
|
||
|
int changelist_unshare(prop_changelist_t *, zfs_share_proto_t *);
|
||
|
int changelist_haszonedchild(prop_changelist_t *);
|
||
|
|
||
|
void remove_mountpoint(zfs_handle_t *);
|
||
|
int create_parents(libzfs_handle_t *, char *, int);
|
||
|
boolean_t isa_child_of(const char *dataset, const char *parent);
|
||
|
|
||
|
zfs_handle_t *make_dataset_handle(libzfs_handle_t *, const char *);
|
||
|
zfs_handle_t *make_bookmark_handle(zfs_handle_t *, const char *,
|
||
|
nvlist_t *props);
|
||
|
|
||
|
int zpool_open_silent(libzfs_handle_t *, const char *, zpool_handle_t **);
|
||
|
|
||
|
boolean_t zpool_name_valid(libzfs_handle_t *, boolean_t, const char *);
|
||
|
|
||
|
int zfs_validate_name(libzfs_handle_t *hdl, const char *path, int type,
|
||
|
boolean_t modifying);
|
||
|
|
||
|
void namespace_clear(libzfs_handle_t *);
|
||
|
|
||
|
/*
|
||
|
* libshare (sharemgr) interfaces used internally.
|
||
|
*/
|
||
|
|
||
|
extern int zfs_init_libshare(libzfs_handle_t *, int);
|
||
|
extern void zfs_uninit_libshare(libzfs_handle_t *);
|
||
|
extern int zfs_parse_options(char *, zfs_share_proto_t);
|
||
|
|
||
|
extern int zfs_unshare_proto(zfs_handle_t *,
|
||
|
const char *, zfs_share_proto_t *);
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif /* _LIBZFS_IMPL_H */
|