Blame SOURCES/0036-libcxl-add-support-for-the-Identify-Device-command.patch

26ccd9
From 244862cbbfecda9b6b638eccaca526f4daba2795 Mon Sep 17 00:00:00 2001
26ccd9
From: Vishal Verma <vishal.l.verma@intel.com>
26ccd9
Date: Thu, 7 Oct 2021 02:21:28 -0600
26ccd9
Subject: [PATCH 036/217] libcxl: add support for the 'Identify Device' command
26ccd9
26ccd9
Add APIs to allocate and send an 'Identify Device' command, and
26ccd9
accessors to retrieve some of the fields from the resulting data.
26ccd9
26ccd9
Only add a handful accessor functions; more can be added as the need
26ccd9
arises. The fields added are fw_revision, partition_align, and
26ccd9
lsa_size.
26ccd9
26ccd9
Cc: Ben Widawsky <ben.widawsky@intel.com>
26ccd9
Cc: Dan Williams <dan.j.williams@intel.com>
26ccd9
Reviewed-by: Dan Williams <dan.j.williams@intel.com>
26ccd9
Signed-off-by: Vishal Verma <vishal.l.verma@intel.com>
26ccd9
---
26ccd9
 cxl/lib/libcxl.c   | 52 ++++++++++++++++++++++++++++++++++++++++++++++
26ccd9
 cxl/lib/libcxl.sym |  4 ++++
26ccd9
 cxl/lib/private.h  | 19 +++++++++++++++++
26ccd9
 cxl/libcxl.h       |  4 ++++
26ccd9
 4 files changed, 79 insertions(+)
26ccd9
26ccd9
diff --git a/cxl/lib/libcxl.c b/cxl/lib/libcxl.c
26ccd9
index 727d599..ed21670 100644
26ccd9
--- a/cxl/lib/libcxl.c
26ccd9
+++ b/cxl/lib/libcxl.c
26ccd9
@@ -13,7 +13,10 @@
26ccd9
 #include <sys/sysmacros.h>
26ccd9
 #include <uuid/uuid.h>
26ccd9
 #include <ccan/list/list.h>
26ccd9
+#include <ccan/endian/endian.h>
26ccd9
+#include <ccan/minmax/minmax.h>
26ccd9
 #include <ccan/array_size/array_size.h>
26ccd9
+#include <ccan/short_types/short_types.h>
26ccd9
 
26ccd9
 #include <util/log.h>
26ccd9
 #include <util/size.h>
26ccd9
@@ -674,6 +677,55 @@ CXL_EXPORT const char *cxl_cmd_get_devname(struct cxl_cmd *cmd)
26ccd9
 	return cxl_memdev_get_devname(cmd->memdev);
26ccd9
 }
26ccd9
 
26ccd9
+CXL_EXPORT struct cxl_cmd *cxl_cmd_new_identify(struct cxl_memdev *memdev)
26ccd9
+{
26ccd9
+	return cxl_cmd_new_generic(memdev, CXL_MEM_COMMAND_ID_IDENTIFY);
26ccd9
+}
26ccd9
+
26ccd9
+CXL_EXPORT int cxl_cmd_identify_get_fw_rev(struct cxl_cmd *cmd, char *fw_rev,
26ccd9
+		int fw_len)
26ccd9
+{
26ccd9
+	struct cxl_cmd_identify *id =
26ccd9
+			(struct cxl_cmd_identify *)cmd->send_cmd->out.payload;
26ccd9
+
26ccd9
+	if (cmd->send_cmd->id != CXL_MEM_COMMAND_ID_IDENTIFY)
26ccd9
+		return -EINVAL;
26ccd9
+	if (cmd->status < 0)
26ccd9
+		return cmd->status;
26ccd9
+
26ccd9
+	if (fw_len > 0)
26ccd9
+		memcpy(fw_rev, id->fw_revision,
26ccd9
+			min(fw_len, CXL_CMD_IDENTIFY_FW_REV_LENGTH));
26ccd9
+	return 0;
26ccd9
+}
26ccd9
+
26ccd9
+CXL_EXPORT unsigned long long cxl_cmd_identify_get_partition_align(
26ccd9
+		struct cxl_cmd *cmd)
26ccd9
+{
26ccd9
+	struct cxl_cmd_identify *id =
26ccd9
+			(struct cxl_cmd_identify *)cmd->send_cmd->out.payload;
26ccd9
+
26ccd9
+	if (cmd->send_cmd->id != CXL_MEM_COMMAND_ID_IDENTIFY)
26ccd9
+		return -EINVAL;
26ccd9
+	if (cmd->status < 0)
26ccd9
+		return cmd->status;
26ccd9
+
26ccd9
+	return le64_to_cpu(id->partition_align);
26ccd9
+}
26ccd9
+
26ccd9
+CXL_EXPORT unsigned int cxl_cmd_identify_get_label_size(struct cxl_cmd *cmd)
26ccd9
+{
26ccd9
+	struct cxl_cmd_identify *id =
26ccd9
+			(struct cxl_cmd_identify *)cmd->send_cmd->out.payload;
26ccd9
+
26ccd9
+	if (cmd->send_cmd->id != CXL_MEM_COMMAND_ID_IDENTIFY)
26ccd9
+		return -EINVAL;
26ccd9
+	if (cmd->status < 0)
26ccd9
+		return cmd->status;
26ccd9
+
26ccd9
+	return le32_to_cpu(id->lsa_size);
26ccd9
+}
26ccd9
+
26ccd9
 CXL_EXPORT struct cxl_cmd *cxl_cmd_new_raw(struct cxl_memdev *memdev,
26ccd9
 		int opcode)
26ccd9
 {
26ccd9
diff --git a/cxl/lib/libcxl.sym b/cxl/lib/libcxl.sym
26ccd9
index 3900f90..1dc45f4 100644
26ccd9
--- a/cxl/lib/libcxl.sym
26ccd9
+++ b/cxl/lib/libcxl.sym
26ccd9
@@ -29,6 +29,10 @@ global:
26ccd9
 	cxl_cmd_submit;
26ccd9
 	cxl_cmd_get_mbox_status;
26ccd9
 	cxl_cmd_get_out_size;
26ccd9
+	cxl_cmd_new_identify;
26ccd9
+	cxl_cmd_identify_get_fw_rev;
26ccd9
+	cxl_cmd_identify_get_partition_align;
26ccd9
+	cxl_cmd_identify_get_label_size;
26ccd9
 local:
26ccd9
         *;
26ccd9
 };
26ccd9
diff --git a/cxl/lib/private.h b/cxl/lib/private.h
26ccd9
index 87ca17e..3273f21 100644
26ccd9
--- a/cxl/lib/private.h
26ccd9
+++ b/cxl/lib/private.h
26ccd9
@@ -54,6 +54,25 @@ struct cxl_cmd {
26ccd9
 	int status;
26ccd9
 };
26ccd9
 
26ccd9
+#define CXL_CMD_IDENTIFY_FW_REV_LENGTH 0x10
26ccd9
+
26ccd9
+struct cxl_cmd_identify {
26ccd9
+	char fw_revision[CXL_CMD_IDENTIFY_FW_REV_LENGTH];
26ccd9
+	le64 total_capacity;
26ccd9
+	le64 volatile_capacity;
26ccd9
+	le64 persistent_capacity;
26ccd9
+	le64 partition_align;
26ccd9
+	le16 info_event_log_size;
26ccd9
+	le16 warning_event_log_size;
26ccd9
+	le16 failure_event_log_size;
26ccd9
+	le16 fatal_event_log_size;
26ccd9
+	le32 lsa_size;
26ccd9
+	u8 poison_list_max_mer[3];
26ccd9
+	le16 inject_poison_limit;
26ccd9
+	u8 poison_caps;
26ccd9
+	u8 qos_telemetry_caps;
26ccd9
+} __attribute__((packed));
26ccd9
+
26ccd9
 static inline int check_kmod(struct kmod_ctx *kmod_ctx)
26ccd9
 {
26ccd9
 	return kmod_ctx ? 0 : -ENXIO;
26ccd9
diff --git a/cxl/libcxl.h b/cxl/libcxl.h
26ccd9
index 6e87b80..0f2d5e9 100644
26ccd9
--- a/cxl/libcxl.h
26ccd9
+++ b/cxl/libcxl.h
26ccd9
@@ -58,6 +58,10 @@ void cxl_cmd_unref(struct cxl_cmd *cmd);
26ccd9
 int cxl_cmd_submit(struct cxl_cmd *cmd);
26ccd9
 int cxl_cmd_get_mbox_status(struct cxl_cmd *cmd);
26ccd9
 int cxl_cmd_get_out_size(struct cxl_cmd *cmd);
26ccd9
+struct cxl_cmd *cxl_cmd_new_identify(struct cxl_memdev *memdev);
26ccd9
+int cxl_cmd_identify_get_fw_rev(struct cxl_cmd *cmd, char *fw_rev, int fw_len);
26ccd9
+unsigned long long cxl_cmd_identify_get_partition_align(struct cxl_cmd *cmd);
26ccd9
+unsigned int cxl_cmd_identify_get_label_size(struct cxl_cmd *cmd);
26ccd9
 
26ccd9
 #ifdef __cplusplus
26ccd9
 } /* extern "C" */
26ccd9
-- 
26ccd9
2.27.0
26ccd9