aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/spmi
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2015-09-01 17:33:35 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2015-09-01 17:33:35 -0400
commit17e6b00ac422b49d44a0b8d98402a211f726282d (patch)
treec7e9143030d20625a0bd94e12ddaf9421890c375 /drivers/spmi
parent5e359bf2219d8622eb0931701e45af55db323228 (diff)
parente324c4dc4a5991d5b1171f434884a4026345e4b4 (diff)
Merge branch 'irq-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
Pull irq updates from Thomas Gleixner: "This updated pull request does not contain the last few GIC related patches which were reported to cause a regression. There is a fix available, but I let it breed for a couple of days first. The irq departement provides: - new infrastructure to support non PCI based MSI interrupts - a couple of new irq chip drivers - the usual pile of fixlets and updates to irq chip drivers - preparatory changes for removal of the irq argument from interrupt flow handlers - preparatory changes to remove IRQF_VALID" * 'irq-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (129 commits) irqchip/imx-gpcv2: IMX GPCv2 driver for wakeup sources irqchip: Add bcm2836 interrupt controller for Raspberry Pi 2 irqchip: Add documentation for the bcm2836 interrupt controller irqchip/bcm2835: Add support for being used as a second level controller irqchip/bcm2835: Refactor handle_IRQ() calls out of MAKE_HWIRQ PCI: xilinx: Fix typo in function name irqchip/gic: Ensure gic_cpu_if_up/down() programs correct GIC instance irqchip/gic: Only allow the primary GIC to set the CPU map PCI/MSI: pci-xgene-msi: Consolidate chained IRQ handler install/remove unicore32/irq: Prepare puv3_gpio_handler for irq argument removal tile/pci_gx: Prepare trio_handle_level_irq for irq argument removal m68k/irq: Prepare irq handlers for irq argument removal C6X/megamode-pic: Prepare megamod_irq_cascade for irq argument removal blackfin: Prepare irq handlers for irq argument removal arc/irq: Prepare idu_cascade_isr for irq argument removal sparc/irq: Use access helper irq_data_get_affinity_mask() sparc/irq: Use helper irq_data_get_irq_handler_data() parisc/irq: Use access helper irq_data_get_affinity_mask() mn10300/irq: Use access helper irq_data_get_affinity_mask() irqchip/i8259: Prepare i8259_irq_dispatch for irq argument removal ...
Diffstat (limited to 'drivers/spmi')
-rw-r--r--drivers/spmi/spmi-pmic-arb.c13
1 files changed, 5 insertions, 8 deletions
diff --git a/drivers/spmi/spmi-pmic-arb.c b/drivers/spmi/spmi-pmic-arb.c
index a4d8c043a710..bdfb3c84c3cb 100644
--- a/drivers/spmi/spmi-pmic-arb.c
+++ b/drivers/spmi/spmi-pmic-arb.c
@@ -453,8 +453,8 @@ static void periph_interrupt(struct spmi_pmic_arb_dev *pa, u8 apid)
453 453
454static void pmic_arb_chained_irq(unsigned int irq, struct irq_desc *desc) 454static void pmic_arb_chained_irq(unsigned int irq, struct irq_desc *desc)
455{ 455{
456 struct spmi_pmic_arb_dev *pa = irq_get_handler_data(irq); 456 struct spmi_pmic_arb_dev *pa = irq_desc_get_handler_data(desc);
457 struct irq_chip *chip = irq_get_chip(irq); 457 struct irq_chip *chip = irq_desc_get_chip(desc);
458 void __iomem *intr = pa->intr; 458 void __iomem *intr = pa->intr;
459 int first = pa->min_apid >> 5; 459 int first = pa->min_apid >> 5;
460 int last = pa->max_apid >> 5; 460 int last = pa->max_apid >> 5;
@@ -945,8 +945,7 @@ static int spmi_pmic_arb_probe(struct platform_device *pdev)
945 goto err_put_ctrl; 945 goto err_put_ctrl;
946 } 946 }
947 947
948 irq_set_handler_data(pa->irq, pa); 948 irq_set_chained_handler_and_data(pa->irq, pmic_arb_chained_irq, pa);
949 irq_set_chained_handler(pa->irq, pmic_arb_chained_irq);
950 949
951 err = spmi_controller_add(ctrl); 950 err = spmi_controller_add(ctrl);
952 if (err) 951 if (err)
@@ -955,8 +954,7 @@ static int spmi_pmic_arb_probe(struct platform_device *pdev)
955 return 0; 954 return 0;
956 955
957err_domain_remove: 956err_domain_remove:
958 irq_set_chained_handler(pa->irq, NULL); 957 irq_set_chained_handler_and_data(pa->irq, NULL, NULL);
959 irq_set_handler_data(pa->irq, NULL);
960 irq_domain_remove(pa->domain); 958 irq_domain_remove(pa->domain);
961err_put_ctrl: 959err_put_ctrl:
962 spmi_controller_put(ctrl); 960 spmi_controller_put(ctrl);
@@ -968,8 +966,7 @@ static int spmi_pmic_arb_remove(struct platform_device *pdev)
968 struct spmi_controller *ctrl = platform_get_drvdata(pdev); 966 struct spmi_controller *ctrl = platform_get_drvdata(pdev);
969 struct spmi_pmic_arb_dev *pa = spmi_controller_get_drvdata(ctrl); 967 struct spmi_pmic_arb_dev *pa = spmi_controller_get_drvdata(ctrl);
970 spmi_controller_remove(ctrl); 968 spmi_controller_remove(ctrl);
971 irq_set_chained_handler(pa->irq, NULL); 969 irq_set_chained_handler_and_data(pa->irq, NULL, NULL);
972 irq_set_handler_data(pa->irq, NULL);
973 irq_domain_remove(pa->domain); 970 irq_domain_remove(pa->domain);
974 spmi_controller_put(ctrl); 971 spmi_controller_put(ctrl);
975 return 0; 972 return 0;