Lines Matching +full:ctrl +full:- +full:module
1 /* SPDX-License-Identifier: GPL-2.0 */
4 * Copyright (c) 2015-2016 HGST, a Western Digital Company.
18 /* default is -1: the fail fast mechanism is disabled */
19 #define NVMF_DEF_FAIL_FAST_TMO -1
37 * enum nvmf_parsing_opts - used to define the sysfs parsing options used.
69 * struct nvmf_ctrl_options - Used to hold the options specified
74 * the controller, (-1) means reconnect forever, zero means remove
81 * @traddr: The transport-specific TRADDR field for a port on the
83 * @trsvcid: The transport-specific TRSVCID field for a port on the
85 * @host_traddr: A transport-specific field identifying the NVME host port
87 * @host_iface: A transport-specific field identifying the NVME host
92 * @discovery_nqn: indicates if the subsysnqn is the well-known discovery NQN.
93 * @kato: Keep-alive timeout.
95 * @dhchap_secret: DH-HMAC-CHAP secret
96 * @dhchap_ctrl_secret: DH-HMAC-CHAP controller secret for bi-directional
134 * struct nvmf_transport_ops - used to register a specific
137 * registration entry to its linked-list internal tree.
138 * @module: Transport module reference
140 * @required_opts: sysfs command-line options that must be specified
142 * @allowed_opts: sysfs command-line options that can be specified
144 * @create_ctrl(): function pointer that points to a non-NVMe
145 * implementation-specific fabric technology
155 * modules .bss section so that a pure module_get on @module
160 struct module *module; member
169 nvmf_ctlr_matches_baseopts(struct nvme_ctrl *ctrl, in nvmf_ctlr_matches_baseopts() argument
172 if (ctrl->state == NVME_CTRL_DELETING || in nvmf_ctlr_matches_baseopts()
173 ctrl->state == NVME_CTRL_DELETING_NOIO || in nvmf_ctlr_matches_baseopts()
174 ctrl->state == NVME_CTRL_DEAD || in nvmf_ctlr_matches_baseopts()
175 strcmp(opts->subsysnqn, ctrl->opts->subsysnqn) || in nvmf_ctlr_matches_baseopts()
176 strcmp(opts->host->nqn, ctrl->opts->host->nqn) || in nvmf_ctlr_matches_baseopts()
177 !uuid_equal(&opts->host->id, &ctrl->opts->host->id)) in nvmf_ctlr_matches_baseopts()
183 static inline char *nvmf_ctrl_subsysnqn(struct nvme_ctrl *ctrl) in nvmf_ctrl_subsysnqn() argument
185 if (!ctrl->subsys || in nvmf_ctrl_subsysnqn()
186 !strcmp(ctrl->opts->subsysnqn, NVME_DISC_SUBSYS_NAME)) in nvmf_ctrl_subsysnqn()
187 return ctrl->opts->subsysnqn; in nvmf_ctrl_subsysnqn()
188 return ctrl->subsys->subnqn; in nvmf_ctrl_subsysnqn()
194 nvme_req(rq)->status = NVME_SC_HOST_ABORTED_CMD; in nvmf_complete_timed_out_request()
201 return min(opts->nr_io_queues, num_online_cpus()) + in nvmf_nr_io_queues()
202 min(opts->nr_write_queues, num_online_cpus()) + in nvmf_nr_io_queues()
203 min(opts->nr_poll_queues, num_online_cpus()); in nvmf_nr_io_queues()
206 int nvmf_reg_read32(struct nvme_ctrl *ctrl, u32 off, u32 *val);
207 int nvmf_reg_read64(struct nvme_ctrl *ctrl, u32 off, u64 *val);
208 int nvmf_reg_write32(struct nvme_ctrl *ctrl, u32 off, u32 val);
209 int nvmf_connect_admin_queue(struct nvme_ctrl *ctrl);
210 int nvmf_connect_io_queue(struct nvme_ctrl *ctrl, u16 qid);
214 int nvmf_get_address(struct nvme_ctrl *ctrl, char *buf, int size);
215 bool nvmf_should_reconnect(struct nvme_ctrl *ctrl);
216 bool nvmf_ip_options_match(struct nvme_ctrl *ctrl,
220 void nvmf_map_queues(struct blk_mq_tag_set *set, struct nvme_ctrl *ctrl,