nvmf: Add a request.h/c
Only move nvmf_request definitions from nvmf_internal.h for now. Subsequent patches will move more. Change-Id: If47472542515fd050cc78d95540eb25beee59d2a Signed-off-by: Ben Walker <benjamin.walker@intel.com>
This commit is contained in:
parent
631f5f27ac
commit
eb705f0da1
@ -38,6 +38,6 @@ LIBNAME = nvmf
|
|||||||
C_SRCS = nvmf_admin_cmd.c nvmf_io_cmd.c \
|
C_SRCS = nvmf_admin_cmd.c nvmf_io_cmd.c \
|
||||||
rdma.c port.c conn.c controller.c \
|
rdma.c port.c conn.c controller.c \
|
||||||
host.c subsystem_grp.c conf.c \
|
host.c subsystem_grp.c conf.c \
|
||||||
nvmf.c session.c
|
nvmf.c request.c session.c
|
||||||
|
|
||||||
include $(SPDK_ROOT_DIR)/mk/spdk.lib.mk
|
include $(SPDK_ROOT_DIR)/mk/spdk.lib.mk
|
||||||
|
@ -49,6 +49,7 @@
|
|||||||
#include "spdk/nvmf_spec.h"
|
#include "spdk/nvmf_spec.h"
|
||||||
#include "conn.h"
|
#include "conn.h"
|
||||||
#include "rdma.h"
|
#include "rdma.h"
|
||||||
|
#include "request.h"
|
||||||
#include "session.h"
|
#include "session.h"
|
||||||
#include "spdk/queue.h"
|
#include "spdk/queue.h"
|
||||||
#include "spdk/log.h"
|
#include "spdk/log.h"
|
||||||
|
@ -78,45 +78,8 @@
|
|||||||
#define TRACE_NVMF_LIB_COMPLETE SPDK_TPOINT_ID(TRACE_GROUP_NVMF, 0x7)
|
#define TRACE_NVMF_LIB_COMPLETE SPDK_TPOINT_ID(TRACE_GROUP_NVMF, 0x7)
|
||||||
#define TRACE_NVMF_IO_COMPLETE SPDK_TPOINT_ID(TRACE_GROUP_NVMF, 0x8)
|
#define TRACE_NVMF_IO_COMPLETE SPDK_TPOINT_ID(TRACE_GROUP_NVMF, 0x8)
|
||||||
|
|
||||||
union nvmf_h2c_msg {
|
|
||||||
struct spdk_nvmf_capsule_cmd nvmf_cmd;
|
|
||||||
struct spdk_nvme_cmd nvme_cmd;
|
|
||||||
struct spdk_nvmf_fabric_prop_set_cmd prop_set_cmd;
|
|
||||||
struct spdk_nvmf_fabric_prop_get_cmd prop_get_cmd;
|
|
||||||
struct spdk_nvmf_fabric_connect_cmd connect_cmd;
|
|
||||||
};
|
|
||||||
SPDK_STATIC_ASSERT(sizeof(union nvmf_h2c_msg) == 64, "Incorrect size");
|
|
||||||
|
|
||||||
union nvmf_c2h_msg {
|
|
||||||
struct spdk_nvmf_capsule_rsp nvmf_rsp;
|
|
||||||
struct spdk_nvme_cpl nvme_cpl;
|
|
||||||
struct spdk_nvmf_fabric_prop_set_rsp prop_set_rsp;
|
|
||||||
struct spdk_nvmf_fabric_prop_get_rsp prop_get_rsp;
|
|
||||||
struct spdk_nvmf_fabric_connect_rsp connect_rsp;
|
|
||||||
};
|
|
||||||
SPDK_STATIC_ASSERT(sizeof(union nvmf_c2h_msg) == 16, "Incorrect size");
|
|
||||||
|
|
||||||
#define NVMF_H2C_MAX_MSG (sizeof(union nvmf_h2c_msg))
|
|
||||||
#define NVMF_C2H_MAX_MSG (sizeof(union nvmf_c2h_msg))
|
|
||||||
|
|
||||||
#define NVMF_CNTLID_SUBS_SHIFT 8
|
#define NVMF_CNTLID_SUBS_SHIFT 8
|
||||||
|
|
||||||
struct nvmf_request {
|
|
||||||
struct nvmf_session *session;
|
|
||||||
struct nvme_qp_tx_desc *tx_desc;
|
|
||||||
struct nvme_qp_rx_desc *rx_desc;
|
|
||||||
uint16_t cid; /* command identifier */
|
|
||||||
uint64_t remote_addr;
|
|
||||||
uint32_t rkey;
|
|
||||||
uint32_t length;
|
|
||||||
enum spdk_nvme_data_transfer xfer;
|
|
||||||
void *data;
|
|
||||||
union nvmf_h2c_msg *cmd;
|
|
||||||
union nvmf_c2h_msg *rsp;
|
|
||||||
|
|
||||||
TAILQ_ENTRY(nvmf_request) entries;
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Some NVMe command definitions not provided in the nvme_spec.h file
|
* Some NVMe command definitions not provided in the nvme_spec.h file
|
||||||
*/
|
*/
|
||||||
@ -158,11 +121,6 @@ struct spdk_nvmf_globals {
|
|||||||
uint16_t sin_port;
|
uint16_t sin_port;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
|
||||||
* Send the response and transfer data from controller to host if required.
|
|
||||||
*/
|
|
||||||
int spdk_nvmf_request_complete(struct nvmf_request *req);
|
|
||||||
|
|
||||||
void
|
void
|
||||||
nvmf_complete_cmd(void *rsp, const struct spdk_nvme_cpl *cmp);
|
nvmf_complete_cmd(void *rsp, const struct spdk_nvme_cpl *cmp);
|
||||||
|
|
||||||
|
@ -33,6 +33,7 @@
|
|||||||
|
|
||||||
#include "nvmf.h"
|
#include "nvmf.h"
|
||||||
#include "nvmf_internal.h"
|
#include "nvmf_internal.h"
|
||||||
|
#include "request.h"
|
||||||
#include "session.h"
|
#include "session.h"
|
||||||
#include "subsystem_grp.h"
|
#include "subsystem_grp.h"
|
||||||
#include "spdk/log.h"
|
#include "spdk/log.h"
|
||||||
|
@ -37,6 +37,7 @@
|
|||||||
#include <infiniband/verbs.h>
|
#include <infiniband/verbs.h>
|
||||||
|
|
||||||
#include "nvmf_internal.h"
|
#include "nvmf_internal.h"
|
||||||
|
#include "request.h"
|
||||||
#include "spdk/nvmf_spec.h"
|
#include "spdk/nvmf_spec.h"
|
||||||
|
|
||||||
/* Define the Admin Queue Rx/Tx Descriptors */
|
/* Define the Admin Queue Rx/Tx Descriptors */
|
||||||
|
34
lib/nvmf/request.c
Normal file
34
lib/nvmf/request.c
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
/*-
|
||||||
|
* BSD LICENSE
|
||||||
|
*
|
||||||
|
* Copyright (c) Intel Corporation.
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
*
|
||||||
|
* * Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* * Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in
|
||||||
|
* the documentation and/or other materials provided with the
|
||||||
|
* distribution.
|
||||||
|
* * Neither the name of Intel Corporation nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived
|
||||||
|
* from this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "request.h"
|
82
lib/nvmf/request.h
Normal file
82
lib/nvmf/request.h
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
/*-
|
||||||
|
* BSD LICENSE
|
||||||
|
*
|
||||||
|
* Copyright (c) Intel Corporation.
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
*
|
||||||
|
* * Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* * Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in
|
||||||
|
* the documentation and/or other materials provided with the
|
||||||
|
* distribution.
|
||||||
|
* * Neither the name of Intel Corporation nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived
|
||||||
|
* from this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef NVMF_REQUEST_H
|
||||||
|
#define NVMF_REQUEST_H
|
||||||
|
|
||||||
|
#include "spdk/nvmf_spec.h"
|
||||||
|
#include "spdk/queue.h"
|
||||||
|
|
||||||
|
union nvmf_h2c_msg {
|
||||||
|
struct spdk_nvmf_capsule_cmd nvmf_cmd;
|
||||||
|
struct spdk_nvme_cmd nvme_cmd;
|
||||||
|
struct spdk_nvmf_fabric_prop_set_cmd prop_set_cmd;
|
||||||
|
struct spdk_nvmf_fabric_prop_get_cmd prop_get_cmd;
|
||||||
|
struct spdk_nvmf_fabric_connect_cmd connect_cmd;
|
||||||
|
};
|
||||||
|
SPDK_STATIC_ASSERT(sizeof(union nvmf_h2c_msg) == 64, "Incorrect size");
|
||||||
|
|
||||||
|
union nvmf_c2h_msg {
|
||||||
|
struct spdk_nvmf_capsule_rsp nvmf_rsp;
|
||||||
|
struct spdk_nvme_cpl nvme_cpl;
|
||||||
|
struct spdk_nvmf_fabric_prop_set_rsp prop_set_rsp;
|
||||||
|
struct spdk_nvmf_fabric_prop_get_rsp prop_get_rsp;
|
||||||
|
struct spdk_nvmf_fabric_connect_rsp connect_rsp;
|
||||||
|
};
|
||||||
|
SPDK_STATIC_ASSERT(sizeof(union nvmf_c2h_msg) == 16, "Incorrect size");
|
||||||
|
|
||||||
|
#define NVMF_H2C_MAX_MSG (sizeof(union nvmf_h2c_msg))
|
||||||
|
#define NVMF_C2H_MAX_MSG (sizeof(union nvmf_c2h_msg))
|
||||||
|
|
||||||
|
struct nvmf_request {
|
||||||
|
struct nvmf_session *session;
|
||||||
|
struct nvme_qp_tx_desc *tx_desc;
|
||||||
|
struct nvme_qp_rx_desc *rx_desc;
|
||||||
|
uint16_t cid; /* command identifier */
|
||||||
|
uint64_t remote_addr;
|
||||||
|
uint32_t rkey;
|
||||||
|
uint32_t length;
|
||||||
|
enum spdk_nvme_data_transfer xfer;
|
||||||
|
void *data;
|
||||||
|
union nvmf_h2c_msg *cmd;
|
||||||
|
union nvmf_c2h_msg *rsp;
|
||||||
|
|
||||||
|
TAILQ_ENTRY(nvmf_request) entries;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Send the response and transfer data from controller to host if required.
|
||||||
|
*/
|
||||||
|
int spdk_nvmf_request_complete(struct nvmf_request *req);
|
||||||
|
|
||||||
|
#endif
|
@ -37,6 +37,7 @@
|
|||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
|
|
||||||
|
#include "request.h"
|
||||||
#include "spdk/nvmf_spec.h"
|
#include "spdk/nvmf_spec.h"
|
||||||
#include "spdk/queue.h"
|
#include "spdk/queue.h"
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user