diff options
Diffstat (limited to 'arch/mips')
-rw-r--r-- | arch/mips/mips-boards/malta/malta_setup.c | 80 |
1 files changed, 42 insertions, 38 deletions
diff --git a/arch/mips/mips-boards/malta/malta_setup.c b/arch/mips/mips-boards/malta/malta_setup.c index 541f4e76747f..2cd8f5734b36 100644 --- a/arch/mips/mips-boards/malta/malta_setup.c +++ b/arch/mips/mips-boards/malta/malta_setup.c | |||
@@ -1,6 +1,7 @@ | |||
1 | /* | 1 | /* |
2 | * Carsten Langgaard, carstenl@mips.com | 2 | * Carsten Langgaard, carstenl@mips.com |
3 | * Copyright (C) 2000 MIPS Technologies, Inc. All rights reserved. | 3 | * Copyright (C) 2000 MIPS Technologies, Inc. All rights reserved. |
4 | * Copyright (C) Dmitri Vorobiev | ||
4 | * | 5 | * |
5 | * This program is free software; you can distribute it and/or modify it | 6 | * This program is free software; you can distribute it and/or modify it |
6 | * under the terms of the GNU General Public License (Version 2) as | 7 | * under the terms of the GNU General Public License (Version 2) as |
@@ -145,6 +146,41 @@ static void __init screen_info_setup(void) | |||
145 | } | 146 | } |
146 | #endif | 147 | #endif |
147 | 148 | ||
149 | static void __init bonito_quirks_setup(void) | ||
150 | { | ||
151 | char *argptr; | ||
152 | |||
153 | argptr = prom_getcmdline(); | ||
154 | if (strstr(argptr, "debug")) { | ||
155 | BONITO_BONGENCFG |= BONITO_BONGENCFG_DEBUGMODE; | ||
156 | printk(KERN_INFO "Enabled Bonito debug mode\n"); | ||
157 | } else | ||
158 | BONITO_BONGENCFG &= ~BONITO_BONGENCFG_DEBUGMODE; | ||
159 | |||
160 | #ifdef CONFIG_DMA_COHERENT | ||
161 | if (BONITO_PCICACHECTRL & BONITO_PCICACHECTRL_CPUCOH_PRES) { | ||
162 | BONITO_PCICACHECTRL |= BONITO_PCICACHECTRL_CPUCOH_EN; | ||
163 | printk(KERN_INFO "Enabled Bonito CPU coherency\n"); | ||
164 | |||
165 | argptr = prom_getcmdline(); | ||
166 | if (strstr(argptr, "iobcuncached")) { | ||
167 | BONITO_PCICACHECTRL &= ~BONITO_PCICACHECTRL_IOBCCOH_EN; | ||
168 | BONITO_PCIMEMBASECFG = BONITO_PCIMEMBASECFG & | ||
169 | ~(BONITO_PCIMEMBASECFG_MEMBASE0_CACHED | | ||
170 | BONITO_PCIMEMBASECFG_MEMBASE1_CACHED); | ||
171 | printk(KERN_INFO "Disabled Bonito IOBC coherency\n"); | ||
172 | } else { | ||
173 | BONITO_PCICACHECTRL |= BONITO_PCICACHECTRL_IOBCCOH_EN; | ||
174 | BONITO_PCIMEMBASECFG |= | ||
175 | (BONITO_PCIMEMBASECFG_MEMBASE0_CACHED | | ||
176 | BONITO_PCIMEMBASECFG_MEMBASE1_CACHED); | ||
177 | printk(KERN_INFO "Enabled Bonito IOBC coherency\n"); | ||
178 | } | ||
179 | } else | ||
180 | panic("Hardware DMA cache coherency not supported"); | ||
181 | #endif | ||
182 | } | ||
183 | |||
148 | void __init plat_mem_setup(void) | 184 | void __init plat_mem_setup(void) |
149 | { | 185 | { |
150 | unsigned int i; | 186 | unsigned int i; |
@@ -164,54 +200,22 @@ void __init plat_mem_setup(void) | |||
164 | kgdb_config(); | 200 | kgdb_config(); |
165 | #endif | 201 | #endif |
166 | 202 | ||
167 | if (mips_revision_sconid == MIPS_REVISION_SCON_BONITO) { | ||
168 | char *argptr; | ||
169 | |||
170 | argptr = prom_getcmdline(); | ||
171 | if (strstr(argptr, "debug")) { | ||
172 | BONITO_BONGENCFG |= BONITO_BONGENCFG_DEBUGMODE; | ||
173 | printk("Enabled Bonito debug mode\n"); | ||
174 | } | ||
175 | else | ||
176 | BONITO_BONGENCFG &= ~BONITO_BONGENCFG_DEBUGMODE; | ||
177 | |||
178 | #ifdef CONFIG_DMA_COHERENT | 203 | #ifdef CONFIG_DMA_COHERENT |
179 | if (BONITO_PCICACHECTRL & BONITO_PCICACHECTRL_CPUCOH_PRES) { | 204 | if (mips_revision_sconid != MIPS_REVISION_SCON_BONITO) |
180 | BONITO_PCICACHECTRL |= BONITO_PCICACHECTRL_CPUCOH_EN; | ||
181 | printk("Enabled Bonito CPU coherency\n"); | ||
182 | |||
183 | argptr = prom_getcmdline(); | ||
184 | if (strstr(argptr, "iobcuncached")) { | ||
185 | BONITO_PCICACHECTRL &= ~BONITO_PCICACHECTRL_IOBCCOH_EN; | ||
186 | BONITO_PCIMEMBASECFG = BONITO_PCIMEMBASECFG & | ||
187 | ~(BONITO_PCIMEMBASECFG_MEMBASE0_CACHED | | ||
188 | BONITO_PCIMEMBASECFG_MEMBASE1_CACHED); | ||
189 | printk("Disabled Bonito IOBC coherency\n"); | ||
190 | } | ||
191 | else { | ||
192 | BONITO_PCICACHECTRL |= BONITO_PCICACHECTRL_IOBCCOH_EN; | ||
193 | BONITO_PCIMEMBASECFG |= | ||
194 | (BONITO_PCIMEMBASECFG_MEMBASE0_CACHED | | ||
195 | BONITO_PCIMEMBASECFG_MEMBASE1_CACHED); | ||
196 | printk("Enabled Bonito IOBC coherency\n"); | ||
197 | } | ||
198 | } | ||
199 | else | ||
200 | panic("Hardware DMA cache coherency not supported"); | ||
201 | |||
202 | #endif | ||
203 | } | ||
204 | #ifdef CONFIG_DMA_COHERENT | ||
205 | else | ||
206 | panic("Hardware DMA cache coherency not supported"); | 205 | panic("Hardware DMA cache coherency not supported"); |
207 | #endif | 206 | #endif |
208 | 207 | ||
208 | if (mips_revision_sconid == MIPS_REVISION_SCON_BONITO) | ||
209 | bonito_quirks_setup(); | ||
210 | |||
209 | #ifdef CONFIG_BLK_DEV_IDE | 211 | #ifdef CONFIG_BLK_DEV_IDE |
210 | pci_clock_check(); | 212 | pci_clock_check(); |
211 | #endif | 213 | #endif |
214 | |||
212 | #ifdef CONFIG_BLK_DEV_FD | 215 | #ifdef CONFIG_BLK_DEV_FD |
213 | fd_activate(); | 216 | fd_activate(); |
214 | #endif | 217 | #endif |
218 | |||
215 | #if defined(CONFIG_VT) && defined(CONFIG_VGA_CONSOLE) | 219 | #if defined(CONFIG_VT) && defined(CONFIG_VGA_CONSOLE) |
216 | screen_info_setup(); | 220 | screen_info_setup(); |
217 | #endif | 221 | #endif |