aboutsummaryrefslogtreecommitdiffstats
path: root/arch/mips
diff options
context:
space:
mode:
authorDavid Daney <david.daney@cavium.com>2012-07-05 12:12:38 -0400
committerRalf Baechle <ralf@linux-mips.org>2012-07-23 08:54:52 -0400
commita339aef90470cf21debb138f95e22adf143eecca (patch)
tree6683f72573fd4b777f7a99d5359b20756323b9ac /arch/mips
parentf5e08284211b09bc4aa85727a44293c529cfa923 (diff)
MIPS: OCTEON: Consolidate the edge and level irq_chip structures.
We can consolidate octeon_irq_chip_ciu_edge and octeon_irq_chip_ciu as they only differ in the .irq_ack element, and that is unused by the level handler. This gets rid of a bunch of duplicate definitions. Signed-off-by: David Daney <david.daney@cavium.com> Cc: linux-mips@linux-mips.org Patchwork: https://patchwork.linux-mips.org/patch/3931/ Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
Diffstat (limited to 'arch/mips')
-rw-r--r--arch/mips/cavium-octeon/octeon-irq.c30
1 files changed, 2 insertions, 28 deletions
diff --git a/arch/mips/cavium-octeon/octeon-irq.c b/arch/mips/cavium-octeon/octeon-irq.c
index bccbda90f7b7..fac22a89f614 100644
--- a/arch/mips/cavium-octeon/octeon-irq.c
+++ b/arch/mips/cavium-octeon/octeon-irq.c
@@ -729,18 +729,6 @@ static struct irq_chip octeon_irq_chip_ciu_v2 = {
729 .name = "CIU", 729 .name = "CIU",
730 .irq_enable = octeon_irq_ciu_enable_v2, 730 .irq_enable = octeon_irq_ciu_enable_v2,
731 .irq_disable = octeon_irq_ciu_disable_all_v2, 731 .irq_disable = octeon_irq_ciu_disable_all_v2,
732 .irq_mask = octeon_irq_ciu_disable_local_v2,
733 .irq_unmask = octeon_irq_ciu_enable_v2,
734#ifdef CONFIG_SMP
735 .irq_set_affinity = octeon_irq_ciu_set_affinity_v2,
736 .irq_cpu_offline = octeon_irq_cpu_offline_ciu,
737#endif
738};
739
740static struct irq_chip octeon_irq_chip_ciu_edge_v2 = {
741 .name = "CIU-E",
742 .irq_enable = octeon_irq_ciu_enable_v2,
743 .irq_disable = octeon_irq_ciu_disable_all_v2,
744 .irq_ack = octeon_irq_ciu_ack, 732 .irq_ack = octeon_irq_ciu_ack,
745 .irq_mask = octeon_irq_ciu_disable_local_v2, 733 .irq_mask = octeon_irq_ciu_disable_local_v2,
746 .irq_unmask = octeon_irq_ciu_enable_v2, 734 .irq_unmask = octeon_irq_ciu_enable_v2,
@@ -754,19 +742,8 @@ static struct irq_chip octeon_irq_chip_ciu = {
754 .name = "CIU", 742 .name = "CIU",
755 .irq_enable = octeon_irq_ciu_enable, 743 .irq_enable = octeon_irq_ciu_enable,
756 .irq_disable = octeon_irq_ciu_disable_all, 744 .irq_disable = octeon_irq_ciu_disable_all,
757 .irq_mask = octeon_irq_dummy_mask,
758#ifdef CONFIG_SMP
759 .irq_set_affinity = octeon_irq_ciu_set_affinity,
760 .irq_cpu_offline = octeon_irq_cpu_offline_ciu,
761#endif
762};
763
764static struct irq_chip octeon_irq_chip_ciu_edge = {
765 .name = "CIU-E",
766 .irq_enable = octeon_irq_ciu_enable,
767 .irq_disable = octeon_irq_ciu_disable_all,
768 .irq_mask = octeon_irq_dummy_mask,
769 .irq_ack = octeon_irq_ciu_ack, 745 .irq_ack = octeon_irq_ciu_ack,
746 .irq_mask = octeon_irq_dummy_mask,
770#ifdef CONFIG_SMP 747#ifdef CONFIG_SMP
771 .irq_set_affinity = octeon_irq_ciu_set_affinity, 748 .irq_set_affinity = octeon_irq_ciu_set_affinity,
772 .irq_cpu_offline = octeon_irq_cpu_offline_ciu, 749 .irq_cpu_offline = octeon_irq_cpu_offline_ciu,
@@ -993,7 +970,6 @@ static void __init octeon_irq_init_ciu(void)
993{ 970{
994 unsigned int i; 971 unsigned int i;
995 struct irq_chip *chip; 972 struct irq_chip *chip;
996 struct irq_chip *chip_edge;
997 struct irq_chip *chip_mbox; 973 struct irq_chip *chip_mbox;
998 struct irq_chip *chip_wd; 974 struct irq_chip *chip_wd;
999 struct irq_chip *chip_gpio; 975 struct irq_chip *chip_gpio;
@@ -1008,7 +984,6 @@ static void __init octeon_irq_init_ciu(void)
1008 octeon_irq_ip2 = octeon_irq_ip2_v2; 984 octeon_irq_ip2 = octeon_irq_ip2_v2;
1009 octeon_irq_ip3 = octeon_irq_ip3_v2; 985 octeon_irq_ip3 = octeon_irq_ip3_v2;
1010 chip = &octeon_irq_chip_ciu_v2; 986 chip = &octeon_irq_chip_ciu_v2;
1011 chip_edge = &octeon_irq_chip_ciu_edge_v2;
1012 chip_mbox = &octeon_irq_chip_ciu_mbox_v2; 987 chip_mbox = &octeon_irq_chip_ciu_mbox_v2;
1013 chip_wd = &octeon_irq_chip_ciu_wd_v2; 988 chip_wd = &octeon_irq_chip_ciu_wd_v2;
1014 chip_gpio = &octeon_irq_chip_ciu_gpio_v2; 989 chip_gpio = &octeon_irq_chip_ciu_gpio_v2;
@@ -1016,7 +991,6 @@ static void __init octeon_irq_init_ciu(void)
1016 octeon_irq_ip2 = octeon_irq_ip2_v1; 991 octeon_irq_ip2 = octeon_irq_ip2_v1;
1017 octeon_irq_ip3 = octeon_irq_ip3_v1; 992 octeon_irq_ip3 = octeon_irq_ip3_v1;
1018 chip = &octeon_irq_chip_ciu; 993 chip = &octeon_irq_chip_ciu;
1019 chip_edge = &octeon_irq_chip_ciu_edge;
1020 chip_mbox = &octeon_irq_chip_ciu_mbox; 994 chip_mbox = &octeon_irq_chip_ciu_mbox;
1021 chip_wd = &octeon_irq_chip_ciu_wd; 995 chip_wd = &octeon_irq_chip_ciu_wd;
1022 chip_gpio = &octeon_irq_chip_ciu_gpio; 996 chip_gpio = &octeon_irq_chip_ciu_gpio;
@@ -1046,7 +1020,7 @@ static void __init octeon_irq_init_ciu(void)
1046 octeon_irq_set_ciu_mapping(OCTEON_IRQ_TWSI, 0, 45, chip, handle_level_irq); 1020 octeon_irq_set_ciu_mapping(OCTEON_IRQ_TWSI, 0, 45, chip, handle_level_irq);
1047 octeon_irq_set_ciu_mapping(OCTEON_IRQ_RML, 0, 46, chip, handle_level_irq); 1021 octeon_irq_set_ciu_mapping(OCTEON_IRQ_RML, 0, 46, chip, handle_level_irq);
1048 for (i = 0; i < 4; i++) 1022 for (i = 0; i < 4; i++)
1049 octeon_irq_set_ciu_mapping(i + OCTEON_IRQ_TIMER0, 0, i + 52, chip_edge, handle_edge_irq); 1023 octeon_irq_set_ciu_mapping(i + OCTEON_IRQ_TIMER0, 0, i + 52, chip, handle_edge_irq);
1050 1024
1051 octeon_irq_set_ciu_mapping(OCTEON_IRQ_USB0, 0, 56, chip, handle_level_irq); 1025 octeon_irq_set_ciu_mapping(OCTEON_IRQ_USB0, 0, 56, chip, handle_level_irq);
1052 octeon_irq_set_ciu_mapping(OCTEON_IRQ_TWSI2, 0, 59, chip, handle_level_irq); 1026 octeon_irq_set_ciu_mapping(OCTEON_IRQ_TWSI2, 0, 59, chip, handle_level_irq);