diff options
author | Paul Mundt <lethal@linux-sh.org> | 2009-03-06 05:19:31 -0500 |
---|---|---|
committer | Paul Mundt <lethal@linux-sh.org> | 2009-03-06 05:19:31 -0500 |
commit | 5dece2bbda728fbf6a70e48be782c24c427072b0 (patch) | |
tree | d2f65105b6708bc7497a9f778e07256bba85c5c9 | |
parent | e26b926a561ba24bfeb8a15bfc848f97052a50f4 (diff) |
sh: multiple vectors per irq - sh7619.
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
-rw-r--r-- | arch/sh/kernel/cpu/sh2/setup-sh7619.c | 34 |
1 files changed, 12 insertions, 22 deletions
diff --git a/arch/sh/kernel/cpu/sh2/setup-sh7619.c b/arch/sh/kernel/cpu/sh2/setup-sh7619.c index 56e5878e5516..0e32d8e448ca 100644 --- a/arch/sh/kernel/cpu/sh2/setup-sh7619.c +++ b/arch/sh/kernel/cpu/sh2/setup-sh7619.c | |||
@@ -2,6 +2,7 @@ | |||
2 | * SH7619 Setup | 2 | * SH7619 Setup |
3 | * | 3 | * |
4 | * Copyright (C) 2006 Yoshinori Sato | 4 | * Copyright (C) 2006 Yoshinori Sato |
5 | * Copyright (C) 2009 Paul Mundt | ||
5 | * | 6 | * |
6 | * This file is subject to the terms and conditions of the GNU General Public | 7 | * This file is subject to the terms and conditions of the GNU General Public |
7 | * License. See the file "COPYING" in the main directory of this archive | 8 | * License. See the file "COPYING" in the main directory of this archive |
@@ -18,15 +19,10 @@ enum { | |||
18 | /* interrupt sources */ | 19 | /* interrupt sources */ |
19 | IRQ0, IRQ1, IRQ2, IRQ3, IRQ4, IRQ5, IRQ6, IRQ7, | 20 | IRQ0, IRQ1, IRQ2, IRQ3, IRQ4, IRQ5, IRQ6, IRQ7, |
20 | WDT, EDMAC, CMT0, CMT1, | 21 | WDT, EDMAC, CMT0, CMT1, |
21 | SCIF0_ERI, SCIF0_RXI, SCIF0_BRI, SCIF0_TXI, | 22 | SCIF0, SCIF1, SCIF2, |
22 | SCIF1_ERI, SCIF1_RXI, SCIF1_BRI, SCIF1_TXI, | ||
23 | SCIF2_ERI, SCIF2_RXI, SCIF2_BRI, SCIF2_TXI, | ||
24 | HIF_HIFI, HIF_HIFBI, | 23 | HIF_HIFI, HIF_HIFBI, |
25 | DMAC0, DMAC1, DMAC2, DMAC3, | 24 | DMAC0, DMAC1, DMAC2, DMAC3, |
26 | SIOF, | 25 | SIOF, |
27 | |||
28 | /* interrupt groups */ | ||
29 | SCIF0, SCIF1, SCIF2, | ||
30 | }; | 26 | }; |
31 | 27 | ||
32 | static struct intc_vect vectors[] __initdata = { | 28 | static struct intc_vect vectors[] __initdata = { |
@@ -36,24 +32,18 @@ static struct intc_vect vectors[] __initdata = { | |||
36 | INTC_IRQ(IRQ6, 82), INTC_IRQ(IRQ7, 83), | 32 | INTC_IRQ(IRQ6, 82), INTC_IRQ(IRQ7, 83), |
37 | INTC_IRQ(WDT, 84), INTC_IRQ(EDMAC, 85), | 33 | INTC_IRQ(WDT, 84), INTC_IRQ(EDMAC, 85), |
38 | INTC_IRQ(CMT0, 86), INTC_IRQ(CMT1, 87), | 34 | INTC_IRQ(CMT0, 86), INTC_IRQ(CMT1, 87), |
39 | INTC_IRQ(SCIF0_ERI, 88), INTC_IRQ(SCIF0_RXI, 89), | 35 | INTC_IRQ(SCIF0, 88), INTC_IRQ(SCIF0, 89), |
40 | INTC_IRQ(SCIF0_BRI, 90), INTC_IRQ(SCIF0_TXI, 91), | 36 | INTC_IRQ(SCIF0, 90), INTC_IRQ(SCIF0, 91), |
41 | INTC_IRQ(SCIF1_ERI, 92), INTC_IRQ(SCIF1_RXI, 93), | 37 | INTC_IRQ(SCIF1, 92), INTC_IRQ(SCIF1, 93), |
42 | INTC_IRQ(SCIF1_BRI, 94), INTC_IRQ(SCIF1_TXI, 95), | 38 | INTC_IRQ(SCIF1, 94), INTC_IRQ(SCIF1, 95), |
43 | INTC_IRQ(SCIF2_ERI, 96), INTC_IRQ(SCIF2_RXI, 97), | 39 | INTC_IRQ(SCIF2, 96), INTC_IRQ(SCIF2, 97), |
44 | INTC_IRQ(SCIF2_BRI, 98), INTC_IRQ(SCIF2_TXI, 99), | 40 | INTC_IRQ(SCIF2, 98), INTC_IRQ(SCIF2, 99), |
45 | INTC_IRQ(HIF_HIFI, 100), INTC_IRQ(HIF_HIFBI, 101), | 41 | INTC_IRQ(HIF_HIFI, 100), INTC_IRQ(HIF_HIFBI, 101), |
46 | INTC_IRQ(DMAC0, 104), INTC_IRQ(DMAC1, 105), | 42 | INTC_IRQ(DMAC0, 104), INTC_IRQ(DMAC1, 105), |
47 | INTC_IRQ(DMAC2, 106), INTC_IRQ(DMAC3, 107), | 43 | INTC_IRQ(DMAC2, 106), INTC_IRQ(DMAC3, 107), |
48 | INTC_IRQ(SIOF, 108), | 44 | INTC_IRQ(SIOF, 108), |
49 | }; | 45 | }; |
50 | 46 | ||
51 | static struct intc_group groups[] __initdata = { | ||
52 | INTC_GROUP(SCIF0, SCIF0_ERI, SCIF0_RXI, SCIF0_BRI, SCIF0_TXI), | ||
53 | INTC_GROUP(SCIF1, SCIF1_ERI, SCIF1_RXI, SCIF1_BRI, SCIF1_TXI), | ||
54 | INTC_GROUP(SCIF2, SCIF2_ERI, SCIF2_RXI, SCIF2_BRI, SCIF2_TXI), | ||
55 | }; | ||
56 | |||
57 | static struct intc_prio_reg prio_registers[] __initdata = { | 47 | static struct intc_prio_reg prio_registers[] __initdata = { |
58 | { 0xf8140006, 0, 16, 4, /* IPRA */ { IRQ0, IRQ1, IRQ2, IRQ3 } }, | 48 | { 0xf8140006, 0, 16, 4, /* IPRA */ { IRQ0, IRQ1, IRQ2, IRQ3 } }, |
59 | { 0xf8140008, 0, 16, 4, /* IPRB */ { IRQ4, IRQ5, IRQ6, IRQ7 } }, | 49 | { 0xf8140008, 0, 16, 4, /* IPRB */ { IRQ4, IRQ5, IRQ6, IRQ7 } }, |
@@ -64,7 +54,7 @@ static struct intc_prio_reg prio_registers[] __initdata = { | |||
64 | { 0xf8080008, 0, 16, 4, /* IPRG */ { SIOF } }, | 54 | { 0xf8080008, 0, 16, 4, /* IPRG */ { SIOF } }, |
65 | }; | 55 | }; |
66 | 56 | ||
67 | static DECLARE_INTC_DESC(intc_desc, "sh7619", vectors, groups, | 57 | static DECLARE_INTC_DESC(intc_desc, "sh7619", vectors, NULL, |
68 | NULL, prio_registers, NULL); | 58 | NULL, prio_registers, NULL); |
69 | 59 | ||
70 | static struct plat_sci_port sci_platform_data[] = { | 60 | static struct plat_sci_port sci_platform_data[] = { |
@@ -72,17 +62,17 @@ static struct plat_sci_port sci_platform_data[] = { | |||
72 | .mapbase = 0xf8400000, | 62 | .mapbase = 0xf8400000, |
73 | .flags = UPF_BOOT_AUTOCONF, | 63 | .flags = UPF_BOOT_AUTOCONF, |
74 | .type = PORT_SCIF, | 64 | .type = PORT_SCIF, |
75 | .irqs = { 88, 89, 91, 90}, | 65 | .irqs = { 88, 88, 88, 88 }, |
76 | }, { | 66 | }, { |
77 | .mapbase = 0xf8410000, | 67 | .mapbase = 0xf8410000, |
78 | .flags = UPF_BOOT_AUTOCONF, | 68 | .flags = UPF_BOOT_AUTOCONF, |
79 | .type = PORT_SCIF, | 69 | .type = PORT_SCIF, |
80 | .irqs = { 92, 93, 95, 94}, | 70 | .irqs = { 92, 92, 92, 92 }, |
81 | }, { | 71 | }, { |
82 | .mapbase = 0xf8420000, | 72 | .mapbase = 0xf8420000, |
83 | .flags = UPF_BOOT_AUTOCONF, | 73 | .flags = UPF_BOOT_AUTOCONF, |
84 | .type = PORT_SCIF, | 74 | .type = PORT_SCIF, |
85 | .irqs = { 96, 97, 99, 98}, | 75 | .irqs = { 96, 96, 96, 96 }, |
86 | }, { | 76 | }, { |
87 | .flags = 0, | 77 | .flags = 0, |
88 | } | 78 | } |