diff options
| -rw-r--r-- | arch/arm/mach-ixp2000/core.c | 35 |
1 files changed, 13 insertions, 22 deletions
diff --git a/arch/arm/mach-ixp2000/core.c b/arch/arm/mach-ixp2000/core.c index df140962bb0f..6851abaf5524 100644 --- a/arch/arm/mach-ixp2000/core.c +++ b/arch/arm/mach-ixp2000/core.c | |||
| @@ -84,63 +84,54 @@ static struct map_desc ixp2000_io_desc[] __initdata = { | |||
| 84 | .virtual = IXP2000_CAP_VIRT_BASE, | 84 | .virtual = IXP2000_CAP_VIRT_BASE, |
| 85 | .pfn = __phys_to_pfn(IXP2000_CAP_PHYS_BASE), | 85 | .pfn = __phys_to_pfn(IXP2000_CAP_PHYS_BASE), |
| 86 | .length = IXP2000_CAP_SIZE, | 86 | .length = IXP2000_CAP_SIZE, |
| 87 | .type = MT_DEVICE | 87 | .type = MT_IXP2000_DEVICE, |
| 88 | }, { | 88 | }, { |
| 89 | .virtual = IXP2000_INTCTL_VIRT_BASE, | 89 | .virtual = IXP2000_INTCTL_VIRT_BASE, |
| 90 | .pfn = __phys_to_pfn(IXP2000_INTCTL_PHYS_BASE), | 90 | .pfn = __phys_to_pfn(IXP2000_INTCTL_PHYS_BASE), |
| 91 | .length = IXP2000_INTCTL_SIZE, | 91 | .length = IXP2000_INTCTL_SIZE, |
| 92 | .type = MT_DEVICE | 92 | .type = MT_IXP2000_DEVICE, |
| 93 | }, { | 93 | }, { |
| 94 | .virtual = IXP2000_PCI_CREG_VIRT_BASE, | 94 | .virtual = IXP2000_PCI_CREG_VIRT_BASE, |
| 95 | .pfn = __phys_to_pfn(IXP2000_PCI_CREG_PHYS_BASE), | 95 | .pfn = __phys_to_pfn(IXP2000_PCI_CREG_PHYS_BASE), |
| 96 | .length = IXP2000_PCI_CREG_SIZE, | 96 | .length = IXP2000_PCI_CREG_SIZE, |
| 97 | .type = MT_DEVICE | 97 | .type = MT_IXP2000_DEVICE, |
| 98 | }, { | 98 | }, { |
| 99 | .virtual = IXP2000_PCI_CSR_VIRT_BASE, | 99 | .virtual = IXP2000_PCI_CSR_VIRT_BASE, |
| 100 | .pfn = __phys_to_pfn(IXP2000_PCI_CSR_PHYS_BASE), | 100 | .pfn = __phys_to_pfn(IXP2000_PCI_CSR_PHYS_BASE), |
| 101 | .length = IXP2000_PCI_CSR_SIZE, | 101 | .length = IXP2000_PCI_CSR_SIZE, |
| 102 | .type = MT_DEVICE | 102 | .type = MT_IXP2000_DEVICE, |
| 103 | }, { | 103 | }, { |
| 104 | .virtual = IXP2000_MSF_VIRT_BASE, | 104 | .virtual = IXP2000_MSF_VIRT_BASE, |
| 105 | .pfn = __phys_to_pfn(IXP2000_MSF_PHYS_BASE), | 105 | .pfn = __phys_to_pfn(IXP2000_MSF_PHYS_BASE), |
| 106 | .length = IXP2000_MSF_SIZE, | 106 | .length = IXP2000_MSF_SIZE, |
| 107 | .type = MT_DEVICE | 107 | .type = MT_IXP2000_DEVICE, |
| 108 | }, { | 108 | }, { |
| 109 | .virtual = IXP2000_PCI_IO_VIRT_BASE, | 109 | .virtual = IXP2000_PCI_IO_VIRT_BASE, |
| 110 | .pfn = __phys_to_pfn(IXP2000_PCI_IO_PHYS_BASE), | 110 | .pfn = __phys_to_pfn(IXP2000_PCI_IO_PHYS_BASE), |
| 111 | .length = IXP2000_PCI_IO_SIZE, | 111 | .length = IXP2000_PCI_IO_SIZE, |
| 112 | .type = MT_DEVICE | 112 | .type = MT_IXP2000_DEVICE, |
| 113 | }, { | 113 | }, { |
| 114 | .virtual = IXP2000_PCI_CFG0_VIRT_BASE, | 114 | .virtual = IXP2000_PCI_CFG0_VIRT_BASE, |
| 115 | .pfn = __phys_to_pfn(IXP2000_PCI_CFG0_PHYS_BASE), | 115 | .pfn = __phys_to_pfn(IXP2000_PCI_CFG0_PHYS_BASE), |
| 116 | .length = IXP2000_PCI_CFG0_SIZE, | 116 | .length = IXP2000_PCI_CFG0_SIZE, |
| 117 | .type = MT_DEVICE | 117 | .type = MT_IXP2000_DEVICE, |
| 118 | }, { | 118 | }, { |
| 119 | .virtual = IXP2000_PCI_CFG1_VIRT_BASE, | 119 | .virtual = IXP2000_PCI_CFG1_VIRT_BASE, |
| 120 | .pfn = __phys_to_pfn(IXP2000_PCI_CFG1_PHYS_BASE), | 120 | .pfn = __phys_to_pfn(IXP2000_PCI_CFG1_PHYS_BASE), |
| 121 | .length = IXP2000_PCI_CFG1_SIZE, | 121 | .length = IXP2000_PCI_CFG1_SIZE, |
| 122 | .type = MT_DEVICE | 122 | .type = MT_IXP2000_DEVICE, |
| 123 | } | 123 | } |
| 124 | }; | 124 | }; |
| 125 | 125 | ||
| 126 | void __init ixp2000_map_io(void) | 126 | void __init ixp2000_map_io(void) |
| 127 | { | 127 | { |
| 128 | extern unsigned int processor_id; | ||
| 129 | |||
| 130 | /* | 128 | /* |
| 131 | * On IXP2400 CPUs we need to use MT_IXP2000_DEVICE for | 129 | * On IXP2400 CPUs we need to use MT_IXP2000_DEVICE so that |
| 132 | * tweaking the PMDs so XCB=101. On IXP2800s we use the normal | 130 | * XCB=101 (to avoid triggering erratum #66), and given that |
| 133 | * PMD flags. | 131 | * this mode speeds up I/O accesses and we have write buffer |
| 132 | * flushes in the right places anyway, it doesn't hurt to use | ||
| 133 | * XCB=101 for all IXP2000s. | ||
| 134 | */ | 134 | */ |
| 135 | if ((processor_id & 0xfffffff0) == 0x69054190) { | ||
| 136 | int i; | ||
| 137 | |||
| 138 | printk(KERN_INFO "Enabling IXP2400 erratum #66 workaround\n"); | ||
| 139 | |||
| 140 | for(i=0;i<ARRAY_SIZE(ixp2000_io_desc);i++) | ||
| 141 | ixp2000_io_desc[i].type = MT_IXP2000_DEVICE; | ||
| 142 | } | ||
| 143 | |||
| 144 | iotable_init(ixp2000_io_desc, ARRAY_SIZE(ixp2000_io_desc)); | 135 | iotable_init(ixp2000_io_desc, ARRAY_SIZE(ixp2000_io_desc)); |
| 145 | 136 | ||
| 146 | /* Set slowport to 8-bit mode. */ | 137 | /* Set slowport to 8-bit mode. */ |
