Path: blob/main/sys/contrib/openzfs/lib/libzfs/libzfs_impl.h
48378 views
// SPDX-License-Identifier: CDDL-1.01/*2* CDDL HEADER START3*4* The contents of this file are subject to the terms of the5* Common Development and Distribution License (the "License").6* You may not use this file except in compliance with the License.7*8* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE9* or https://opensource.org/licenses/CDDL-1.0.10* See the License for the specific language governing permissions11* and limitations under the License.12*13* When distributing Covered Code, include this CDDL HEADER in each14* file and include the License file at usr/src/OPENSOLARIS.LICENSE.15* If applicable, add the following below this CDDL HEADER, with the16* fields enclosed by brackets "[]" replaced with your own identifying17* information: Portions Copyright [yyyy] [name of copyright owner]18*19* CDDL HEADER END20*/2122/*23* Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.24* Copyright (c) 2011, 2020 by Delphix. All rights reserved.25* Copyright (c) 2018 Datto Inc.26* Copyright 2020 Joyent, Inc.27*/2829#ifndef _LIBZFS_IMPL_H30#define _LIBZFS_IMPL_H3132#include <sys/fs/zfs.h>33#include <sys/nvpair.h>34#include <sys/dmu.h>35#include <sys/zfs_ioctl.h>36#include <regex.h>3738#include <libuutil.h>39#include <libzfs.h>40#include <libshare.h>41#include <libzfs_core.h>4243#ifdef __cplusplus44extern "C" {45#endif4647#define ERRBUFLEN 10244849struct libzfs_handle {50int libzfs_error;51int libzfs_fd;52zpool_handle_t *libzfs_pool_handles;53uu_avl_pool_t *libzfs_ns_avlpool;54uu_avl_t *libzfs_ns_avl;55uint64_t libzfs_ns_gen;56int libzfs_desc_active;57char libzfs_action[1024];58char libzfs_desc[1024];59int libzfs_printerr;60boolean_t libzfs_mnttab_enable;61/*62* We need a lock to handle the case where parallel mount63* threads are populating the mnttab cache simultaneously. The64* lock only protects the integrity of the avl tree, and does65* not protect the contents of the mnttab entries themselves.66*/67pthread_mutex_t libzfs_mnttab_cache_lock;68avl_tree_t libzfs_mnttab_cache;69int libzfs_pool_iter;70boolean_t libzfs_prop_debug;71regex_t libzfs_urire;72uint64_t libzfs_max_nvlist;73void *libfetch;74char *libfetch_load_error;75};7677struct zfs_handle {78libzfs_handle_t *zfs_hdl;79zpool_handle_t *zpool_hdl;80char zfs_name[ZFS_MAX_DATASET_NAME_LEN];81zfs_type_t zfs_type; /* type including snapshot */82zfs_type_t zfs_head_type; /* type excluding snapshot */83dmu_objset_stats_t zfs_dmustats;84nvlist_t *zfs_props;85nvlist_t *zfs_user_props;86nvlist_t *zfs_recvd_props;87boolean_t zfs_mntcheck;88char *zfs_mntopts;89uint8_t *zfs_props_table;90};9192/*93* This is different from checking zfs_type, because it will also catch94* snapshots of volumes.95*/96#define ZFS_IS_VOLUME(zhp) ((zhp)->zfs_head_type == ZFS_TYPE_VOLUME)97#define ZHP_MAX_PROPNAMES 49899struct zpool_handle {100libzfs_handle_t *zpool_hdl;101zpool_handle_t *zpool_next;102char zpool_name[ZFS_MAX_DATASET_NAME_LEN];103int zpool_state;104unsigned int zpool_n_propnames;105const char *zpool_propnames[ZHP_MAX_PROPNAMES];106size_t zpool_config_size;107nvlist_t *zpool_config;108nvlist_t *zpool_old_config;109nvlist_t *zpool_props;110diskaddr_t zpool_start_block;111};112113typedef int (*zfs_uri_handler_fn_t)(struct libzfs_handle *, const char *,114const char *, zfs_keyformat_t, boolean_t, uint8_t **, size_t *);115116typedef struct zfs_uri_handler {117const char *zuh_scheme;118zfs_uri_handler_fn_t zuh_handler;119} zfs_uri_handler_t;120121#define CONFIG_BUF_MINSIZE 262144122123extern int zfs_error(libzfs_handle_t *, int, const char *);124extern int zfs_error_fmt(libzfs_handle_t *, int, const char *, ...)125__attribute__((format(printf, 3, 4)));126extern void zfs_error_aux(libzfs_handle_t *, const char *, ...)127__attribute__((format(printf, 2, 3)));128extern void *zfs_alloc(libzfs_handle_t *, size_t);129extern void *zfs_realloc(libzfs_handle_t *, void *, size_t, size_t);130extern char *zfs_asprintf(libzfs_handle_t *, const char *, ...)131__attribute__((format(printf, 2, 3)));132extern char *zfs_strdup(libzfs_handle_t *, const char *);133extern int no_memory(libzfs_handle_t *);134135extern int zfs_standard_error_fmt(libzfs_handle_t *, int, const char *, ...)136__attribute__((format(printf, 3, 4)));137extern void zfs_setprop_error(libzfs_handle_t *, zfs_prop_t, int, char *);138extern int zpool_standard_error(libzfs_handle_t *, int, const char *);139extern int zpool_standard_error_fmt(libzfs_handle_t *, int, const char *, ...)140__attribute__((format(printf, 3, 4)));141142extern zfs_handle_t *make_dataset_handle_zc(libzfs_handle_t *, zfs_cmd_t *);143extern zfs_handle_t *make_dataset_simple_handle_zc(zfs_handle_t *, zfs_cmd_t *);144145extern int zprop_parse_value(libzfs_handle_t *, nvpair_t *, int, zfs_type_t,146nvlist_t *, const char **, uint64_t *, const char *);147extern int zprop_expand_list(libzfs_handle_t *hdl, zprop_list_t **plp,148zfs_type_t type);149150/*151* Use this changelist_gather() flag to force attempting mounts152* on each change node regardless of whether or not it is currently153* mounted.154*/155#define CL_GATHER_MOUNT_ALWAYS 1156/*157* changelist_gather() flag to force it to iterate on mounted datasets only158*/159#define CL_GATHER_ITER_MOUNTED 2160/*161* Use this changelist_gather() flag to prevent unmounting of file systems.162*/163#define CL_GATHER_DONT_UNMOUNT 4164165typedef struct prop_changelist prop_changelist_t;166167extern void zcmd_alloc_dst_nvlist(libzfs_handle_t *, zfs_cmd_t *, size_t);168extern void zcmd_write_src_nvlist(libzfs_handle_t *, zfs_cmd_t *, nvlist_t *);169extern void zcmd_write_conf_nvlist(libzfs_handle_t *, zfs_cmd_t *, nvlist_t *);170extern void zcmd_expand_dst_nvlist(libzfs_handle_t *, zfs_cmd_t *);171extern int zcmd_read_dst_nvlist(libzfs_handle_t *, zfs_cmd_t *, nvlist_t **);172extern void zcmd_free_nvlists(zfs_cmd_t *);173174extern int changelist_prefix(prop_changelist_t *);175extern int changelist_postfix(prop_changelist_t *);176extern void changelist_rename(prop_changelist_t *, const char *, const char *);177extern void changelist_remove(prop_changelist_t *, const char *);178extern void changelist_free(prop_changelist_t *);179extern prop_changelist_t *changelist_gather(zfs_handle_t *, zfs_prop_t, int,180int);181extern int changelist_unshare(prop_changelist_t *, const enum sa_protocol *);182extern int changelist_haszonedchild(prop_changelist_t *);183184extern void remove_mountpoint(zfs_handle_t *);185extern int create_parents(libzfs_handle_t *, char *, int);186187extern zfs_handle_t *make_dataset_handle(libzfs_handle_t *, const char *);188extern zfs_handle_t *make_bookmark_handle(zfs_handle_t *, const char *,189nvlist_t *props);190191extern int zpool_open_silent(libzfs_handle_t *, const char *,192zpool_handle_t **);193194extern boolean_t zpool_name_valid(libzfs_handle_t *, boolean_t, const char *);195196extern int zfs_validate_name(libzfs_handle_t *hdl, const char *path, int type,197boolean_t modifying);198199extern void namespace_clear(libzfs_handle_t *);200201typedef struct {202zfs_prop_t p_prop;203int p_share_err;204int p_unshare_err;205} proto_table_t;206207typedef struct differ_info {208zfs_handle_t *zhp;209char *fromsnap;210char *frommnt;211char *tosnap;212char *tomnt;213char *ds;214char *dsmnt;215char *tmpsnap;216char errbuf[ERRBUFLEN];217boolean_t isclone;218boolean_t scripted;219boolean_t classify;220boolean_t timestamped;221boolean_t no_mangle;222uint64_t shares;223int zerr;224int cleanupfd;225int outputfd;226int datafd;227} differ_info_t;228229extern int do_mount(zfs_handle_t *zhp, const char *mntpt, const char *opts,230int flags);231extern int do_unmount(zfs_handle_t *zhp, const char *mntpt, int flags);232extern int libzfs_load_module(void);233extern int zpool_relabel_disk(libzfs_handle_t *hdl, const char *path,234const char *msg);235extern int find_shares_object(differ_info_t *di);236237#ifdef __cplusplus238}239#endif240241#endif /* _LIBZFS_IMPL_H */242243244