138 lines
4.9 KiB
Diff
138 lines
4.9 KiB
Diff
From d00453667cb972dc2fe1242081d3b39313a6a925 Mon Sep 17 00:00:00 2001
|
||
From: "plai@redhat.com" <plai@redhat.com>
|
||
Date: Thu, 21 May 2020 23:56:52 +0100
|
||
Subject: [PATCH 09/12] hmat acpi: Build Memory Side Cache Information
|
||
Structure(s)
|
||
|
||
RH-Author: plai@redhat.com
|
||
Message-id: <20200521235655.27141-9-plai@redhat.com>
|
||
Patchwork-id: 96741
|
||
O-Subject: [RHEL8.2.1 AV qemu-kvm PATCH 08/11] hmat acpi: Build Memory Side Cache Information Structure(s)
|
||
Bugzilla: 1600217
|
||
RH-Acked-by: Michael S. Tsirkin <mst@redhat.com>
|
||
RH-Acked-by: Igor Mammedov <imammedo@redhat.com>
|
||
RH-Acked-by: Eduardo Habkost <ehabkost@redhat.com>
|
||
|
||
From: Liu Jingqi <jingqi.liu@intel.com>
|
||
|
||
This structure describes memory side cache information for memory
|
||
proximity domains if the memory side cache is present and the
|
||
physical device forms the memory side cache.
|
||
The software could use this information to effectively place
|
||
the data in memory to maximize the performance of the system
|
||
memory that use the memory side cache.
|
||
|
||
Acked-by: Markus Armbruster <armbru@redhat.com>
|
||
Reviewed-by: Igor Mammedov <imammedo@redhat.com>
|
||
Reviewed-by: Daniel Black <daniel@linux.ibm.com>
|
||
Reviewed-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
|
||
Signed-off-by: Liu Jingqi <jingqi.liu@intel.com>
|
||
Signed-off-by: Tao Xu <tao3.xu@intel.com>
|
||
Message-Id: <20191213011929.2520-7-tao3.xu@intel.com>
|
||
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
|
||
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
|
||
(cherry picked from commit a9c2b841af002db6e21e1297c9026b63fc22c875)
|
||
Signed-off-by: Paul Lai <plai@redhat.com>
|
||
Signed-off-by: Danilo C. L. de Paula <ddepaula@redhat.com>
|
||
---
|
||
hw/acpi/hmat.c | 69 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++-
|
||
1 file changed, 68 insertions(+), 1 deletion(-)
|
||
|
||
diff --git a/hw/acpi/hmat.c b/hw/acpi/hmat.c
|
||
index 4635d45..7c24bb5 100644
|
||
--- a/hw/acpi/hmat.c
|
||
+++ b/hw/acpi/hmat.c
|
||
@@ -143,14 +143,62 @@ static void build_hmat_lb(GArray *table_data, HMAT_LB_Info *hmat_lb,
|
||
g_free(entry_list);
|
||
}
|
||
|
||
+/* ACPI 6.3: 5.2.27.5 Memory Side Cache Information Structure: Table 5-147 */
|
||
+static void build_hmat_cache(GArray *table_data, uint8_t total_levels,
|
||
+ NumaHmatCacheOptions *hmat_cache)
|
||
+{
|
||
+ /*
|
||
+ * Cache Attributes: Bits [3:0] – Total Cache Levels
|
||
+ * for this Memory Proximity Domain
|
||
+ */
|
||
+ uint32_t cache_attr = total_levels;
|
||
+
|
||
+ /* Bits [7:4] : Cache Level described in this structure */
|
||
+ cache_attr |= (uint32_t) hmat_cache->level << 4;
|
||
+
|
||
+ /* Bits [11:8] - Cache Associativity */
|
||
+ cache_attr |= (uint32_t) hmat_cache->associativity << 8;
|
||
+
|
||
+ /* Bits [15:12] - Write Policy */
|
||
+ cache_attr |= (uint32_t) hmat_cache->policy << 12;
|
||
+
|
||
+ /* Bits [31:16] - Cache Line size in bytes */
|
||
+ cache_attr |= (uint32_t) hmat_cache->line << 16;
|
||
+
|
||
+ /* Type */
|
||
+ build_append_int_noprefix(table_data, 2, 2);
|
||
+ /* Reserved */
|
||
+ build_append_int_noprefix(table_data, 0, 2);
|
||
+ /* Length */
|
||
+ build_append_int_noprefix(table_data, 32, 4);
|
||
+ /* Proximity Domain for the Memory */
|
||
+ build_append_int_noprefix(table_data, hmat_cache->node_id, 4);
|
||
+ /* Reserved */
|
||
+ build_append_int_noprefix(table_data, 0, 4);
|
||
+ /* Memory Side Cache Size */
|
||
+ build_append_int_noprefix(table_data, hmat_cache->size, 8);
|
||
+ /* Cache Attributes */
|
||
+ build_append_int_noprefix(table_data, cache_attr, 4);
|
||
+ /* Reserved */
|
||
+ build_append_int_noprefix(table_data, 0, 2);
|
||
+ /*
|
||
+ * Number of SMBIOS handles (n)
|
||
+ * Linux kernel uses Memory Side Cache Information Structure
|
||
+ * without SMBIOS entries for now, so set Number of SMBIOS handles
|
||
+ * as 0.
|
||
+ */
|
||
+ build_append_int_noprefix(table_data, 0, 2);
|
||
+}
|
||
+
|
||
/* Build HMAT sub table structures */
|
||
static void hmat_build_table_structs(GArray *table_data, NumaState *numa_state)
|
||
{
|
||
uint16_t flags;
|
||
uint32_t num_initiator = 0;
|
||
uint32_t initiator_list[MAX_NODES];
|
||
- int i, hierarchy, type;
|
||
+ int i, hierarchy, type, cache_level, total_levels;
|
||
HMAT_LB_Info *hmat_lb;
|
||
+ NumaHmatCacheOptions *hmat_cache;
|
||
|
||
for (i = 0; i < numa_state->num_nodes; i++) {
|
||
flags = 0;
|
||
@@ -184,6 +232,25 @@ static void hmat_build_table_structs(GArray *table_data, NumaState *numa_state)
|
||
}
|
||
}
|
||
}
|
||
+
|
||
+ /*
|
||
+ * ACPI 6.3: 5.2.27.5 Memory Side Cache Information Structure:
|
||
+ * Table 5-147
|
||
+ */
|
||
+ for (i = 0; i < numa_state->num_nodes; i++) {
|
||
+ total_levels = 0;
|
||
+ for (cache_level = 1; cache_level < HMAT_LB_LEVELS; cache_level++) {
|
||
+ if (numa_state->hmat_cache[i][cache_level]) {
|
||
+ total_levels++;
|
||
+ }
|
||
+ }
|
||
+ for (cache_level = 0; cache_level <= total_levels; cache_level++) {
|
||
+ hmat_cache = numa_state->hmat_cache[i][cache_level];
|
||
+ if (hmat_cache) {
|
||
+ build_hmat_cache(table_data, total_levels, hmat_cache);
|
||
+ }
|
||
+ }
|
||
+ }
|
||
}
|
||
|
||
void build_hmat(GArray *table_data, BIOSLinker *linker, NumaState *numa_state)
|
||
--
|
||
1.8.3.1
|
||
|