[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v1 3/9] Add init and realize funciontality for RDT device.
From: |
Hendrik Wuethrich |
Subject: |
[PATCH v1 3/9] Add init and realize funciontality for RDT device. |
Date: |
Fri, 19 Jul 2024 16:29:23 +0000 |
From: Hendrik Wüthrich <whendrik@google.com>
Add code to initialize all necessary state for the RDT device.
Signed-off-by: Hendrik Wüthrich <whendrik@google.com>
---
hw/i386/rdt.c | 28 ++++++++++++++++++++++++++++
1 file changed, 28 insertions(+)
diff --git a/hw/i386/rdt.c b/hw/i386/rdt.c
index cf246ab835..259dafc963 100644
--- a/hw/i386/rdt.c
+++ b/hw/i386/rdt.c
@@ -62,10 +62,38 @@ static void rdt_init(Object *obj)
static void rdt_realize(DeviceState *dev, Error **errp)
{
+ CPUState *cs = first_cpu;
+
+ RDTState *rdtDev = RDT(dev);
+ rdtDev->rdtInstances = g_array_new(false, true, sizeof(RDTStateInstance));
+ g_array_set_size(rdtDev->rdtInstances, cs->nr_cores);
+ CPU_FOREACH(cs) {
+ RDTStateInstance *rdt = &g_array_index(rdtDev->rdtInstances,
RDTStateInstance, cs->cpu_index);
+
+ X86CPU *cpu = X86_CPU(cs);
+ rdt->rdtstate = rdtDev;
+ cpu->rdt = rdt;
+
+ rdt->monitors = g_array_new(false, true, sizeof(RDTMonitor));
+ rdt->rdtstate->allocations = g_array_new(false, true,
sizeof(RDTAllocation));
+
+ g_array_set_size(rdt->monitors, rdtDev->rmids);
+ g_array_set_size(rdt->rdtstate->allocations, rdtDev->rmids);
+ }
}
static void rdt_finalize(Object *obj)
{
+ CPUState *cs;
+ RDTState *rdt = RDT(obj);
+
+ CPU_FOREACH(cs) {
+ RDTStateInstance *rdtInstance = &g_array_index(rdt->rdtInstances,
RDTStateInstance, cs->cpu_index);
+ g_array_free(rdtInstance->monitors, true);
+ g_array_free(rdtInstance->rdtstate->allocations, true);
+ }
+
+ g_array_free(rdt->rdtInstances, true);
}
static void rdt_class_init(ObjectClass *klass, void *data)
--
2.45.2.1089.g2a221341d9-goog
- [PATCH v1 2/9] Add state for RDT device., (continued)
- [PATCH v1 2/9] Add state for RDT device., Hendrik Wuethrich, 2024/07/19
- [PATCH v1 9/9] Adjust level for RDT on full_cpuid_auto_level, Hendrik Wuethrich, 2024/07/19
- [PATCH v1 4/9] Add RDT functionality, Hendrik Wuethrich, 2024/07/19
- [PATCH v1 8/9] Adjust CPUID level for RDT features, Hendrik Wuethrich, 2024/07/19
- [PATCH v1 1/9] Add Intel RDT device to config., Hendrik Wuethrich, 2024/07/19
- [PATCH v1 6/9] Add CPUID enumeration for RDT, Hendrik Wuethrich, 2024/07/19
- [PATCH v1 3/9] Add init and realize funciontality for RDT device.,
Hendrik Wuethrich <=
- [PATCH v1 7/9] Add RDT feature flags., Hendrik Wuethrich, 2024/07/19