diff options
| author | Paul Mackerras <paulus@samba.org> | 2007-11-19 19:39:26 -0500 |
|---|---|---|
| committer | Paul Mackerras <paulus@samba.org> | 2007-11-19 19:39:26 -0500 |
| commit | b22da92f2cf52b3c51dd9a45abb658b1414b0784 (patch) | |
| tree | 7c602fb1b2d1de588fbfde6bb53662b3a1f8cb8a | |
| parent | 52142e756e9bf6485d3d53596e8aff2e816a7253 (diff) | |
| parent | 3d1d662ef423adf6947a37e230f4d7e8ed7c9544 (diff) | |
Merge branch 'for-2.6.24' of master.kernel.org:/pub/scm/linux/kernel/git/jwboyer/powerpc-4xx into merge
| -rw-r--r-- | arch/powerpc/platforms/40x/walnut.c | 3 | ||||
| -rw-r--r-- | arch/powerpc/platforms/44x/bamboo.c | 3 | ||||
| -rw-r--r-- | arch/powerpc/platforms/44x/ebony.c | 3 | ||||
| -rw-r--r-- | arch/powerpc/platforms/44x/sequoia.c | 3 | ||||
| -rw-r--r-- | arch/powerpc/sysdev/uic.c | 18 | ||||
| -rw-r--r-- | arch/ppc/kernel/setup.c | 7 | ||||
| -rw-r--r-- | arch/ppc/platforms/4xx/yucca.c | 1 | ||||
| -rw-r--r-- | arch/ppc/syslib/virtex_devices.c | 31 |
8 files changed, 64 insertions, 5 deletions
diff --git a/arch/powerpc/platforms/40x/walnut.c b/arch/powerpc/platforms/40x/walnut.c index eb0c136b1c44..ff6db2431798 100644 --- a/arch/powerpc/platforms/40x/walnut.c +++ b/arch/powerpc/platforms/40x/walnut.c | |||
| @@ -17,12 +17,13 @@ | |||
| 17 | */ | 17 | */ |
| 18 | 18 | ||
| 19 | #include <linux/init.h> | 19 | #include <linux/init.h> |
| 20 | #include <linux/of_platform.h> | ||
| 21 | |||
| 20 | #include <asm/machdep.h> | 22 | #include <asm/machdep.h> |
| 21 | #include <asm/prom.h> | 23 | #include <asm/prom.h> |
| 22 | #include <asm/udbg.h> | 24 | #include <asm/udbg.h> |
| 23 | #include <asm/time.h> | 25 | #include <asm/time.h> |
| 24 | #include <asm/uic.h> | 26 | #include <asm/uic.h> |
| 25 | #include <asm/of_platform.h> | ||
| 26 | 27 | ||
| 27 | static struct of_device_id walnut_of_bus[] = { | 28 | static struct of_device_id walnut_of_bus[] = { |
| 28 | { .compatible = "ibm,plb3", }, | 29 | { .compatible = "ibm,plb3", }, |
diff --git a/arch/powerpc/platforms/44x/bamboo.c b/arch/powerpc/platforms/44x/bamboo.c index 470e1a3fd755..be23f112184f 100644 --- a/arch/powerpc/platforms/44x/bamboo.c +++ b/arch/powerpc/platforms/44x/bamboo.c | |||
| @@ -14,12 +14,13 @@ | |||
| 14 | * option) any later version. | 14 | * option) any later version. |
| 15 | */ | 15 | */ |
| 16 | #include <linux/init.h> | 16 | #include <linux/init.h> |
| 17 | #include <linux/of_platform.h> | ||
| 18 | |||
| 17 | #include <asm/machdep.h> | 19 | #include <asm/machdep.h> |
| 18 | #include <asm/prom.h> | 20 | #include <asm/prom.h> |
| 19 | #include <asm/udbg.h> | 21 | #include <asm/udbg.h> |
| 20 | #include <asm/time.h> | 22 | #include <asm/time.h> |
| 21 | #include <asm/uic.h> | 23 | #include <asm/uic.h> |
| 22 | #include <asm/of_platform.h> | ||
| 23 | #include "44x.h" | 24 | #include "44x.h" |
| 24 | 25 | ||
| 25 | static struct of_device_id bamboo_of_bus[] = { | 26 | static struct of_device_id bamboo_of_bus[] = { |
diff --git a/arch/powerpc/platforms/44x/ebony.c b/arch/powerpc/platforms/44x/ebony.c index 40e18fcb666c..6cd3476767cc 100644 --- a/arch/powerpc/platforms/44x/ebony.c +++ b/arch/powerpc/platforms/44x/ebony.c | |||
| @@ -17,12 +17,13 @@ | |||
| 17 | */ | 17 | */ |
| 18 | 18 | ||
| 19 | #include <linux/init.h> | 19 | #include <linux/init.h> |
| 20 | #include <linux/of_platform.h> | ||
| 21 | |||
| 20 | #include <asm/machdep.h> | 22 | #include <asm/machdep.h> |
| 21 | #include <asm/prom.h> | 23 | #include <asm/prom.h> |
| 22 | #include <asm/udbg.h> | 24 | #include <asm/udbg.h> |
| 23 | #include <asm/time.h> | 25 | #include <asm/time.h> |
| 24 | #include <asm/uic.h> | 26 | #include <asm/uic.h> |
| 25 | #include <asm/of_platform.h> | ||
| 26 | 27 | ||
| 27 | #include "44x.h" | 28 | #include "44x.h" |
| 28 | 29 | ||
diff --git a/arch/powerpc/platforms/44x/sequoia.c b/arch/powerpc/platforms/44x/sequoia.c index 30700b31d43b..21a9dd14f297 100644 --- a/arch/powerpc/platforms/44x/sequoia.c +++ b/arch/powerpc/platforms/44x/sequoia.c | |||
| @@ -14,12 +14,13 @@ | |||
| 14 | * option) any later version. | 14 | * option) any later version. |
| 15 | */ | 15 | */ |
| 16 | #include <linux/init.h> | 16 | #include <linux/init.h> |
| 17 | #include <linux/of_platform.h> | ||
| 18 | |||
| 17 | #include <asm/machdep.h> | 19 | #include <asm/machdep.h> |
| 18 | #include <asm/prom.h> | 20 | #include <asm/prom.h> |
| 19 | #include <asm/udbg.h> | 21 | #include <asm/udbg.h> |
| 20 | #include <asm/time.h> | 22 | #include <asm/time.h> |
| 21 | #include <asm/uic.h> | 23 | #include <asm/uic.h> |
| 22 | #include <asm/of_platform.h> | ||
| 23 | #include "44x.h" | 24 | #include "44x.h" |
| 24 | 25 | ||
| 25 | static struct of_device_id sequoia_of_bus[] = { | 26 | static struct of_device_id sequoia_of_bus[] = { |
diff --git a/arch/powerpc/sysdev/uic.c b/arch/powerpc/sysdev/uic.c index 5149716c734d..847a5496b869 100644 --- a/arch/powerpc/sysdev/uic.c +++ b/arch/powerpc/sysdev/uic.c | |||
| @@ -97,6 +97,22 @@ static void uic_ack_irq(unsigned int virq) | |||
| 97 | spin_unlock_irqrestore(&uic->lock, flags); | 97 | spin_unlock_irqrestore(&uic->lock, flags); |
| 98 | } | 98 | } |
| 99 | 99 | ||
| 100 | static void uic_mask_ack_irq(unsigned int virq) | ||
| 101 | { | ||
| 102 | struct uic *uic = get_irq_chip_data(virq); | ||
| 103 | unsigned int src = uic_irq_to_hw(virq); | ||
| 104 | unsigned long flags; | ||
| 105 | u32 er, sr; | ||
| 106 | |||
| 107 | sr = 1 << (31-src); | ||
| 108 | spin_lock_irqsave(&uic->lock, flags); | ||
| 109 | er = mfdcr(uic->dcrbase + UIC_ER); | ||
| 110 | er &= ~sr; | ||
| 111 | mtdcr(uic->dcrbase + UIC_ER, er); | ||
| 112 | mtdcr(uic->dcrbase + UIC_SR, sr); | ||
| 113 | spin_unlock_irqrestore(&uic->lock, flags); | ||
| 114 | } | ||
| 115 | |||
| 100 | static int uic_set_irq_type(unsigned int virq, unsigned int flow_type) | 116 | static int uic_set_irq_type(unsigned int virq, unsigned int flow_type) |
| 101 | { | 117 | { |
| 102 | struct uic *uic = get_irq_chip_data(virq); | 118 | struct uic *uic = get_irq_chip_data(virq); |
| @@ -152,7 +168,7 @@ static struct irq_chip uic_irq_chip = { | |||
| 152 | .typename = " UIC ", | 168 | .typename = " UIC ", |
| 153 | .unmask = uic_unmask_irq, | 169 | .unmask = uic_unmask_irq, |
| 154 | .mask = uic_mask_irq, | 170 | .mask = uic_mask_irq, |
| 155 | /* .mask_ack = uic_mask_irq_and_ack, */ | 171 | .mask_ack = uic_mask_ack_irq, |
| 156 | .ack = uic_ack_irq, | 172 | .ack = uic_ack_irq, |
| 157 | .set_type = uic_set_irq_type, | 173 | .set_type = uic_set_irq_type, |
| 158 | }; | 174 | }; |
diff --git a/arch/ppc/kernel/setup.c b/arch/ppc/kernel/setup.c index aac88c2f3db9..5255bd80aa6b 100644 --- a/arch/ppc/kernel/setup.c +++ b/arch/ppc/kernel/setup.c | |||
| @@ -312,7 +312,14 @@ early_init(int r3, int r4, int r5) | |||
| 312 | * Identify the CPU type and fix up code sections | 312 | * Identify the CPU type and fix up code sections |
| 313 | * that depend on which cpu we have. | 313 | * that depend on which cpu we have. |
| 314 | */ | 314 | */ |
| 315 | #if defined(CONFIG_440EP) && defined(CONFIG_PPC_FPU) | ||
| 316 | /* We pass the virtual PVR here for 440EP as 440EP and 440GR have | ||
| 317 | * identical PVRs and there is no reliable way to check for the FPU | ||
| 318 | */ | ||
| 319 | spec = identify_cpu(offset, (mfspr(SPRN_PVR) | 0x8)); | ||
| 320 | #else | ||
| 315 | spec = identify_cpu(offset, mfspr(SPRN_PVR)); | 321 | spec = identify_cpu(offset, mfspr(SPRN_PVR)); |
| 322 | #endif | ||
| 316 | do_feature_fixups(spec->cpu_features, | 323 | do_feature_fixups(spec->cpu_features, |
| 317 | PTRRELOC(&__start___ftr_fixup), | 324 | PTRRELOC(&__start___ftr_fixup), |
| 318 | PTRRELOC(&__stop___ftr_fixup)); | 325 | PTRRELOC(&__stop___ftr_fixup)); |
diff --git a/arch/ppc/platforms/4xx/yucca.c b/arch/ppc/platforms/4xx/yucca.c index a83b0baea011..66a44ff0d926 100644 --- a/arch/ppc/platforms/4xx/yucca.c +++ b/arch/ppc/platforms/4xx/yucca.c | |||
| @@ -211,6 +211,7 @@ static void __init yucca_setup_pcie_fpga_rootpoint(int port) | |||
| 211 | break; | 211 | break; |
| 212 | 212 | ||
| 213 | default: | 213 | default: |
| 214 | iounmap(pcie_reg_fpga_base); | ||
| 214 | return; | 215 | return; |
| 215 | } | 216 | } |
| 216 | 217 | ||
diff --git a/arch/ppc/syslib/virtex_devices.c b/arch/ppc/syslib/virtex_devices.c index ace4ec08de51..f658ff3b3890 100644 --- a/arch/ppc/syslib/virtex_devices.c +++ b/arch/ppc/syslib/virtex_devices.c | |||
| @@ -87,6 +87,29 @@ | |||
| 87 | }, \ | 87 | }, \ |
| 88 | } | 88 | } |
| 89 | 89 | ||
| 90 | #define XPAR_AC97_CONTROLLER_REFERENCE(num) { \ | ||
| 91 | .name = "ml403_ac97cr", \ | ||
| 92 | .id = num, \ | ||
| 93 | .num_resources = 3, \ | ||
| 94 | .resource = (struct resource[]) { \ | ||
| 95 | { \ | ||
| 96 | .start = XPAR_OPB_AC97_CONTROLLER_REF_##num##_BASEADDR, \ | ||
| 97 | .end = XPAR_OPB_AC97_CONTROLLER_REF_##num##_HIGHADDR, \ | ||
| 98 | .flags = IORESOURCE_MEM, \ | ||
| 99 | }, \ | ||
| 100 | { \ | ||
| 101 | .start = XPAR_OPB_INTC_0_OPB_AC97_CONTROLLER_REF_##num##_PLAYBACK_INTERRUPT_INTR, \ | ||
| 102 | .end = XPAR_OPB_INTC_0_OPB_AC97_CONTROLLER_REF_##num##_PLAYBACK_INTERRUPT_INTR, \ | ||
| 103 | .flags = IORESOURCE_IRQ, \ | ||
| 104 | }, \ | ||
| 105 | { \ | ||
| 106 | .start = XPAR_OPB_INTC_0_OPB_AC97_CONTROLLER_REF_##num##_RECORD_INTERRUPT_INTR, \ | ||
| 107 | .end = XPAR_OPB_INTC_0_OPB_AC97_CONTROLLER_REF_##num##_RECORD_INTERRUPT_INTR, \ | ||
| 108 | .flags = IORESOURCE_IRQ, \ | ||
| 109 | }, \ | ||
| 110 | }, \ | ||
| 111 | } | ||
| 112 | |||
| 90 | /* UART 8250 driver platform data table */ | 113 | /* UART 8250 driver platform data table */ |
| 91 | struct plat_serial8250_port virtex_serial_platform_data[] = { | 114 | struct plat_serial8250_port virtex_serial_platform_data[] = { |
| 92 | #if defined(XPAR_UARTNS550_0_BASEADDR) | 115 | #if defined(XPAR_UARTNS550_0_BASEADDR) |
| @@ -173,6 +196,14 @@ struct platform_device virtex_platform_devices[] = { | |||
| 173 | #if defined(XPAR_TFT_3_BASEADDR) | 196 | #if defined(XPAR_TFT_3_BASEADDR) |
| 174 | XPAR_TFT(3), | 197 | XPAR_TFT(3), |
| 175 | #endif | 198 | #endif |
| 199 | |||
| 200 | /* AC97 Controller Reference instances */ | ||
| 201 | #if defined(XPAR_OPB_AC97_CONTROLLER_REF_0_BASEADDR) | ||
| 202 | XPAR_AC97_CONTROLLER_REFERENCE(0), | ||
| 203 | #endif | ||
| 204 | #if defined(XPAR_OPB_AC97_CONTROLLER_REF_1_BASEADDR) | ||
| 205 | XPAR_AC97_CONTROLLER_REFERENCE(1), | ||
| 206 | #endif | ||
| 176 | }; | 207 | }; |
| 177 | 208 | ||
| 178 | /* Early serial support functions */ | 209 | /* Early serial support functions */ |
