2022-06-03 19:15:11 +00:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause
|
2020-11-23 15:59:21 +00:00
|
|
|
* Copyright (c) Intel Corporation. All rights reserved.
|
|
|
|
* Copyright (c) 2021 Mellanox Technologies LTD. All rights reserved.
|
2018-06-11 22:13:55 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include "spdk/nvme_ocssd.h"
|
|
|
|
#include "nvme_internal.h"
|
|
|
|
|
2018-05-15 10:36:00 +00:00
|
|
|
bool
|
|
|
|
spdk_nvme_ctrlr_is_ocssd_supported(struct spdk_nvme_ctrlr *ctrlr)
|
|
|
|
{
|
|
|
|
if (ctrlr->quirks & NVME_QUIRK_OCSSD) {
|
2018-10-29 03:18:22 +00:00
|
|
|
/* TODO: There isn't a standardized way to identify Open-Channel SSD
|
|
|
|
* different verdors may have different conditions.
|
|
|
|
*/
|
2018-05-15 10:36:00 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Current QEMU OpenChannel Device needs to check nsdata->vs[0].
|
|
|
|
* Here check nsdata->vs[0] of the first namespace.
|
|
|
|
*/
|
2021-10-27 18:12:59 +00:00
|
|
|
if (ctrlr->cdata.vid == SPDK_PCI_VID_CNEXLABS) {
|
2020-11-23 15:59:21 +00:00
|
|
|
uint32_t nsid = spdk_nvme_ctrlr_get_first_active_ns(ctrlr);
|
2021-10-27 18:12:59 +00:00
|
|
|
struct spdk_nvme_ns *ns;
|
|
|
|
|
|
|
|
if (nsid == 0) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
ns = spdk_nvme_ctrlr_get_ns(ctrlr, nsid);
|
2020-11-23 15:59:21 +00:00
|
|
|
|
|
|
|
if (ns && ns->nsdata.vendor_specific[0] == 0x1) {
|
2018-05-15 10:36:00 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-06-11 22:13:55 +00:00
|
|
|
int
|
|
|
|
spdk_nvme_ocssd_ctrlr_cmd_geometry(struct spdk_nvme_ctrlr *ctrlr, uint32_t nsid,
|
|
|
|
void *payload, uint32_t payload_size,
|
|
|
|
spdk_nvme_cmd_cb cb_fn, void *cb_arg)
|
|
|
|
{
|
|
|
|
struct nvme_request *req;
|
|
|
|
struct spdk_nvme_cmd *cmd;
|
2019-02-15 01:36:48 +00:00
|
|
|
int rc;
|
2018-06-11 22:13:55 +00:00
|
|
|
|
|
|
|
if (!payload || (payload_size != sizeof(struct spdk_ocssd_geometry_data))) {
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
|
|
|
|
nvme_robust_mutex_lock(&ctrlr->ctrlr_lock);
|
|
|
|
req = nvme_allocate_request_user_copy(ctrlr->adminq,
|
|
|
|
payload, payload_size, cb_fn, cb_arg, false);
|
|
|
|
if (req == NULL) {
|
2018-11-20 11:51:59 +00:00
|
|
|
nvme_robust_mutex_unlock(&ctrlr->ctrlr_lock);
|
2018-06-11 22:13:55 +00:00
|
|
|
return -ENOMEM;
|
|
|
|
}
|
|
|
|
|
|
|
|
cmd = &req->cmd;
|
|
|
|
cmd->opc = SPDK_OCSSD_OPC_GEOMETRY;
|
|
|
|
cmd->nsid = nsid;
|
|
|
|
|
2019-02-15 01:36:48 +00:00
|
|
|
rc = nvme_ctrlr_submit_admin_request(ctrlr, req);
|
|
|
|
|
|
|
|
nvme_robust_mutex_unlock(&ctrlr->ctrlr_lock);
|
|
|
|
return rc;
|
2018-06-11 22:13:55 +00:00
|
|
|
}
|