#ifndef _SYS_CTFS_IMPL_H
#define _SYS_CTFS_IMPL_H
#include <sys/contract.h>
#include <sys/gfs.h>
#ifdef __cplusplus
extern "C" {
#endif
#define CTFS_INO_ROOT 0
#define CTFS_INO_CT_SHIFT 32
#define CTFS_INO_CT(ctid, file) \
((1ULL << 63) | \
((unsigned long long)(file) << CTFS_INO_CT_SHIFT) | \
(ctid))
#define CTFS_INO_CT_DIR(ctid) CTFS_INO_CT((ctid), 0)
#define CTFS_INO_CT_LINK(ctid) CTFS_INO_CT((ctid), 1)
#define CTFS_INO_CT_FILE(ctid, file) CTFS_INO_CT((ctid), (file) + 2)
#define CTFS_INO_TYPE_SHIFT 16
#define CTFS_INO_TYPE(type, file) \
(((type) + 1) << CTFS_INO_TYPE_SHIFT | (file))
#define CTFS_INO_TYPE_DIR(type) CTFS_INO_TYPE((type), 0)
#define CTFS_INO_TYPE_FILE(type, file) CTFS_INO_TYPE((type), (file) + 1)
#define CTFS_NAME_MAX 32
#define CTFS_ENDPT_SETUP 0x1
#define CTFS_ENDPT_NBLOCK 0x2
typedef struct ctfs_endpoint {
kmutex_t ctfs_endpt_lock;
ct_listener_t ctfs_endpt_listener;
uint_t ctfs_endpt_flags;
} ctfs_endpoint_t;
typedef gfs_dir_t ctfs_rootnode_t;
typedef gfs_dir_t ctfs_adirnode_t;
typedef struct ctfs_symnode {
gfs_file_t ctfs_sn_file;
contract_t *ctfs_sn_contract;
char *ctfs_sn_string;
size_t ctfs_sn_size;
} ctfs_symnode_t;
typedef gfs_dir_t ctfs_tdirnode_t;
typedef struct ctfs_cdirnode {
gfs_dir_t ctfs_cn_dir;
contract_t *ctfs_cn_contract;
contract_vnode_t ctfs_cn_linkage;
} ctfs_cdirnode_t;
typedef struct ctfs_tmplnode {
gfs_file_t ctfs_tmn_file;
ct_template_t *ctfs_tmn_tmpl;
} ctfs_tmplnode_t;
typedef struct ctfs_ctlnode {
gfs_file_t ctfs_ctl_file;
contract_t *ctfs_ctl_contract;
} ctfs_ctlnode_t;
typedef gfs_dir_t ctfs_latenode_t;
typedef struct ctfs_evnode {
gfs_file_t ctfs_ev_file;
contract_t *ctfs_ev_contract;
ctfs_endpoint_t ctfs_ev_listener;
} ctfs_evnode_t;
typedef struct ctfs_bunode {
gfs_file_t ctfs_bu_file;
ct_equeue_t *ctfs_bu_queue;
ctfs_endpoint_t ctfs_bu_listener;
} ctfs_bunode_t;
typedef struct ctfs_vfs {
vnode_t *ctvfs_root;
} ctfs_vfs_t;
extern vnode_t *ctfs_create_tdirnode(vnode_t *);
extern vnode_t *ctfs_create_tmplnode(vnode_t *);
extern vnode_t *ctfs_create_latenode(vnode_t *);
extern vnode_t *ctfs_create_pbundle(vnode_t *);
extern vnode_t *ctfs_create_bundle(vnode_t *);
extern vnode_t *ctfs_create_ctlnode(vnode_t *);
extern vnode_t *ctfs_create_statnode(vnode_t *);
extern vnode_t *ctfs_create_evnode(vnode_t *);
extern vnode_t *ctfs_create_adirnode(vnode_t *);
extern vnode_t *ctfs_create_cdirnode(vnode_t *, contract_t *);
extern vnode_t *ctfs_create_symnode(vnode_t *, contract_t *);
extern void ctfs_common_getattr(vnode_t *, vattr_t *);
extern int ctfs_close(vnode_t *, int, int, offset_t, cred_t *,
caller_context_t *);
extern int ctfs_access_dir(vnode_t *, int, int, cred_t *,
caller_context_t *);
extern int ctfs_access_readonly(vnode_t *, int, int, cred_t *,
caller_context_t *);
extern int ctfs_access_readwrite(vnode_t *, int, int, cred_t *,
caller_context_t *);
extern int ctfs_open(vnode_t **, int, cred_t *,
caller_context_t *);
extern vnodeops_t *ctfs_ops_root;
extern vnodeops_t *ctfs_ops_adir;
extern vnodeops_t *ctfs_ops_sym;
extern vnodeops_t *ctfs_ops_tdir;
extern vnodeops_t *ctfs_ops_tmpl;
extern vnodeops_t *ctfs_ops_cdir;
extern vnodeops_t *ctfs_ops_ctl;
extern vnodeops_t *ctfs_ops_stat;
extern vnodeops_t *ctfs_ops_event;
extern vnodeops_t *ctfs_ops_bundle;
extern vnodeops_t *ctfs_ops_latest;
#ifdef __cplusplus
}
#endif
#endif