[patch 4/5] irqdomain: Revert gfp hackery
From: Thomas Gleixner
Date: Fri Dec 05 2014 - 03:48:59 EST
Reverts: eda7516e1d428 'irqdomain: Correct early allocation of irq
domains with IRQs off'
Now that we distangled the allocations and the enablement of irq
remapping and removed the pointless preempt disabled region from
native_smp_prepare_cpus() we can remove that hackaround
Signed-off-by: Thomas Gleixner <tglx@xxxxxxxxxxxxx>
---
kernel/irq/irqdomain.c | 21 ++-------------------
1 file changed, 2 insertions(+), 19 deletions(-)
Index: tip/kernel/irq/irqdomain.c
===================================================================
--- tip.orig/kernel/irq/irqdomain.c
+++ tip/kernel/irq/irqdomain.c
@@ -46,31 +46,14 @@ struct irq_domain *__irq_domain_add(stru
void *host_data)
{
struct irq_domain *domain;
- gfp_t gfp_flags = GFP_KERNEL;
-
-#ifdef CONFIG_X86
- /*
- * BIG FAT COMMENT: Early initialization paths like enable_IR_x2apic(),
- * for example, call into here with interrupts disabled but then we do
- * allocate memory and can sleep so no-no. A proper fix would be to do
- * x2APIC IR setup in the early irq setup path but it is too late for
- * fixing it this way now, shortly before the merge window.
- *
- * So we do this little brown paper bag, which is temporary! Do not even
- * think of calling irq domain setup code with IRQs disabled. You will
- * get frozen-sharked!
- */
- if (irqs_disabled())
- gfp_flags = GFP_NOFS;
-#endif
domain = kzalloc_node(sizeof(*domain) + (sizeof(unsigned int) * size),
- gfp_flags, of_node_to_nid(of_node));
+ GFP_KERNEL, of_node_to_nid(of_node));
if (WARN_ON(!domain))
return NULL;
/* Fill structure */
- INIT_RADIX_TREE(&domain->revmap_tree, gfp_flags);
+ INIT_RADIX_TREE(&domain->revmap_tree, GFP_KERNEL);
domain->ops = ops;
domain->host_data = host_data;
domain->of_node = of_node_get(of_node);
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/