/* SPDX-License-Identifier: GPL-2.0 */ #ifndef _FS_FUSE_DEV_H #define _FS_FUSE_DEV_H #include /** Maximum number of outstanding background requests */ #define FUSE_DEFAULT_MAX_BACKGROUND 12 struct fuse_conn; struct fuse_chan; struct fuse_dev; struct fuse_args; struct fuse_copy_state; struct fuse_backing_map; struct file; struct folio; enum fuse_notify_code; struct fuse_chan_param { unsigned int minor; unsigned int max_write; unsigned int max_pages; }; struct fuse_chan *fuse_chan_new(void); struct fuse_chan *fuse_dev_chan_new(void); void fuse_chan_release(struct fuse_chan *fch); void fuse_chan_free(struct fuse_chan *fch); unsigned int fuse_chan_num_background(struct fuse_chan *fch); unsigned int fuse_chan_max_background(struct fuse_chan *fch); void fuse_chan_max_background_set(struct fuse_chan *fch, unsigned int val); unsigned int fuse_chan_num_waiting(struct fuse_chan *fch); void fuse_chan_set_fc(struct fuse_chan *fch, struct fuse_conn *fc); void fuse_chan_set_initialized(struct fuse_chan *fch, struct fuse_chan_param *param); void fuse_chan_io_uring_enable(struct fuse_chan *fch); ssize_t fuse_chan_send(struct fuse_chan *fch, struct fuse_args *args); int fuse_chan_send_bg(struct fuse_chan *fch, struct fuse_args *args, gfp_t gfp_flags); int fuse_chan_send_notify_reply(struct fuse_chan *fch, struct fuse_args *args, u64 unique); void fuse_chan_resend(struct fuse_chan *fch); struct fuse_forget_link *fuse_alloc_forget(void); void fuse_chan_queue_forget(struct fuse_chan *fch, struct fuse_forget_link *forget, u64 nodeid, u64 nlookup); DEFINE_FREE(fuse_chan_free, struct fuse_chan *, if (_T) fuse_chan_free(_T)) /** * Initialize the client device */ int fuse_dev_init(void); /** * Cleanup the client device */ void fuse_dev_cleanup(void); void fuse_dev_install(struct fuse_dev *fud, struct fuse_chan *fch); bool fuse_dev_verify(struct fuse_dev *fud, struct fuse_chan *fch); void fuse_dev_put(struct fuse_dev *fud); bool fuse_dev_is_installed(struct fuse_dev *fud); bool fuse_dev_is_sync_init(struct fuse_dev *fud); struct fuse_dev *fuse_dev_grab(struct file *file); void fuse_init_server_timeout(struct fuse_chan *fch, unsigned int timeout); /* Abort all requests */ void fuse_chan_abort(struct fuse_chan *fch, bool abort_with_err); void fuse_chan_wait_aborted(struct fuse_chan *fch); /** * Acquire reference to fuse_conn */ struct fuse_conn *fuse_conn_get(struct fuse_conn *fc); /** * Release reference to fuse_conn */ void fuse_conn_put(struct fuse_conn *fc); dev_t fuse_conn_get_id(struct fuse_conn *fc); void fuse_end_polls(struct fuse_conn *fc); int fuse_notify(struct fuse_conn *fc, enum fuse_notify_code code, unsigned int size, struct fuse_copy_state *cs); int fuse_backing_open(struct fuse_conn *fc, struct fuse_backing_map *map); int fuse_backing_close(struct fuse_conn *fc, int backing_id); int fuse_copy_one(struct fuse_copy_state *cs, void *val, unsigned size); int fuse_copy_folio(struct fuse_copy_state *cs, struct folio **foliop, unsigned offset, unsigned count, int zeroing); void fuse_copy_finish(struct fuse_copy_state *cs); #ifdef CONFIG_FUSE_IO_URING bool fuse_uring_enabled(void); void fuse_uring_destruct(struct fuse_chan *fch); #else /* CONFIG_FUSE_IO_URING */ static inline bool fuse_uring_enabled(void) { return false; } static inline void fuse_uring_destruct(struct fuse_chan *fch) { } #endif /* CONFIG_FUSE_IO_URING */ #endif /* _FS_FUSE_DEV_H */