per Intel policy to include file commit date using git cmd below. The policy does not apply to non-Intel (C) notices. git log --follow -C90% --format=%ad --date default <file> | tail -1 and then pull just the 4 digit year from the result. Intel copyrights were not added to files where Intel either had no contribution ot the contribution lacked substance (ie license header updates, formatting changes, etc). Contribution date used "--follow -C95%" to get the most accurate date. Note that several files in this patch didn't end the license/(c) block with a blank comment line so these were added as the vast majority of files do have this last blank line. Simply there for consistency. Signed-off-by: paul luse <paul.e.luse@intel.com> Change-Id: Id5b7ce4f658fe87132f14139ead58d6e285c04d4 Reviewed-on: https://review.spdk.io/gerrit/c/spdk/spdk/+/15192 Tested-by: SPDK CI Jenkins <sys_sgci@intel.com> Reviewed-by: Jim Harris <james.r.harris@intel.com> Reviewed-by: Ben Walker <benjamin.walker@intel.com> Community-CI: Mellanox Build Bot
63 lines
1.8 KiB
C
63 lines
1.8 KiB
C
/* SPDX-License-Identifier: BSD-3-Clause
|
|
* Copyright (C) 2019 Intel Corporation.
|
|
* All rights reserved.
|
|
*/
|
|
|
|
/** \file
|
|
* SPDK cuse
|
|
*/
|
|
|
|
|
|
#ifndef SPDK_NVME_IO_MSG_H_
|
|
#define SPDK_NVME_IO_MSG_H_
|
|
|
|
typedef void (*spdk_nvme_io_msg_fn)(struct spdk_nvme_ctrlr *ctrlr, uint32_t nsid,
|
|
void *arg);
|
|
|
|
struct spdk_nvme_io_msg {
|
|
struct spdk_nvme_ctrlr *ctrlr;
|
|
uint32_t nsid;
|
|
|
|
spdk_nvme_io_msg_fn fn;
|
|
void *arg;
|
|
};
|
|
|
|
struct nvme_io_msg_producer {
|
|
const char *name;
|
|
void (*update)(struct spdk_nvme_ctrlr *ctrlr);
|
|
void (*stop)(struct spdk_nvme_ctrlr *ctrlr);
|
|
STAILQ_ENTRY(nvme_io_msg_producer) link;
|
|
};
|
|
|
|
int nvme_io_msg_send(struct spdk_nvme_ctrlr *ctrlr, uint32_t nsid, spdk_nvme_io_msg_fn fn,
|
|
void *arg);
|
|
|
|
/**
|
|
* Process IO message sent to controller from external module.
|
|
*
|
|
* This call process requests from the ring, send IO to an allocated qpair or
|
|
* admin commands in its context. This call is non-blocking and intended to be
|
|
* polled by SPDK thread to provide safe environment for NVMe request
|
|
* completion sent by external module to controller.
|
|
*
|
|
* The caller must ensure that each controller is polled by only one thread at
|
|
* a time.
|
|
*
|
|
* This function may be called at any point while the controller is attached to
|
|
* the SPDK NVMe driver.
|
|
*
|
|
* \param ctrlr Opaque handle to NVMe controller.
|
|
*
|
|
* \return number of processed external IO messages.
|
|
*/
|
|
int nvme_io_msg_process(struct spdk_nvme_ctrlr *ctrlr);
|
|
|
|
int nvme_io_msg_ctrlr_register(struct spdk_nvme_ctrlr *ctrlr,
|
|
struct nvme_io_msg_producer *io_msg_producer);
|
|
void nvme_io_msg_ctrlr_unregister(struct spdk_nvme_ctrlr *ctrlr,
|
|
struct nvme_io_msg_producer *io_msg_producer);
|
|
void nvme_io_msg_ctrlr_detach(struct spdk_nvme_ctrlr *ctrlr);
|
|
void nvme_io_msg_ctrlr_update(struct spdk_nvme_ctrlr *ctrlr);
|
|
|
|
#endif /* SPDK_NVME_IO_MSG_H_ */
|