Blame SOURCES/0133-libcxl-add-accessors-for-capacity-fields-of-the-IDEN.patch

2eb93d
From 50b9d77232d41a33c2109894ae93ddad877c1747 Mon Sep 17 00:00:00 2001
2eb93d
From: Alison Schofield <alison.schofield@intel.com>
2eb93d
Date: Tue, 22 Feb 2022 11:56:04 -0800
2eb93d
Subject: [PATCH 133/217] libcxl: add accessors for capacity fields of the
2eb93d
 IDENTIFY command
2eb93d
2eb93d
The CXL PMEM provisioning model depends upon the values reported
2eb93d
in the CXL IDENTIFY mailbox command when changing the partitioning
2eb93d
between volatile and persistent capacity.
2eb93d
2eb93d
Add accessors to the libcxl API to retrieve the total, volatile only,
2eb93d
and persistent only capacities from the IDENTIFY command.
2eb93d
2eb93d
The fields are specified in multiples of 256MB per the CXL 2.0 spec.
2eb93d
Use the capacity multiplier to convert the raw data into bytes for user
2eb93d
consumption.
2eb93d
2eb93d
Link: https://lore.kernel.org/r/58dec40b15a68f134466f61421751994735e55c1.1645558189.git.alison.schofield@intel.com
2eb93d
Reviewed-by: Dan Williams <dan.j.williams@intel.com>
2eb93d
Signed-off-by: Alison Schofield <alison.schofield@intel.com>
2eb93d
Signed-off-by: Vishal Verma <vishal.l.verma@intel.com>
2eb93d
---
2eb93d
 cxl/lib/libcxl.c   | 44 ++++++++++++++++++++++++++++++++++++++++++++
2eb93d
 cxl/lib/libcxl.sym |  3 +++
2eb93d
 cxl/libcxl.h       |  3 +++
2eb93d
 3 files changed, 50 insertions(+)
2eb93d
2eb93d
diff --git a/cxl/lib/libcxl.c b/cxl/lib/libcxl.c
2eb93d
index 4557a71..9413384 100644
2eb93d
--- a/cxl/lib/libcxl.c
2eb93d
+++ b/cxl/lib/libcxl.c
2eb93d
@@ -2277,6 +2277,17 @@ CXL_EXPORT struct cxl_cmd *cxl_cmd_new_identify(struct cxl_memdev *memdev)
2eb93d
 	return cxl_cmd_new_generic(memdev, CXL_MEM_COMMAND_ID_IDENTIFY);
2eb93d
 }
2eb93d
 
2eb93d
+static struct cxl_cmd_identify *
2eb93d
+cmd_to_identify(struct cxl_cmd *cmd)
2eb93d
+{
2eb93d
+	if (cxl_cmd_validate_status(cmd, CXL_MEM_COMMAND_ID_IDENTIFY))
2eb93d
+		return NULL;
2eb93d
+
2eb93d
+	if (!cmd)
2eb93d
+		return NULL;
2eb93d
+	return cmd->output_payload;
2eb93d
+}
2eb93d
+
2eb93d
 CXL_EXPORT int cxl_cmd_identify_get_fw_rev(struct cxl_cmd *cmd, char *fw_rev,
2eb93d
 		int fw_len)
2eb93d
 {
2eb93d
@@ -2321,6 +2332,39 @@ CXL_EXPORT unsigned int cxl_cmd_identify_get_label_size(struct cxl_cmd *cmd)
2eb93d
 	return le32_to_cpu(id->lsa_size);
2eb93d
 }
2eb93d
 
2eb93d
+CXL_EXPORT unsigned long long
2eb93d
+cxl_cmd_identify_get_total_size(struct cxl_cmd *cmd)
2eb93d
+{
2eb93d
+	struct cxl_cmd_identify *c;
2eb93d
+
2eb93d
+	c = cmd_to_identify(cmd);
2eb93d
+	if (!c)
2eb93d
+		return ULLONG_MAX;
2eb93d
+	return cxl_capacity_to_bytes(c->total_capacity);
2eb93d
+}
2eb93d
+
2eb93d
+CXL_EXPORT unsigned long long
2eb93d
+cxl_cmd_identify_get_volatile_only_size(struct cxl_cmd *cmd)
2eb93d
+{
2eb93d
+	struct cxl_cmd_identify *c;
2eb93d
+
2eb93d
+	c = cmd_to_identify(cmd);
2eb93d
+	if (!c)
2eb93d
+		return ULLONG_MAX;
2eb93d
+	return cxl_capacity_to_bytes(c->volatile_capacity);
2eb93d
+}
2eb93d
+
2eb93d
+CXL_EXPORT unsigned long long
2eb93d
+cxl_cmd_identify_get_persistent_only_size(struct cxl_cmd *cmd)
2eb93d
+{
2eb93d
+	struct cxl_cmd_identify *c;
2eb93d
+
2eb93d
+	c = cmd_to_identify(cmd);
2eb93d
+	if (!c)
2eb93d
+		return ULLONG_MAX;
2eb93d
+	return cxl_capacity_to_bytes(c->persistent_capacity);
2eb93d
+}
2eb93d
+
2eb93d
 CXL_EXPORT struct cxl_cmd *cxl_cmd_new_raw(struct cxl_memdev *memdev,
2eb93d
 		int opcode)
2eb93d
 {
2eb93d
diff --git a/cxl/lib/libcxl.sym b/cxl/lib/libcxl.sym
2eb93d
index 509e62d..5ac6e9b 100644
2eb93d
--- a/cxl/lib/libcxl.sym
2eb93d
+++ b/cxl/lib/libcxl.sym
2eb93d
@@ -160,4 +160,7 @@ global:
2eb93d
 	cxl_cmd_partition_get_active_persistent_size;
2eb93d
 	cxl_cmd_partition_get_next_volatile_size;
2eb93d
 	cxl_cmd_partition_get_next_persistent_size;
2eb93d
+	cxl_cmd_identify_get_total_size;
2eb93d
+	cxl_cmd_identify_get_volatile_only_size;
2eb93d
+	cxl_cmd_identify_get_persistent_only_size;
2eb93d
 } LIBCXL_1;
2eb93d
diff --git a/cxl/libcxl.h b/cxl/libcxl.h
2eb93d
index 2c0a8d1..6e18e84 100644
2eb93d
--- a/cxl/libcxl.h
2eb93d
+++ b/cxl/libcxl.h
2eb93d
@@ -201,6 +201,9 @@ int cxl_cmd_get_mbox_status(struct cxl_cmd *cmd);
2eb93d
 int cxl_cmd_get_out_size(struct cxl_cmd *cmd);
2eb93d
 struct cxl_cmd *cxl_cmd_new_identify(struct cxl_memdev *memdev);
2eb93d
 int cxl_cmd_identify_get_fw_rev(struct cxl_cmd *cmd, char *fw_rev, int fw_len);
2eb93d
+unsigned long long cxl_cmd_identify_get_total_size(struct cxl_cmd *cmd);
2eb93d
+unsigned long long cxl_cmd_identify_get_volatile_only_size(struct cxl_cmd *cmd);
2eb93d
+unsigned long long cxl_cmd_identify_get_persistent_only_size(struct cxl_cmd *cmd);
2eb93d
 unsigned long long cxl_cmd_identify_get_partition_align(struct cxl_cmd *cmd);
2eb93d
 unsigned int cxl_cmd_identify_get_label_size(struct cxl_cmd *cmd);
2eb93d
 struct cxl_cmd *cxl_cmd_new_get_health_info(struct cxl_memdev *memdev);
2eb93d
-- 
2eb93d
2.27.0
2eb93d