From 9a1fd29a82c9762c3676f613075d44a8d1fcbe82 Mon Sep 17 00:00:00 2001 From: Robin Jarry <rjarry@redhat.com> Date: Wed, 12 Jul 2023 08:59:45 +0200 Subject: [PATCH 5/7] activate_mapping: report error reason If a given IRQ affinity cannot be set, include strerror in the warning message. Fixes: https://bugzilla.redhat.com/show_bug.cgi?id=2184735 Signed-off-by: Robin Jarry <rjarry@redhat.com> --- activate.c | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) diff --git a/activate.c b/activate.c index a4112e0..4418cda 100644 --- a/activate.c +++ b/activate.c @@ -25,10 +25,12 @@ * of interrupts to the kernel. */ #include "config.h" +#include <errno.h> #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <stdint.h> +#include <string.h> #include "irqbalance.h" @@ -48,7 +50,7 @@ static void activate_mapping(struct irq_info *info, void *data __attribute__((un { char buf[PATH_MAX]; FILE *file; - int ret = 0; + int errsave, ret; cpumask_t applied_mask; /* @@ -79,11 +81,18 @@ static void activate_mapping(struct irq_info *info, void *data __attribute__((un cpumask_scnprintf(buf, PATH_MAX, applied_mask); ret = fprintf(file, "%s", buf); - if (fclose(file) || ret < 0) + errsave = errno; + if (fclose(file)) { + errsave = errno; + goto error; + } + if (ret < 0) goto error; info->moved = 0; /*migration is done*/ error: - log(TO_ALL, LOG_WARNING, "cannot change IRQ %i affinity, will never try again\n", info->irq); + log(TO_ALL, LOG_WARNING, + "Cannot change IRQ %i affinity: %s. Will never try again.\n", + info->irq, strerror(errsave)); info->flags |= IRQ_FLAG_AFFINITY_UNMANAGED; } -- 2.40.1