xref: /freebsd/lib/libnvmf/internal.h (revision dd21556857e8d40f66bf5ad54754d9d52669ebf7)
1 /*-
2  * SPDX-License-Identifier: BSD-2-Clause
3  *
4  * Copyright (c) 2022-2024 Chelsio Communications, Inc.
5  * Written by: John Baldwin <jhb@FreeBSD.org>
6  */
7 
8 #ifndef __LIBNVMF_INTERNAL_H__
9 #define __LIBNVMF_INTERNAL_H__
10 
11 #include <sys/nv.h>
12 #include <sys/queue.h>
13 
14 struct nvmf_transport_ops {
15 	/* Association management. */
16 	struct nvmf_association *(*allocate_association)(bool controller,
17 	    const struct nvmf_association_params *params);
18 	void (*update_association)(struct nvmf_association *na,
19 	    const struct nvme_controller_data *cdata);
20 	void (*free_association)(struct nvmf_association *na);
21 
22 	/* Queue pair management. */
23 	struct nvmf_qpair *(*allocate_qpair)(struct nvmf_association *na,
24 	    const struct nvmf_qpair_params *params);
25 	void (*free_qpair)(struct nvmf_qpair *qp);
26 
27 	/* Add params for kernel handoff. */
28 	void (*kernel_handoff_params)(struct nvmf_qpair *qp, nvlist_t *nvl);
29 
30 	/* Capsule operations. */
31 	struct nvmf_capsule *(*allocate_capsule)(struct nvmf_qpair *qp);
32 	void (*free_capsule)(struct nvmf_capsule *nc);
33 	int (*transmit_capsule)(struct nvmf_capsule *nc);
34 	int (*receive_capsule)(struct nvmf_qpair *qp,
35 	    struct nvmf_capsule **ncp);
36 	uint8_t (*validate_command_capsule)(const struct nvmf_capsule *nc);
37 
38 	/* Transferring controller data. */
39 	size_t (*capsule_data_len)(const struct nvmf_capsule *nc);
40 	int (*receive_controller_data)(const struct nvmf_capsule *nc,
41 	    uint32_t data_offset, void *buf, size_t len);
42 	int (*send_controller_data)(const struct nvmf_capsule *nc,
43 	    const void *buf, size_t len);
44 };
45 
46 struct nvmf_association {
47 	struct nvmf_transport_ops *na_ops;
48 	enum nvmf_trtype na_trtype;
49 	bool na_controller;
50 
51 	struct nvmf_association_params na_params;
52 
53 	/* Each qpair holds a reference on an association. */
54 	u_int na_refs;
55 
56 	char *na_last_error;
57 };
58 
59 struct nvmf_qpair {
60 	struct nvmf_association *nq_association;
61 	bool nq_admin;
62 
63 	uint16_t nq_cid;	/* host only */
64 
65 	/*
66 	 * Queue sizes.  This assumes the same size for both the
67 	 * completion and submission queues within a pair.
68 	 */
69 	u_int	nq_qsize;
70 
71 	/* Flow control management for submission queues. */
72 	bool nq_flow_control;
73 	uint16_t nq_sqhd;
74 	uint16_t nq_sqtail;	/* host only */
75 
76 	/* Value in response to/from CONNECT. */
77 	uint16_t nq_cntlid;
78 
79 	uint32_t nq_kato;	/* valid on admin queue only */
80 
81 	TAILQ_HEAD(, nvmf_capsule) nq_rx_capsules;
82 };
83 
84 struct nvmf_capsule {
85 	struct nvmf_qpair *nc_qpair;
86 
87 	/* Either a SQE or CQE. */
88 	union {
89 		struct nvme_command nc_sqe;
90 		struct nvme_completion nc_cqe;
91 	};
92 	int	nc_qe_len;
93 
94 	/*
95 	 * Is SQHD in received capsule valid?  False for locally-
96 	 * synthesized responses.
97 	 */
98 	bool	nc_sqhd_valid;
99 
100 	/* Data buffer. */
101 	bool	nc_send_data;
102 	void	*nc_data;
103 	size_t	nc_data_len;
104 
105 	TAILQ_ENTRY(nvmf_capsule) nc_link;
106 };
107 
108 extern struct nvmf_transport_ops tcp_ops;
109 
110 void	na_clear_error(struct nvmf_association *na);
111 void	na_error(struct nvmf_association *na, const char *fmt, ...);
112 
113 int	nvmf_kernel_handoff_params(struct nvmf_qpair *qp, nvlist_t **nvlp);
114 int	nvmf_pack_ioc_nvlist(struct nvmf_ioc_nv *nv, nvlist_t *nvl);
115 
116 #endif /* !__LIBNVMF_INTERNAL_H__ */
117