Skip to content

Commit 0e98719

Browse files
author
Christoph Hellwig
committed
nvme: simplify the API for getting log pages
Merge nvme_get_log and nvme_get_log_ext into a single helper, which takes a plain nsid instead of the nvme_ns pointer. Also add support for the log specific field while we're at it. Signed-off-by: Christoph Hellwig <[email protected]> Reviewed-by: Keith Busch <[email protected]> Reviewed-by: Sagi Grimberg <[email protected]> Reviewed-by: Martin K. Petersen <[email protected]> Reviewed-by: Hannes Reinecke <[email protected]> Reviewed-by: Johannes Thumshirn <[email protected]>
1 parent 1a37621 commit 0e98719

File tree

3 files changed

+16
-25
lines changed

3 files changed

+16
-25
lines changed

drivers/nvme/host/core.c

Lines changed: 11 additions & 21 deletions
Original file line numberDiff line numberDiff line change
@@ -2249,21 +2249,16 @@ static int nvme_init_subsystem(struct nvme_ctrl *ctrl, struct nvme_id_ctrl *id)
22492249
return ret;
22502250
}
22512251

2252-
int nvme_get_log_ext(struct nvme_ctrl *ctrl, struct nvme_ns *ns,
2253-
u8 log_page, void *log,
2254-
size_t size, u64 offset)
2252+
int nvme_get_log(struct nvme_ctrl *ctrl, u32 nsid, u8 log_page, u8 lsp,
2253+
void *log, size_t size, u64 offset)
22552254
{
22562255
struct nvme_command c = { };
22572256
unsigned long dwlen = size / 4 - 1;
22582257

22592258
c.get_log_page.opcode = nvme_admin_get_log_page;
2260-
2261-
if (ns)
2262-
c.get_log_page.nsid = cpu_to_le32(ns->head->ns_id);
2263-
else
2264-
c.get_log_page.nsid = cpu_to_le32(NVME_NSID_ALL);
2265-
2259+
c.get_log_page.nsid = cpu_to_le32(nsid);
22662260
c.get_log_page.lid = log_page;
2261+
c.get_log_page.lsp = lsp;
22672262
c.get_log_page.numdl = cpu_to_le16(dwlen & ((1 << 16) - 1));
22682263
c.get_log_page.numdu = cpu_to_le16(dwlen >> 16);
22692264
c.get_log_page.lpol = cpu_to_le32(lower_32_bits(offset));
@@ -2272,12 +2267,6 @@ int nvme_get_log_ext(struct nvme_ctrl *ctrl, struct nvme_ns *ns,
22722267
return nvme_submit_sync_cmd(ctrl->admin_q, &c, log, size);
22732268
}
22742269

2275-
static int nvme_get_log(struct nvme_ctrl *ctrl, u8 log_page, void *log,
2276-
size_t size)
2277-
{
2278-
return nvme_get_log_ext(ctrl, NULL, log_page, log, size, 0);
2279-
}
2280-
22812270
static int nvme_get_effects_log(struct nvme_ctrl *ctrl)
22822271
{
22832272
int ret;
@@ -2288,8 +2277,8 @@ static int nvme_get_effects_log(struct nvme_ctrl *ctrl)
22882277
if (!ctrl->effects)
22892278
return 0;
22902279

2291-
ret = nvme_get_log(ctrl, NVME_LOG_CMD_EFFECTS, ctrl->effects,
2292-
sizeof(*ctrl->effects));
2280+
ret = nvme_get_log(ctrl, NVME_NSID_ALL, NVME_LOG_CMD_EFFECTS, 0,
2281+
ctrl->effects, sizeof(*ctrl->effects), 0);
22932282
if (ret) {
22942283
kfree(ctrl->effects);
22952284
ctrl->effects = NULL;
@@ -3208,7 +3197,8 @@ static void nvme_clear_changed_ns_log(struct nvme_ctrl *ctrl)
32083197
* raced with us in reading the log page, which could cause us to miss
32093198
* updates.
32103199
*/
3211-
error = nvme_get_log(ctrl, NVME_LOG_CHANGED_NS, log, log_size);
3200+
error = nvme_get_log(ctrl, NVME_NSID_ALL, NVME_LOG_CHANGED_NS, 0, log,
3201+
log_size, 0);
32123202
if (error)
32133203
dev_warn(ctrl->device,
32143204
"reading changed ns log failed: %d\n", error);
@@ -3325,9 +3315,9 @@ static void nvme_get_fw_slot_info(struct nvme_ctrl *ctrl)
33253315
if (!log)
33263316
return;
33273317

3328-
if (nvme_get_log(ctrl, NVME_LOG_FW_SLOT, log, sizeof(*log)))
3329-
dev_warn(ctrl->device,
3330-
"Get FW SLOT INFO log error\n");
3318+
if (nvme_get_log(ctrl, NVME_NSID_ALL, 0, NVME_LOG_FW_SLOT, log,
3319+
sizeof(*log), 0))
3320+
dev_warn(ctrl->device, "Get FW SLOT INFO log error\n");
33313321
kfree(log);
33323322
}
33333323

drivers/nvme/host/lightnvm.c

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -604,8 +604,9 @@ static int nvme_nvm_get_chk_meta(struct nvm_dev *ndev,
604604
while (left) {
605605
len = min_t(unsigned int, left, max_len);
606606

607-
ret = nvme_get_log_ext(ctrl, ns, NVME_NVM_LOG_REPORT_CHUNK,
608-
dev_meta, len, offset);
607+
ret = nvme_get_log(ctrl, ns->head->ns_id,
608+
NVME_NVM_LOG_REPORT_CHUNK, 0, dev_meta, len,
609+
offset);
609610
if (ret) {
610611
dev_err(ctrl->device, "Get REPORT CHUNK log error\n");
611612
break;

drivers/nvme/host/nvme.h

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -443,8 +443,8 @@ int nvme_reset_ctrl_sync(struct nvme_ctrl *ctrl);
443443
int nvme_delete_ctrl(struct nvme_ctrl *ctrl);
444444
int nvme_delete_ctrl_sync(struct nvme_ctrl *ctrl);
445445

446-
int nvme_get_log_ext(struct nvme_ctrl *ctrl, struct nvme_ns *ns,
447-
u8 log_page, void *log, size_t size, u64 offset);
446+
int nvme_get_log(struct nvme_ctrl *ctrl, u32 nsid, u8 log_page, u8 lsp,
447+
void *log, size_t size, u64 offset);
448448

449449
extern const struct attribute_group nvme_ns_id_attr_group;
450450
extern const struct block_device_operations nvme_ns_head_ops;

0 commit comments

Comments
 (0)