126b76271a
Resolves: RHEL-58317 Resolves: RHEL-53438 Resolves: RHEL-36576 Resolves: RHEL-54006 Signed-off-by: Tao Liu <ltao@redhat.com>
174 lines
5.6 KiB
Diff
174 lines
5.6 KiB
Diff
From d16ad5df4cd14b148513ab9d5cf0ebcf09d023e0 Mon Sep 17 00:00:00 2001
|
|
From: Andrew Zaborowski <andrew.zaborowski@intel.com>
|
|
Date: Fri, 10 May 2024 18:38:52 -0700
|
|
Subject: [PATCH 22/44] Wrap migrate_irq in a higher level utility function
|
|
|
|
Add migrate_irq_obj and replace existing migrate_irq calls with calls to
|
|
the new function. migrate_irq_obj takes source and destination
|
|
topo_obj's instead of interrupt lists so as to factor out updating of
|
|
the load on the destination cpu and of info->asssigned_obj.
|
|
|
|
Pass NULL as destination to move irq to rebalance_irq_list.
|
|
|
|
Drop the unneeded force_irq_migration.
|
|
---
|
|
irqbalance.c | 4 +---
|
|
irqbalance.h | 1 +
|
|
irqlist.c | 31 +++++++++++++++++++++----------
|
|
placement.c | 24 +++++-------------------
|
|
4 files changed, 28 insertions(+), 32 deletions(-)
|
|
|
|
diff --git a/irqbalance.c b/irqbalance.c
|
|
index 870d7c0..7efbc98 100644
|
|
--- a/irqbalance.c
|
|
+++ b/irqbalance.c
|
|
@@ -253,9 +253,7 @@ void force_rebalance_irq(struct irq_info *info, void *data __attribute__((unused
|
|
if (info->assigned_obj == NULL)
|
|
rebalance_irq_list = g_list_append(rebalance_irq_list, info);
|
|
else
|
|
- migrate_irq(&info->assigned_obj->interrupts, &rebalance_irq_list, info);
|
|
-
|
|
- info->assigned_obj = NULL;
|
|
+ migrate_irq_obj(info->assigned_obj, NULL, info);
|
|
}
|
|
|
|
gboolean handler(gpointer data __attribute__((unused)))
|
|
diff --git a/irqbalance.h b/irqbalance.h
|
|
index 09daa3d..76640dd 100644
|
|
--- a/irqbalance.h
|
|
+++ b/irqbalance.h
|
|
@@ -52,6 +52,7 @@ void dump_workloads(void);
|
|
void sort_irq_list(GList **list);
|
|
void calculate_placement(void);
|
|
void dump_tree(void);
|
|
+void migrate_irq_obj(struct topo_obj *from, struct topo_obj *to, struct irq_info *info);
|
|
|
|
void activate_mappings(void);
|
|
void clear_cpu_tree(void);
|
|
diff --git a/irqlist.c b/irqlist.c
|
|
index 0ba411e..304b1c6 100644
|
|
--- a/irqlist.c
|
|
+++ b/irqlist.c
|
|
@@ -108,9 +108,7 @@ static void move_candidate_irqs(struct irq_info *info, void *data)
|
|
|
|
log(TO_CONSOLE, LOG_INFO, "Selecting irq %d for rebalancing\n", info->irq);
|
|
|
|
- migrate_irq(&info->assigned_obj->interrupts, &rebalance_irq_list, info);
|
|
-
|
|
- info->assigned_obj = NULL;
|
|
+ force_rebalance_irq(info, NULL);
|
|
}
|
|
|
|
static void migrate_overloaded_irqs(struct topo_obj *obj, void *data)
|
|
@@ -146,12 +144,6 @@ static void migrate_overloaded_irqs(struct topo_obj *obj, void *data)
|
|
}
|
|
}
|
|
|
|
-static void force_irq_migration(struct irq_info *info, void *data __attribute__((unused)))
|
|
-{
|
|
- migrate_irq(&info->assigned_obj->interrupts, &rebalance_irq_list, info);
|
|
- info->assigned_obj = NULL;
|
|
-}
|
|
-
|
|
static void clear_powersave_mode(struct topo_obj *obj, void *data __attribute__((unused)))
|
|
{
|
|
obj->powersave_mode = 0;
|
|
@@ -183,7 +175,7 @@ void update_migration_status(void)
|
|
log(TO_ALL, LOG_INFO, "cpu %d entering powersave mode\n", info.powersave->number);
|
|
info.powersave->powersave_mode = 1;
|
|
if (g_list_length(info.powersave->interrupts) > 0)
|
|
- for_each_irq(info.powersave->interrupts, force_irq_migration, NULL);
|
|
+ for_each_irq(info.powersave->interrupts, force_rebalance_irq, NULL);
|
|
} else if ((info.num_over) && (info.num_powersave)) {
|
|
log(TO_ALL, LOG_INFO, "Load average increasing, re-enabling all cpus for irq balancing\n");
|
|
for_each_object(cpus, clear_powersave_mode, NULL);
|
|
@@ -205,3 +197,22 @@ void dump_workloads(void)
|
|
for_each_irq(NULL, dump_workload, NULL);
|
|
}
|
|
|
|
+void migrate_irq_obj(struct topo_obj *from, struct topo_obj *to, struct irq_info *info)
|
|
+{
|
|
+
|
|
+ GList **from_list;
|
|
+ GList **to_list;
|
|
+
|
|
+ if (!from)
|
|
+ from = info->assigned_obj;
|
|
+
|
|
+ from_list = from ? &from->interrupts : &rebalance_irq_list;
|
|
+ to_list = to ? &to->interrupts : &rebalance_irq_list;
|
|
+
|
|
+ migrate_irq(from_list, to_list, info);
|
|
+
|
|
+ if (to)
|
|
+ to->load += info->load + 1;
|
|
+
|
|
+ info->assigned_obj = to;
|
|
+}
|
|
diff --git a/placement.c b/placement.c
|
|
index dea7c23..f156e0e 100644
|
|
--- a/placement.c
|
|
+++ b/placement.c
|
|
@@ -74,7 +74,6 @@ static void find_best_object_for_irq(struct irq_info *info, void *data)
|
|
{
|
|
struct obj_placement place;
|
|
struct topo_obj *d = data;
|
|
- struct topo_obj *asign;
|
|
|
|
if (!info->moved)
|
|
return;
|
|
@@ -107,13 +106,8 @@ static void find_best_object_for_irq(struct irq_info *info, void *data)
|
|
|
|
for_each_object(d->children, find_best_object, &place);
|
|
|
|
- asign = place.best;
|
|
-
|
|
- if (asign) {
|
|
- migrate_irq(&d->interrupts, &asign->interrupts, info);
|
|
- info->assigned_obj = asign;
|
|
- asign->load += info->load;
|
|
- }
|
|
+ if (place.best)
|
|
+ migrate_irq_obj(d, place.best, info);
|
|
}
|
|
|
|
static void place_irq_in_object(struct topo_obj *d, void *data __attribute__((unused)))
|
|
@@ -125,7 +119,6 @@ static void place_irq_in_object(struct topo_obj *d, void *data __attribute__((un
|
|
static void place_irq_in_node(struct irq_info *info, void *data __attribute__((unused)))
|
|
{
|
|
struct obj_placement place;
|
|
- struct topo_obj *asign;
|
|
|
|
if ((info->level == BALANCE_NONE) && cpus_empty(banned_cpus))
|
|
return;
|
|
@@ -145,9 +138,7 @@ static void place_irq_in_node(struct irq_info *info, void *data __attribute__((u
|
|
* This irq belongs to a device with a preferred numa node
|
|
* put it on that node
|
|
*/
|
|
- migrate_irq(&rebalance_irq_list, &irq_numa_node(info)->interrupts, info);
|
|
- info->assigned_obj = irq_numa_node(info);
|
|
- irq_numa_node(info)->load += info->load + 1;
|
|
+ migrate_irq_obj(NULL, irq_numa_node(info), info);
|
|
|
|
return;
|
|
}
|
|
@@ -159,13 +150,8 @@ find_placement:
|
|
|
|
for_each_object(numa_nodes, find_best_object, &place);
|
|
|
|
- asign = place.best;
|
|
-
|
|
- if (asign) {
|
|
- migrate_irq(&rebalance_irq_list, &asign->interrupts, info);
|
|
- info->assigned_obj = asign;
|
|
- asign->load += info->load;
|
|
- }
|
|
+ if (place.best)
|
|
+ migrate_irq_obj(NULL, place.best, info);
|
|
}
|
|
|
|
static void validate_irq(struct irq_info *info, void *data)
|
|
--
|
|
2.47.0
|
|
|