lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <1320372728-3235-1-git-send-email-trenn@suse.de>
Date:	Fri,  4 Nov 2011 03:12:08 +0100
From:	Thomas Renninger <trenn@...e.de>
To:	linux-kernel@...r.kernel.org
Cc:	trenn@...e.de, linux-acpi@...r.kernel.org,
	Yinghai Lu <yinghai@...nel.org>,
	"Eric W. Biederman" <ebiederm@...ssion.com>, bjorn.helgaas@...com,
	lenb@...nel.org, stable@...nel.org, Ingo Molnar <mingo@...e.hu>,
	H Peter Anvin <hpa@...or.com>,
	Thomas Gleixner <tglx@...utronix.de>
Subject: [PATCH] PNP ACPI: Use real gsi

From: Yinghai Lu <yinghai@...nel.org>

In 2.6.35 a lot cleanups in this area (not pnp, but x86 ioapic setup) have
been introduced.
On an IBM Xseries (x3850) this caused the machine to freeze around when
the init userspace process is tried to get started.
The reason is that the timer interrupt is not set up correctly on this machine.

I could bisect the issue to one of ioapic cleanups introduced in 2.6.35:
commit a4384df3e24579d6292a1b3b41d500349948f30b

While on this machine the problem was an interrupt timer issue,
there may be other platforms with different interrupt issues relatd to this
problem. Kernel logs with similar IOAPIC errors inside pnpacpi setup might
need this patch:
  pnp 00:04: [io  0x02f8-0x02ff]
  IOAPIC[1]: Invalid reference to IRQ 0
  pnp 00:04: [irq 2]
  pnp 00:04: Plug and Play ACPI device, IDs PNP0501 (active)

Yinghai came up with this patch which fixes the problem for me.
Looks like the bisected commit is correct, but the pnp layer has been
overseen.

Tested-by: Thomas Renninger <trenn@...e.de>
CC: Eric W. Biederman <ebiederm@...ssion.com>
CC: bjorn.helgaas@...com
CC: lenb@...nel.org
CC: stable@...nel.org
CC: Ingo Molnar <mingo@...e.hu>
CC: H Peter Anvin <hpa@...or.com>
CC: Thomas Gleixner <tglx@...utronix.de>
Signed-off-by: Thomas Renninger <trenn@...e.de>
---
 drivers/pnp/pnpacpi/rsparser.c |    8 ++++++++
 1 files changed, 8 insertions(+), 0 deletions(-)

diff --git a/drivers/pnp/pnpacpi/rsparser.c b/drivers/pnp/pnpacpi/rsparser.c
index bbf3edd..dad5da9 100644
--- a/drivers/pnp/pnpacpi/rsparser.c
+++ b/drivers/pnp/pnpacpi/rsparser.c
@@ -106,6 +106,14 @@ static void pnpacpi_parse_allocated_irqresource(struct pnp_dev *dev,
 		return;
 	}
 
+#ifdef CONFIG_X86_IO_APIC
+	/*
+	 * Convert it back to real gsi
+	 */
+	if (acpi_irq_model == ACPI_IRQ_MODEL_IOAPIC)
+		acpi_isa_irq_to_gsi(gsi, &gsi);
+#endif
+
 	/*
 	 * in IO-APIC mode, use overrided attribute. Two reasons:
 	 * 1. BIOS bug in DSDT
-- 
1.7.6.1

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ