Thread (18 messages) 18 messages, 5 authors, 2026-02-04

Re: [PATCH 1/2] x86/ioapic: Add NMI delivery configuration helper

From: Alexander Graf <graf@amazon.com>
Date: 2026-02-03 10:44:57
Also in: lkml

On 03.02.26 11:08, Thomas Gleixner wrote:
On Mon, Feb 02 2026 at 17:48, Alexander Graf wrote:
quoted
To implement an HPET based NMI watchdog, the HPET code will need to
reconfigure an IOAPIC pin to NMI mode. Add a function that allows driver
code to configure an IOAPIC pin for NMI delivery mode.
A function which violates all layering of the interrupt hierarchy...

Yes, just like the device itself :). The HPET is magical.

Let me try and see whether I can just make the HPET logic require MSI 
(FSB) mode, so it can generate the NMI MSI message itself and post it 
without going through the IOAPIC in the first place. That's probably 
cleaner, more self contained and hence creates less layering violations 
and complexity in the long run.

quoted
+/**
+ * ioapic_set_nmi - Configure an IOAPIC pin for NMI delivery
+ * @gsi: Global System Interrupt number
+ * @broadcast: true to broadcast to all CPUs, false to send to CPU 0 only
+ *
+ * Configures the specified GSI for NMI delivery mode.
+ *
+ * Returns 0 on success, negative error code on failure.
+ */
+int ioapic_set_nmi(u32 gsi, bool broadcast)
+{
+     struct IO_APIC_route_entry entry = { };
+     int ioapic_idx, pin;
+
+     ioapic_idx = mp_find_ioapic(gsi);
+     if (ioapic_idx < 0)
+             return -ENODEV;
+
+     pin = mp_find_ioapic_pin(ioapic_idx, gsi);
+     if (pin < 0)
+             return -ENODEV;
+
+     entry.delivery_mode = APIC_DELIVERY_MODE_NMI;
+     entry.destid_0_7 = broadcast ? 0xFF : boot_cpu_physical_apicid;
+     entry.dest_mode_logical = 0;
+     entry.masked = 0;
+
+     ioapic_write_entry(ioapic_idx, pin, entry);
Q: How is that supposed to work with interrupt remapping?
A: Not at all.

... and yes, hopefully also gets us support for INTR if I manage to find 
the right abstraction.

Thanks a lot for the review!


Alex




Amazon Web Services Development Center Germany GmbH
Tamara-Danz-Str. 13
10243 Berlin
Geschaeftsfuehrung: Christof Hellmis, Andreas Stieger
Eingetragen am Amtsgericht Charlottenburg unter HRB 257764 B
Sitz: Berlin
Ust-ID: DE 365 538 597
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help