diff options
author | Ludovic Desroches <ludovic.desroches@atmel.com> | 2012-05-21 06:23:27 -0400 |
---|---|---|
committer | Nicolas Ferre <nicolas.ferre@atmel.com> | 2012-07-02 12:03:01 -0400 |
commit | 4cf3326ab5f34a333a46c59d0d3783db9cef13bf (patch) | |
tree | 4d8b5f494f0c99b2f261b6145c91cbc97f492795 /arch/arm/mach-at91 | |
parent | 24f5c4b6e6f2933eb22979283db6174f378d9b36 (diff) |
ARM: at91: add atmel-mci support for chips and boards which can use it
Since atmel-mci driver supports all atmel mci versions,
use it instead of the deprecated at91_mci driver.
Platform data and all related configuration are removed.
Signed-off-by: Ludovic Desroches <ludovic.desroches@atmel.com>
[nicolas.ferre@atmel.com: remove at91_mci platform data]
Signed-off-by: Nicolas Ferre <nicolas.ferre@atmel.com>
Diffstat (limited to 'arch/arm/mach-at91')
32 files changed, 375 insertions, 439 deletions
diff --git a/arch/arm/mach-at91/at91rm9200_devices.c b/arch/arm/mach-at91/at91rm9200_devices.c index e6b7d0533dd7..f6c09b8f5fc9 100644 --- a/arch/arm/mach-at91/at91rm9200_devices.c +++ b/arch/arm/mach-at91/at91rm9200_devices.c | |||
@@ -294,9 +294,9 @@ void __init at91_add_device_cf(struct at91_cf_data *data) {} | |||
294 | * MMC / SD | 294 | * MMC / SD |
295 | * -------------------------------------------------------------------- */ | 295 | * -------------------------------------------------------------------- */ |
296 | 296 | ||
297 | #if defined(CONFIG_MMC_AT91) || defined(CONFIG_MMC_AT91_MODULE) | 297 | #if IS_ENABLED(CONFIG_MMC_ATMELMCI) |
298 | static u64 mmc_dmamask = DMA_BIT_MASK(32); | 298 | static u64 mmc_dmamask = DMA_BIT_MASK(32); |
299 | static struct at91_mmc_data mmc_data; | 299 | static struct mci_platform_data mmc_data; |
300 | 300 | ||
301 | static struct resource mmc_resources[] = { | 301 | static struct resource mmc_resources[] = { |
302 | [0] = { | 302 | [0] = { |
@@ -312,7 +312,7 @@ static struct resource mmc_resources[] = { | |||
312 | }; | 312 | }; |
313 | 313 | ||
314 | static struct platform_device at91rm9200_mmc_device = { | 314 | static struct platform_device at91rm9200_mmc_device = { |
315 | .name = "at91_mci", | 315 | .name = "atmel_mci", |
316 | .id = -1, | 316 | .id = -1, |
317 | .dev = { | 317 | .dev = { |
318 | .dma_mask = &mmc_dmamask, | 318 | .dma_mask = &mmc_dmamask, |
@@ -323,53 +323,69 @@ static struct platform_device at91rm9200_mmc_device = { | |||
323 | .num_resources = ARRAY_SIZE(mmc_resources), | 323 | .num_resources = ARRAY_SIZE(mmc_resources), |
324 | }; | 324 | }; |
325 | 325 | ||
326 | void __init at91_add_device_mmc(short mmc_id, struct at91_mmc_data *data) | 326 | void __init at91_add_device_mci(short mmc_id, struct mci_platform_data *data) |
327 | { | 327 | { |
328 | unsigned int i; | ||
329 | unsigned int slot_count = 0; | ||
330 | |||
328 | if (!data) | 331 | if (!data) |
329 | return; | 332 | return; |
330 | 333 | ||
331 | /* input/irq */ | 334 | for (i = 0; i < ATMCI_MAX_NR_SLOTS; i++) { |
332 | if (gpio_is_valid(data->det_pin)) { | ||
333 | at91_set_gpio_input(data->det_pin, 1); | ||
334 | at91_set_deglitch(data->det_pin, 1); | ||
335 | } | ||
336 | if (gpio_is_valid(data->wp_pin)) | ||
337 | at91_set_gpio_input(data->wp_pin, 1); | ||
338 | if (gpio_is_valid(data->vcc_pin)) | ||
339 | at91_set_gpio_output(data->vcc_pin, 0); | ||
340 | |||
341 | /* CLK */ | ||
342 | at91_set_A_periph(AT91_PIN_PA27, 0); | ||
343 | 335 | ||
344 | if (data->slot_b) { | 336 | if (!data->slot[i].bus_width) |
345 | /* CMD */ | 337 | continue; |
346 | at91_set_B_periph(AT91_PIN_PA8, 1); | ||
347 | 338 | ||
348 | /* DAT0, maybe DAT1..DAT3 */ | 339 | /* input/irq */ |
349 | at91_set_B_periph(AT91_PIN_PA9, 1); | 340 | if (gpio_is_valid(data->slot[i].detect_pin)) { |
350 | if (data->wire4) { | 341 | at91_set_gpio_input(data->slot[i].detect_pin, 1); |
351 | at91_set_B_periph(AT91_PIN_PA10, 1); | 342 | at91_set_deglitch(data->slot[i].detect_pin, 1); |
352 | at91_set_B_periph(AT91_PIN_PA11, 1); | ||
353 | at91_set_B_periph(AT91_PIN_PA12, 1); | ||
354 | } | 343 | } |
355 | } else { | 344 | if (gpio_is_valid(data->slot[i].wp_pin)) |
356 | /* CMD */ | 345 | at91_set_gpio_input(data->slot[i].wp_pin, 1); |
357 | at91_set_A_periph(AT91_PIN_PA28, 1); | 346 | |
358 | 347 | switch (i) { | |
359 | /* DAT0, maybe DAT1..DAT3 */ | 348 | case 0: /* slot A */ |
360 | at91_set_A_periph(AT91_PIN_PA29, 1); | 349 | /* CMD */ |
361 | if (data->wire4) { | 350 | at91_set_A_periph(AT91_PIN_PA28, 1); |
362 | at91_set_B_periph(AT91_PIN_PB3, 1); | 351 | /* DAT0, maybe DAT1..DAT3 */ |
363 | at91_set_B_periph(AT91_PIN_PB4, 1); | 352 | at91_set_A_periph(AT91_PIN_PA29, 1); |
364 | at91_set_B_periph(AT91_PIN_PB5, 1); | 353 | if (data->slot[i].bus_width == 4) { |
354 | at91_set_B_periph(AT91_PIN_PB3, 1); | ||
355 | at91_set_B_periph(AT91_PIN_PB4, 1); | ||
356 | at91_set_B_periph(AT91_PIN_PB5, 1); | ||
357 | } | ||
358 | slot_count++; | ||
359 | break; | ||
360 | case 1: /* slot B */ | ||
361 | /* CMD */ | ||
362 | at91_set_B_periph(AT91_PIN_PA8, 1); | ||
363 | /* DAT0, maybe DAT1..DAT3 */ | ||
364 | at91_set_B_periph(AT91_PIN_PA9, 1); | ||
365 | if (data->slot[i].bus_width == 4) { | ||
366 | at91_set_B_periph(AT91_PIN_PA10, 1); | ||
367 | at91_set_B_periph(AT91_PIN_PA11, 1); | ||
368 | at91_set_B_periph(AT91_PIN_PA12, 1); | ||
369 | } | ||
370 | slot_count++; | ||
371 | break; | ||
372 | default: | ||
373 | printk(KERN_ERR | ||
374 | "AT91: SD/MMC slot %d not available\n", i); | ||
375 | break; | ||
376 | } | ||
377 | if (slot_count) { | ||
378 | /* CLK */ | ||
379 | at91_set_A_periph(AT91_PIN_PA27, 0); | ||
380 | |||
381 | mmc_data = *data; | ||
382 | platform_device_register(&at91rm9200_mmc_device); | ||
365 | } | 383 | } |
366 | } | 384 | } |
367 | 385 | ||
368 | mmc_data = *data; | ||
369 | platform_device_register(&at91rm9200_mmc_device); | ||
370 | } | 386 | } |
371 | #else | 387 | #else |
372 | void __init at91_add_device_mmc(short mmc_id, struct at91_mmc_data *data) {} | 388 | void __init at91_add_device_mci(short mmc_id, struct mci_platform_data *data) {} |
373 | #endif | 389 | #endif |
374 | 390 | ||
375 | 391 | ||
diff --git a/arch/arm/mach-at91/at91sam9260_devices.c b/arch/arm/mach-at91/at91sam9260_devices.c index 0ded951f785a..95f8395f4ebb 100644 --- a/arch/arm/mach-at91/at91sam9260_devices.c +++ b/arch/arm/mach-at91/at91sam9260_devices.c | |||
@@ -209,92 +209,10 @@ void __init at91_add_device_eth(struct macb_platform_data *data) {} | |||
209 | 209 | ||
210 | 210 | ||
211 | /* -------------------------------------------------------------------- | 211 | /* -------------------------------------------------------------------- |
212 | * MMC / SD | ||
213 | * -------------------------------------------------------------------- */ | ||
214 | |||
215 | #if defined(CONFIG_MMC_AT91) || defined(CONFIG_MMC_AT91_MODULE) | ||
216 | static u64 mmc_dmamask = DMA_BIT_MASK(32); | ||
217 | static struct at91_mmc_data mmc_data; | ||
218 | |||
219 | static struct resource mmc_resources[] = { | ||
220 | [0] = { | ||
221 | .start = AT91SAM9260_BASE_MCI, | ||
222 | .end = AT91SAM9260_BASE_MCI + SZ_16K - 1, | ||
223 | .flags = IORESOURCE_MEM, | ||
224 | }, | ||
225 | [1] = { | ||
226 | .start = AT91SAM9260_ID_MCI, | ||
227 | .end = AT91SAM9260_ID_MCI, | ||
228 | .flags = IORESOURCE_IRQ, | ||
229 | }, | ||
230 | }; | ||
231 | |||
232 | static struct platform_device at91sam9260_mmc_device = { | ||
233 | .name = "at91_mci", | ||
234 | .id = -1, | ||
235 | .dev = { | ||
236 | .dma_mask = &mmc_dmamask, | ||
237 | .coherent_dma_mask = DMA_BIT_MASK(32), | ||
238 | .platform_data = &mmc_data, | ||
239 | }, | ||
240 | .resource = mmc_resources, | ||
241 | .num_resources = ARRAY_SIZE(mmc_resources), | ||
242 | }; | ||
243 | |||
244 | void __init at91_add_device_mmc(short mmc_id, struct at91_mmc_data *data) | ||
245 | { | ||
246 | if (!data) | ||
247 | return; | ||
248 | |||
249 | /* input/irq */ | ||
250 | if (gpio_is_valid(data->det_pin)) { | ||
251 | at91_set_gpio_input(data->det_pin, 1); | ||
252 | at91_set_deglitch(data->det_pin, 1); | ||
253 | } | ||
254 | if (gpio_is_valid(data->wp_pin)) | ||
255 | at91_set_gpio_input(data->wp_pin, 1); | ||
256 | if (gpio_is_valid(data->vcc_pin)) | ||
257 | at91_set_gpio_output(data->vcc_pin, 0); | ||
258 | |||
259 | /* CLK */ | ||
260 | at91_set_A_periph(AT91_PIN_PA8, 0); | ||
261 | |||
262 | if (data->slot_b) { | ||
263 | /* CMD */ | ||
264 | at91_set_B_periph(AT91_PIN_PA1, 1); | ||
265 | |||
266 | /* DAT0, maybe DAT1..DAT3 */ | ||
267 | at91_set_B_periph(AT91_PIN_PA0, 1); | ||
268 | if (data->wire4) { | ||
269 | at91_set_B_periph(AT91_PIN_PA5, 1); | ||
270 | at91_set_B_periph(AT91_PIN_PA4, 1); | ||
271 | at91_set_B_periph(AT91_PIN_PA3, 1); | ||
272 | } | ||
273 | } else { | ||
274 | /* CMD */ | ||
275 | at91_set_A_periph(AT91_PIN_PA7, 1); | ||
276 | |||
277 | /* DAT0, maybe DAT1..DAT3 */ | ||
278 | at91_set_A_periph(AT91_PIN_PA6, 1); | ||
279 | if (data->wire4) { | ||
280 | at91_set_A_periph(AT91_PIN_PA9, 1); | ||
281 | at91_set_A_periph(AT91_PIN_PA10, 1); | ||
282 | at91_set_A_periph(AT91_PIN_PA11, 1); | ||
283 | } | ||
284 | } | ||
285 | |||
286 | mmc_data = *data; | ||
287 | platform_device_register(&at91sam9260_mmc_device); | ||
288 | } | ||
289 | #else | ||
290 | void __init at91_add_device_mmc(short mmc_id, struct at91_mmc_data *data) {} | ||
291 | #endif | ||
292 | |||
293 | /* -------------------------------------------------------------------- | ||
294 | * MMC / SD Slot for Atmel MCI Driver | 212 | * MMC / SD Slot for Atmel MCI Driver |
295 | * -------------------------------------------------------------------- */ | 213 | * -------------------------------------------------------------------- */ |
296 | 214 | ||
297 | #if defined(CONFIG_MMC_ATMELMCI) || defined(CONFIG_MMC_ATMELMCI_MODULE) | 215 | #if IS_ENABLED(CONFIG_MMC_ATMELMCI) |
298 | static u64 mmc_dmamask = DMA_BIT_MASK(32); | 216 | static u64 mmc_dmamask = DMA_BIT_MASK(32); |
299 | static struct mci_platform_data mmc_data; | 217 | static struct mci_platform_data mmc_data; |
300 | 218 | ||
diff --git a/arch/arm/mach-at91/at91sam9261_devices.c b/arch/arm/mach-at91/at91sam9261_devices.c index 9295e90b08ff..5d9d4c876a44 100644 --- a/arch/arm/mach-at91/at91sam9261_devices.c +++ b/arch/arm/mach-at91/at91sam9261_devices.c | |||
@@ -137,9 +137,9 @@ void __init at91_add_device_udc(struct at91_udc_data *data) {} | |||
137 | * MMC / SD | 137 | * MMC / SD |
138 | * -------------------------------------------------------------------- */ | 138 | * -------------------------------------------------------------------- */ |
139 | 139 | ||
140 | #if defined(CONFIG_MMC_AT91) || defined(CONFIG_MMC_AT91_MODULE) | 140 | #if IS_ENABLED(CONFIG_MMC_ATMELMCI) |
141 | static u64 mmc_dmamask = DMA_BIT_MASK(32); | 141 | static u64 mmc_dmamask = DMA_BIT_MASK(32); |
142 | static struct at91_mmc_data mmc_data; | 142 | static struct mci_platform_data mmc_data; |
143 | 143 | ||
144 | static struct resource mmc_resources[] = { | 144 | static struct resource mmc_resources[] = { |
145 | [0] = { | 145 | [0] = { |
@@ -155,7 +155,7 @@ static struct resource mmc_resources[] = { | |||
155 | }; | 155 | }; |
156 | 156 | ||
157 | static struct platform_device at91sam9261_mmc_device = { | 157 | static struct platform_device at91sam9261_mmc_device = { |
158 | .name = "at91_mci", | 158 | .name = "atmel_mci", |
159 | .id = -1, | 159 | .id = -1, |
160 | .dev = { | 160 | .dev = { |
161 | .dma_mask = &mmc_dmamask, | 161 | .dma_mask = &mmc_dmamask, |
@@ -166,40 +166,40 @@ static struct platform_device at91sam9261_mmc_device = { | |||
166 | .num_resources = ARRAY_SIZE(mmc_resources), | 166 | .num_resources = ARRAY_SIZE(mmc_resources), |
167 | }; | 167 | }; |
168 | 168 | ||
169 | void __init at91_add_device_mmc(short mmc_id, struct at91_mmc_data *data) | 169 | void __init at91_add_device_mci(short mmc_id, struct mci_platform_data *data) |
170 | { | 170 | { |
171 | if (!data) | 171 | if (!data) |
172 | return; | 172 | return; |
173 | 173 | ||
174 | /* input/irq */ | 174 | if (data->slot[0].bus_width) { |
175 | if (gpio_is_valid(data->det_pin)) { | 175 | /* input/irq */ |
176 | at91_set_gpio_input(data->det_pin, 1); | 176 | if (gpio_is_valid(data->slot[0].detect_pin)) { |
177 | at91_set_deglitch(data->det_pin, 1); | 177 | at91_set_gpio_input(data->slot[0].detect_pin, 1); |
178 | } | 178 | at91_set_deglitch(data->slot[0].detect_pin, 1); |
179 | if (gpio_is_valid(data->wp_pin)) | 179 | } |
180 | at91_set_gpio_input(data->wp_pin, 1); | 180 | if (gpio_is_valid(data->slot[0].wp_pin)) |
181 | if (gpio_is_valid(data->vcc_pin)) | 181 | at91_set_gpio_input(data->slot[0].wp_pin, 1); |
182 | at91_set_gpio_output(data->vcc_pin, 0); | 182 | |
183 | 183 | /* CLK */ | |
184 | /* CLK */ | 184 | at91_set_B_periph(AT91_PIN_PA2, 0); |
185 | at91_set_B_periph(AT91_PIN_PA2, 0); | ||
186 | |||
187 | /* CMD */ | ||
188 | at91_set_B_periph(AT91_PIN_PA1, 1); | ||
189 | |||
190 | /* DAT0, maybe DAT1..DAT3 */ | ||
191 | at91_set_B_periph(AT91_PIN_PA0, 1); | ||
192 | if (data->wire4) { | ||
193 | at91_set_B_periph(AT91_PIN_PA4, 1); | ||
194 | at91_set_B_periph(AT91_PIN_PA5, 1); | ||
195 | at91_set_B_periph(AT91_PIN_PA6, 1); | ||
196 | } | ||
197 | 185 | ||
198 | mmc_data = *data; | 186 | /* CMD */ |
199 | platform_device_register(&at91sam9261_mmc_device); | 187 | at91_set_B_periph(AT91_PIN_PA1, 1); |
188 | |||
189 | /* DAT0, maybe DAT1..DAT3 */ | ||
190 | at91_set_B_periph(AT91_PIN_PA0, 1); | ||
191 | if (data->slot[0].bus_width == 4) { | ||
192 | at91_set_B_periph(AT91_PIN_PA4, 1); | ||
193 | at91_set_B_periph(AT91_PIN_PA5, 1); | ||
194 | at91_set_B_periph(AT91_PIN_PA6, 1); | ||
195 | } | ||
196 | |||
197 | mmc_data = *data; | ||
198 | platform_device_register(&at91sam9261_mmc_device); | ||
199 | } | ||
200 | } | 200 | } |
201 | #else | 201 | #else |
202 | void __init at91_add_device_mmc(short mmc_id, struct at91_mmc_data *data) {} | 202 | void __init at91_add_device_mci(short mmc_id, struct mci_platform_data *data) {} |
203 | #endif | 203 | #endif |
204 | 204 | ||
205 | 205 | ||
diff --git a/arch/arm/mach-at91/at91sam9263.c b/arch/arm/mach-at91/at91sam9263.c index ed91c7e9f7c2..7ccf6d0c2427 100644 --- a/arch/arm/mach-at91/at91sam9263.c +++ b/arch/arm/mach-at91/at91sam9263.c | |||
@@ -187,8 +187,8 @@ static struct clk_lookup periph_clocks_lookups[] = { | |||
187 | CLKDEV_CON_ID("hclk", &macb_clk), | 187 | CLKDEV_CON_ID("hclk", &macb_clk), |
188 | CLKDEV_CON_DEV_ID("pclk", "ssc.0", &ssc0_clk), | 188 | CLKDEV_CON_DEV_ID("pclk", "ssc.0", &ssc0_clk), |
189 | CLKDEV_CON_DEV_ID("pclk", "ssc.1", &ssc1_clk), | 189 | CLKDEV_CON_DEV_ID("pclk", "ssc.1", &ssc1_clk), |
190 | CLKDEV_CON_DEV_ID("mci_clk", "at91_mci.0", &mmc0_clk), | 190 | CLKDEV_CON_DEV_ID("mci_clk", "atmel_mci.0", &mmc0_clk), |
191 | CLKDEV_CON_DEV_ID("mci_clk", "at91_mci.1", &mmc1_clk), | 191 | CLKDEV_CON_DEV_ID("mci_clk", "atmel_mci.1", &mmc1_clk), |
192 | CLKDEV_CON_DEV_ID("spi_clk", "atmel_spi.0", &spi0_clk), | 192 | CLKDEV_CON_DEV_ID("spi_clk", "atmel_spi.0", &spi0_clk), |
193 | CLKDEV_CON_DEV_ID("spi_clk", "atmel_spi.1", &spi1_clk), | 193 | CLKDEV_CON_DEV_ID("spi_clk", "atmel_spi.1", &spi1_clk), |
194 | CLKDEV_CON_DEV_ID("t0_clk", "atmel_tcb.0", &tcb_clk), | 194 | CLKDEV_CON_DEV_ID("t0_clk", "atmel_tcb.0", &tcb_clk), |
diff --git a/arch/arm/mach-at91/at91sam9263_devices.c b/arch/arm/mach-at91/at91sam9263_devices.c index 175e0009eaa9..aa15997ec9eb 100644 --- a/arch/arm/mach-at91/at91sam9263_devices.c +++ b/arch/arm/mach-at91/at91sam9263_devices.c | |||
@@ -218,9 +218,9 @@ void __init at91_add_device_eth(struct macb_platform_data *data) {} | |||
218 | * MMC / SD | 218 | * MMC / SD |
219 | * -------------------------------------------------------------------- */ | 219 | * -------------------------------------------------------------------- */ |
220 | 220 | ||
221 | #if defined(CONFIG_MMC_AT91) || defined(CONFIG_MMC_AT91_MODULE) | 221 | #if IS_ENABLED(CONFIG_MMC_ATMELMCI) |
222 | static u64 mmc_dmamask = DMA_BIT_MASK(32); | 222 | static u64 mmc_dmamask = DMA_BIT_MASK(32); |
223 | static struct at91_mmc_data mmc0_data, mmc1_data; | 223 | static struct mci_platform_data mmc0_data, mmc1_data; |
224 | 224 | ||
225 | static struct resource mmc0_resources[] = { | 225 | static struct resource mmc0_resources[] = { |
226 | [0] = { | 226 | [0] = { |
@@ -236,7 +236,7 @@ static struct resource mmc0_resources[] = { | |||
236 | }; | 236 | }; |
237 | 237 | ||
238 | static struct platform_device at91sam9263_mmc0_device = { | 238 | static struct platform_device at91sam9263_mmc0_device = { |
239 | .name = "at91_mci", | 239 | .name = "atmel_mci", |
240 | .id = 0, | 240 | .id = 0, |
241 | .dev = { | 241 | .dev = { |
242 | .dma_mask = &mmc_dmamask, | 242 | .dma_mask = &mmc_dmamask, |
@@ -261,7 +261,7 @@ static struct resource mmc1_resources[] = { | |||
261 | }; | 261 | }; |
262 | 262 | ||
263 | static struct platform_device at91sam9263_mmc1_device = { | 263 | static struct platform_device at91sam9263_mmc1_device = { |
264 | .name = "at91_mci", | 264 | .name = "atmel_mci", |
265 | .id = 1, | 265 | .id = 1, |
266 | .dev = { | 266 | .dev = { |
267 | .dma_mask = &mmc_dmamask, | 267 | .dma_mask = &mmc_dmamask, |
@@ -272,85 +272,110 @@ static struct platform_device at91sam9263_mmc1_device = { | |||
272 | .num_resources = ARRAY_SIZE(mmc1_resources), | 272 | .num_resources = ARRAY_SIZE(mmc1_resources), |
273 | }; | 273 | }; |
274 | 274 | ||
275 | void __init at91_add_device_mmc(short mmc_id, struct at91_mmc_data *data) | 275 | void __init at91_add_device_mci(short mmc_id, struct mci_platform_data *data) |
276 | { | 276 | { |
277 | unsigned int i; | ||
278 | unsigned int slot_count = 0; | ||
279 | |||
277 | if (!data) | 280 | if (!data) |
278 | return; | 281 | return; |
279 | 282 | ||
280 | /* input/irq */ | 283 | for (i = 0; i < ATMCI_MAX_NR_SLOTS; i++) { |
281 | if (gpio_is_valid(data->det_pin)) { | ||
282 | at91_set_gpio_input(data->det_pin, 1); | ||
283 | at91_set_deglitch(data->det_pin, 1); | ||
284 | } | ||
285 | if (gpio_is_valid(data->wp_pin)) | ||
286 | at91_set_gpio_input(data->wp_pin, 1); | ||
287 | if (gpio_is_valid(data->vcc_pin)) | ||
288 | at91_set_gpio_output(data->vcc_pin, 0); | ||
289 | 284 | ||
290 | if (mmc_id == 0) { /* MCI0 */ | 285 | if (!data->slot[i].bus_width) |
291 | /* CLK */ | 286 | continue; |
292 | at91_set_A_periph(AT91_PIN_PA12, 0); | ||
293 | 287 | ||
294 | if (data->slot_b) { | 288 | /* input/irq */ |
295 | /* CMD */ | 289 | if (gpio_is_valid(data->slot[i].detect_pin)) { |
296 | at91_set_A_periph(AT91_PIN_PA16, 1); | 290 | at91_set_gpio_input(data->slot[i].detect_pin, |
291 | 1); | ||
292 | at91_set_deglitch(data->slot[i].detect_pin, | ||
293 | 1); | ||
294 | } | ||
295 | if (gpio_is_valid(data->slot[i].wp_pin)) | ||
296 | at91_set_gpio_input(data->slot[i].wp_pin, 1); | ||
297 | |||
298 | if (mmc_id == 0) { /* MCI0 */ | ||
299 | switch (i) { | ||
300 | case 0: /* slot A */ | ||
301 | /* CMD */ | ||
302 | at91_set_A_periph(AT91_PIN_PA1, 1); | ||
303 | /* DAT0, maybe DAT1..DAT3 */ | ||
304 | at91_set_A_periph(AT91_PIN_PA0, 1); | ||
305 | if (data->slot[i].bus_width == 4) { | ||
306 | at91_set_A_periph(AT91_PIN_PA3, 1); | ||
307 | at91_set_A_periph(AT91_PIN_PA4, 1); | ||
308 | at91_set_A_periph(AT91_PIN_PA5, 1); | ||
309 | } | ||
310 | slot_count++; | ||
311 | break; | ||
312 | case 1: /* slot B */ | ||
313 | /* CMD */ | ||
314 | at91_set_A_periph(AT91_PIN_PA16, 1); | ||
315 | /* DAT0, maybe DAT1..DAT3 */ | ||
316 | at91_set_A_periph(AT91_PIN_PA17, 1); | ||
317 | if (data->slot[i].bus_width == 4) { | ||
318 | at91_set_A_periph(AT91_PIN_PA18, 1); | ||
319 | at91_set_A_periph(AT91_PIN_PA19, 1); | ||
320 | at91_set_A_periph(AT91_PIN_PA20, 1); | ||
321 | } | ||
322 | slot_count++; | ||
323 | break; | ||
324 | default: | ||
325 | printk(KERN_ERR | ||
326 | "AT91: SD/MMC slot %d not available\n", i); | ||
327 | break; | ||
328 | } | ||
329 | if (slot_count) { | ||
330 | /* CLK */ | ||
331 | at91_set_A_periph(AT91_PIN_PA12, 0); | ||
297 | 332 | ||
298 | /* DAT0, maybe DAT1..DAT3 */ | 333 | mmc0_data = *data; |
299 | at91_set_A_periph(AT91_PIN_PA17, 1); | 334 | platform_device_register(&at91sam9263_mmc0_device); |
300 | if (data->wire4) { | ||
301 | at91_set_A_periph(AT91_PIN_PA18, 1); | ||
302 | at91_set_A_periph(AT91_PIN_PA19, 1); | ||
303 | at91_set_A_periph(AT91_PIN_PA20, 1); | ||
304 | } | 335 | } |
305 | } else { | 336 | } else if (mmc_id == 1) { /* MCI1 */ |
306 | /* CMD */ | 337 | switch (i) { |
307 | at91_set_A_periph(AT91_PIN_PA1, 1); | 338 | case 0: /* slot A */ |
308 | 339 | /* CMD */ | |
309 | /* DAT0, maybe DAT1..DAT3 */ | 340 | at91_set_A_periph(AT91_PIN_PA7, 1); |
310 | at91_set_A_periph(AT91_PIN_PA0, 1); | 341 | /* DAT0, maybe DAT1..DAT3 */ |
311 | if (data->wire4) { | 342 | at91_set_A_periph(AT91_PIN_PA8, 1); |
312 | at91_set_A_periph(AT91_PIN_PA3, 1); | 343 | if (data->slot[i].bus_width == 4) { |
313 | at91_set_A_periph(AT91_PIN_PA4, 1); | 344 | at91_set_A_periph(AT91_PIN_PA9, 1); |
314 | at91_set_A_periph(AT91_PIN_PA5, 1); | 345 | at91_set_A_periph(AT91_PIN_PA10, 1); |
346 | at91_set_A_periph(AT91_PIN_PA11, 1); | ||
347 | } | ||
348 | slot_count++; | ||
349 | break; | ||
350 | case 1: /* slot B */ | ||
351 | /* CMD */ | ||
352 | at91_set_A_periph(AT91_PIN_PA21, 1); | ||
353 | /* DAT0, maybe DAT1..DAT3 */ | ||
354 | at91_set_A_periph(AT91_PIN_PA22, 1); | ||
355 | if (data->slot[i].bus_width == 4) { | ||
356 | at91_set_A_periph(AT91_PIN_PA23, 1); | ||
357 | at91_set_A_periph(AT91_PIN_PA24, 1); | ||
358 | at91_set_A_periph(AT91_PIN_PA25, 1); | ||
359 | } | ||
360 | slot_count++; | ||
361 | break; | ||
362 | default: | ||
363 | printk(KERN_ERR | ||
364 | "AT91: SD/MMC slot %d not available\n", i); | ||
365 | break; | ||
315 | } | 366 | } |
316 | } | 367 | if (slot_count) { |
368 | /* CLK */ | ||
369 | at91_set_A_periph(AT91_PIN_PA6, 0); | ||
317 | 370 | ||
318 | mmc0_data = *data; | 371 | mmc1_data = *data; |
319 | platform_device_register(&at91sam9263_mmc0_device); | 372 | platform_device_register(&at91sam9263_mmc1_device); |
320 | } else { /* MCI1 */ | ||
321 | /* CLK */ | ||
322 | at91_set_A_periph(AT91_PIN_PA6, 0); | ||
323 | |||
324 | if (data->slot_b) { | ||
325 | /* CMD */ | ||
326 | at91_set_A_periph(AT91_PIN_PA21, 1); | ||
327 | |||
328 | /* DAT0, maybe DAT1..DAT3 */ | ||
329 | at91_set_A_periph(AT91_PIN_PA22, 1); | ||
330 | if (data->wire4) { | ||
331 | at91_set_A_periph(AT91_PIN_PA23, 1); | ||
332 | at91_set_A_periph(AT91_PIN_PA24, 1); | ||
333 | at91_set_A_periph(AT91_PIN_PA25, 1); | ||
334 | } | ||
335 | } else { | ||
336 | /* CMD */ | ||
337 | at91_set_A_periph(AT91_PIN_PA7, 1); | ||
338 | |||
339 | /* DAT0, maybe DAT1..DAT3 */ | ||
340 | at91_set_A_periph(AT91_PIN_PA8, 1); | ||
341 | if (data->wire4) { | ||
342 | at91_set_A_periph(AT91_PIN_PA9, 1); | ||
343 | at91_set_A_periph(AT91_PIN_PA10, 1); | ||
344 | at91_set_A_periph(AT91_PIN_PA11, 1); | ||
345 | } | 373 | } |
346 | } | 374 | } |
347 | |||
348 | mmc1_data = *data; | ||
349 | platform_device_register(&at91sam9263_mmc1_device); | ||
350 | } | 375 | } |
351 | } | 376 | } |
352 | #else | 377 | #else |
353 | void __init at91_add_device_mmc(short mmc_id, struct at91_mmc_data *data) {} | 378 | void __init at91_add_device_mci(short mmc_id, struct mci_platform_data *data) {} |
354 | #endif | 379 | #endif |
355 | 380 | ||
356 | /* -------------------------------------------------------------------- | 381 | /* -------------------------------------------------------------------- |
diff --git a/arch/arm/mach-at91/at91sam9rl_devices.c b/arch/arm/mach-at91/at91sam9rl_devices.c index 9c0b1481a9a7..7359472f2764 100644 --- a/arch/arm/mach-at91/at91sam9rl_devices.c +++ b/arch/arm/mach-at91/at91sam9rl_devices.c | |||
@@ -161,9 +161,9 @@ void __init at91_add_device_usba(struct usba_platform_data *data) {} | |||
161 | * MMC / SD | 161 | * MMC / SD |
162 | * -------------------------------------------------------------------- */ | 162 | * -------------------------------------------------------------------- */ |
163 | 163 | ||
164 | #if defined(CONFIG_MMC_AT91) || defined(CONFIG_MMC_AT91_MODULE) | 164 | #if IS_ENABLED(CONFIG_MMC_ATMELMCI) |
165 | static u64 mmc_dmamask = DMA_BIT_MASK(32); | 165 | static u64 mmc_dmamask = DMA_BIT_MASK(32); |
166 | static struct at91_mmc_data mmc_data; | 166 | static struct mci_platform_data mmc_data; |
167 | 167 | ||
168 | static struct resource mmc_resources[] = { | 168 | static struct resource mmc_resources[] = { |
169 | [0] = { | 169 | [0] = { |
@@ -179,7 +179,7 @@ static struct resource mmc_resources[] = { | |||
179 | }; | 179 | }; |
180 | 180 | ||
181 | static struct platform_device at91sam9rl_mmc_device = { | 181 | static struct platform_device at91sam9rl_mmc_device = { |
182 | .name = "at91_mci", | 182 | .name = "atmel_mci", |
183 | .id = -1, | 183 | .id = -1, |
184 | .dev = { | 184 | .dev = { |
185 | .dma_mask = &mmc_dmamask, | 185 | .dma_mask = &mmc_dmamask, |
@@ -190,40 +190,40 @@ static struct platform_device at91sam9rl_mmc_device = { | |||
190 | .num_resources = ARRAY_SIZE(mmc_resources), | 190 | .num_resources = ARRAY_SIZE(mmc_resources), |
191 | }; | 191 | }; |
192 | 192 | ||
193 | void __init at91_add_device_mmc(short mmc_id, struct at91_mmc_data *data) | 193 | void __init at91_add_device_mci(short mmc_id, struct mci_platform_data *data) |
194 | { | 194 | { |
195 | if (!data) | 195 | if (!data) |
196 | return; | 196 | return; |
197 | 197 | ||
198 | /* input/irq */ | 198 | if (data->slot[0].bus_width) { |
199 | if (gpio_is_valid(data->det_pin)) { | 199 | /* input/irq */ |
200 | at91_set_gpio_input(data->det_pin, 1); | 200 | if (gpio_is_valid(data->slot[0].detect_pin)) { |
201 | at91_set_deglitch(data->det_pin, 1); | 201 | at91_set_gpio_input(data->slot[0].detect_pin, 1); |
202 | } | 202 | at91_set_deglitch(data->slot[0].detect_pin, 1); |
203 | if (gpio_is_valid(data->wp_pin)) | 203 | } |
204 | at91_set_gpio_input(data->wp_pin, 1); | 204 | if (gpio_is_valid(data->slot[0].wp_pin)) |
205 | if (gpio_is_valid(data->vcc_pin)) | 205 | at91_set_gpio_input(data->slot[0].wp_pin, 1); |
206 | at91_set_gpio_output(data->vcc_pin, 0); | 206 | |
207 | 207 | /* CLK */ | |
208 | /* CLK */ | 208 | at91_set_A_periph(AT91_PIN_PA2, 0); |
209 | at91_set_A_periph(AT91_PIN_PA2, 0); | 209 | |
210 | 210 | /* CMD */ | |
211 | /* CMD */ | 211 | at91_set_A_periph(AT91_PIN_PA1, 1); |
212 | at91_set_A_periph(AT91_PIN_PA1, 1); | 212 | |
213 | 213 | /* DAT0, maybe DAT1..DAT3 */ | |
214 | /* DAT0, maybe DAT1..DAT3 */ | 214 | at91_set_A_periph(AT91_PIN_PA0, 1); |
215 | at91_set_A_periph(AT91_PIN_PA0, 1); | 215 | if (data->slot[0].bus_width == 4) { |
216 | if (data->wire4) { | 216 | at91_set_A_periph(AT91_PIN_PA3, 1); |
217 | at91_set_A_periph(AT91_PIN_PA3, 1); | 217 | at91_set_A_periph(AT91_PIN_PA4, 1); |
218 | at91_set_A_periph(AT91_PIN_PA4, 1); | 218 | at91_set_A_periph(AT91_PIN_PA5, 1); |
219 | at91_set_A_periph(AT91_PIN_PA5, 1); | 219 | } |
220 | |||
221 | mmc_data = *data; | ||
222 | platform_device_register(&at91sam9rl_mmc_device); | ||
220 | } | 223 | } |
221 | |||
222 | mmc_data = *data; | ||
223 | platform_device_register(&at91sam9rl_mmc_device); | ||
224 | } | 224 | } |
225 | #else | 225 | #else |
226 | void __init at91_add_device_mmc(short mmc_id, struct at91_mmc_data *data) {} | 226 | void __init at91_add_device_mci(short mmc_id, struct mci_platform_data *data) {} |
227 | #endif | 227 | #endif |
228 | 228 | ||
229 | 229 | ||
diff --git a/arch/arm/mach-at91/board-afeb-9260v1.c b/arch/arm/mach-at91/board-afeb-9260v1.c index b7d8aa7b81e6..e49907c25508 100644 --- a/arch/arm/mach-at91/board-afeb-9260v1.c +++ b/arch/arm/mach-at91/board-afeb-9260v1.c | |||
@@ -132,12 +132,12 @@ static struct atmel_nand_data __initdata afeb9260_nand_data = { | |||
132 | /* | 132 | /* |
133 | * MCI (SD/MMC) | 133 | * MCI (SD/MMC) |
134 | */ | 134 | */ |
135 | static struct at91_mmc_data __initdata afeb9260_mmc_data = { | 135 | static struct mci_platform_data __initdata afeb9260_mci0_data = { |
136 | .det_pin = AT91_PIN_PC9, | 136 | .slot[1] = { |
137 | .wp_pin = AT91_PIN_PC4, | 137 | .bus_width = 4, |
138 | .slot_b = 1, | 138 | .detect_pin = AT91_PIN_PC9, |
139 | .wire4 = 1, | 139 | .wp_pin = AT91_PIN_PC4, |
140 | .vcc_pin = -EINVAL, | 140 | }, |
141 | }; | 141 | }; |
142 | 142 | ||
143 | 143 | ||
@@ -198,7 +198,7 @@ static void __init afeb9260_board_init(void) | |||
198 | at91_set_B_periph(AT91_PIN_PA10, 0); /* ETX2 */ | 198 | at91_set_B_periph(AT91_PIN_PA10, 0); /* ETX2 */ |
199 | at91_set_B_periph(AT91_PIN_PA11, 0); /* ETX3 */ | 199 | at91_set_B_periph(AT91_PIN_PA11, 0); /* ETX3 */ |
200 | /* MMC */ | 200 | /* MMC */ |
201 | at91_add_device_mmc(0, &afeb9260_mmc_data); | 201 | at91_add_device_mci(0, &afeb9260_mci0_data); |
202 | /* I2C */ | 202 | /* I2C */ |
203 | at91_add_device_i2c(afeb9260_i2c_devices, | 203 | at91_add_device_i2c(afeb9260_i2c_devices, |
204 | ARRAY_SIZE(afeb9260_i2c_devices)); | 204 | ARRAY_SIZE(afeb9260_i2c_devices)); |
diff --git a/arch/arm/mach-at91/board-carmeva.c b/arch/arm/mach-at91/board-carmeva.c index 44328a6d4609..99e2de74429b 100644 --- a/arch/arm/mach-at91/board-carmeva.c +++ b/arch/arm/mach-at91/board-carmeva.c | |||
@@ -70,12 +70,12 @@ static struct at91_udc_data __initdata carmeva_udc_data = { | |||
70 | // .vcc_pin = -EINVAL, | 70 | // .vcc_pin = -EINVAL, |
71 | // }; | 71 | // }; |
72 | 72 | ||
73 | static struct at91_mmc_data __initdata carmeva_mmc_data = { | 73 | static struct mci_platform_data __initdata carmeva_mci0_data = { |
74 | .slot_b = 0, | 74 | .slot[0] = { |
75 | .wire4 = 1, | 75 | .bus_width = 4, |
76 | .det_pin = AT91_PIN_PB10, | 76 | .detect_pin = AT91_PIN_PB10, |
77 | .wp_pin = AT91_PIN_PC14, | 77 | .wp_pin = AT91_PIN_PC14, |
78 | .vcc_pin = -EINVAL, | 78 | }, |
79 | }; | 79 | }; |
80 | 80 | ||
81 | static struct spi_board_info carmeva_spi_devices[] = { | 81 | static struct spi_board_info carmeva_spi_devices[] = { |
@@ -149,7 +149,7 @@ static void __init carmeva_board_init(void) | |||
149 | /* Compact Flash */ | 149 | /* Compact Flash */ |
150 | // at91_add_device_cf(&carmeva_cf_data); | 150 | // at91_add_device_cf(&carmeva_cf_data); |
151 | /* MMC */ | 151 | /* MMC */ |
152 | at91_add_device_mmc(0, &carmeva_mmc_data); | 152 | at91_add_device_mci(0, &carmeva_mci0_data); |
153 | /* LEDs */ | 153 | /* LEDs */ |
154 | at91_gpio_leds(carmeva_leds, ARRAY_SIZE(carmeva_leds)); | 154 | at91_gpio_leds(carmeva_leds, ARRAY_SIZE(carmeva_leds)); |
155 | } | 155 | } |
diff --git a/arch/arm/mach-at91/board-cpu9krea.c b/arch/arm/mach-at91/board-cpu9krea.c index ece0d76fd0f8..202c3b99fda8 100644 --- a/arch/arm/mach-at91/board-cpu9krea.c +++ b/arch/arm/mach-at91/board-cpu9krea.c | |||
@@ -310,12 +310,12 @@ static void __init cpu9krea_add_device_buttons(void) | |||
310 | /* | 310 | /* |
311 | * MCI (SD/MMC) | 311 | * MCI (SD/MMC) |
312 | */ | 312 | */ |
313 | static struct at91_mmc_data __initdata cpu9krea_mmc_data = { | 313 | static struct mci_platform_data __initdata cpu9krea_mci0_data = { |
314 | .slot_b = 0, | 314 | .slot[0] = { |
315 | .wire4 = 1, | 315 | .bus_width = 4, |
316 | .det_pin = AT91_PIN_PA29, | 316 | .detect_pin = AT91_PIN_PA29, |
317 | .wp_pin = -EINVAL, | 317 | .wp_pin = -EINVAL, |
318 | .vcc_pin = -EINVAL, | 318 | }, |
319 | }; | 319 | }; |
320 | 320 | ||
321 | static void __init cpu9krea_board_init(void) | 321 | static void __init cpu9krea_board_init(void) |
@@ -357,7 +357,7 @@ static void __init cpu9krea_board_init(void) | |||
357 | /* Ethernet */ | 357 | /* Ethernet */ |
358 | at91_add_device_eth(&cpu9krea_macb_data); | 358 | at91_add_device_eth(&cpu9krea_macb_data); |
359 | /* MMC */ | 359 | /* MMC */ |
360 | at91_add_device_mmc(0, &cpu9krea_mmc_data); | 360 | at91_add_device_mci(0, &cpu9krea_mci0_data); |
361 | /* I2C */ | 361 | /* I2C */ |
362 | at91_add_device_i2c(cpu9krea_i2c_devices, | 362 | at91_add_device_i2c(cpu9krea_i2c_devices, |
363 | ARRAY_SIZE(cpu9krea_i2c_devices)); | 363 | ARRAY_SIZE(cpu9krea_i2c_devices)); |
diff --git a/arch/arm/mach-at91/board-cpuat91.c b/arch/arm/mach-at91/board-cpuat91.c index 895cf2dba612..7f64920a41c0 100644 --- a/arch/arm/mach-at91/board-cpuat91.c +++ b/arch/arm/mach-at91/board-cpuat91.c | |||
@@ -77,11 +77,12 @@ static struct at91_udc_data __initdata cpuat91_udc_data = { | |||
77 | .pullup_pin = AT91_PIN_PC14, | 77 | .pullup_pin = AT91_PIN_PC14, |
78 | }; | 78 | }; |
79 | 79 | ||
80 | static struct at91_mmc_data __initdata cpuat91_mmc_data = { | 80 | static struct mci_platform_data __initdata cpuat91_mci0_data = { |
81 | .det_pin = AT91_PIN_PC2, | 81 | .slot[0] = { |
82 | .wire4 = 1, | 82 | .bus_width = 4, |
83 | .wp_pin = -EINVAL, | 83 | .detect_pin = AT91_PIN_PC2, |
84 | .vcc_pin = -EINVAL, | 84 | .wp_pin = -EINVAL, |
85 | }, | ||
85 | }; | 86 | }; |
86 | 87 | ||
87 | static struct physmap_flash_data cpuat91_flash_data = { | 88 | static struct physmap_flash_data cpuat91_flash_data = { |
@@ -167,7 +168,7 @@ static void __init cpuat91_board_init(void) | |||
167 | /* USB Device */ | 168 | /* USB Device */ |
168 | at91_add_device_udc(&cpuat91_udc_data); | 169 | at91_add_device_udc(&cpuat91_udc_data); |
169 | /* MMC */ | 170 | /* MMC */ |
170 | at91_add_device_mmc(0, &cpuat91_mmc_data); | 171 | at91_add_device_mci(0, &cpuat91_mci0_data); |
171 | /* I2C */ | 172 | /* I2C */ |
172 | at91_add_device_i2c(NULL, 0); | 173 | at91_add_device_i2c(NULL, 0); |
173 | /* Platform devices */ | 174 | /* Platform devices */ |
diff --git a/arch/arm/mach-at91/board-csb337.c b/arch/arm/mach-at91/board-csb337.c index cd813361cd26..a17693540a15 100644 --- a/arch/arm/mach-at91/board-csb337.c +++ b/arch/arm/mach-at91/board-csb337.c | |||
@@ -86,12 +86,12 @@ static struct at91_cf_data __initdata csb337_cf_data = { | |||
86 | .rst_pin = AT91_PIN_PD2, | 86 | .rst_pin = AT91_PIN_PD2, |
87 | }; | 87 | }; |
88 | 88 | ||
89 | static struct at91_mmc_data __initdata csb337_mmc_data = { | 89 | static struct mci_platform_data __initdata csb337_mci0_data = { |
90 | .det_pin = AT91_PIN_PD5, | 90 | .slot[0] = { |
91 | .slot_b = 0, | 91 | .bus_width = 4, |
92 | .wire4 = 1, | 92 | .detect_pin = AT91_PIN_PD5, |
93 | .wp_pin = AT91_PIN_PD6, | 93 | .wp_pin = AT91_PIN_PD6, |
94 | .vcc_pin = -EINVAL, | 94 | }, |
95 | }; | 95 | }; |
96 | 96 | ||
97 | static struct spi_board_info csb337_spi_devices[] = { | 97 | static struct spi_board_info csb337_spi_devices[] = { |
@@ -239,7 +239,7 @@ static void __init csb337_board_init(void) | |||
239 | /* SPI */ | 239 | /* SPI */ |
240 | at91_add_device_spi(csb337_spi_devices, ARRAY_SIZE(csb337_spi_devices)); | 240 | at91_add_device_spi(csb337_spi_devices, ARRAY_SIZE(csb337_spi_devices)); |
241 | /* MMC */ | 241 | /* MMC */ |
242 | at91_add_device_mmc(0, &csb337_mmc_data); | 242 | at91_add_device_mci(0, &csb337_mci0_data); |
243 | /* NOR flash */ | 243 | /* NOR flash */ |
244 | platform_device_register(&csb_flash); | 244 | platform_device_register(&csb_flash); |
245 | /* LEDs */ | 245 | /* LEDs */ |
diff --git a/arch/arm/mach-at91/board-eb9200.c b/arch/arm/mach-at91/board-eb9200.c index bd1017297989..d9f4f75a1c0a 100644 --- a/arch/arm/mach-at91/board-eb9200.c +++ b/arch/arm/mach-at91/board-eb9200.c | |||
@@ -69,12 +69,12 @@ static struct at91_cf_data __initdata eb9200_cf_data = { | |||
69 | .rst_pin = AT91_PIN_PC5, | 69 | .rst_pin = AT91_PIN_PC5, |
70 | }; | 70 | }; |
71 | 71 | ||
72 | static struct at91_mmc_data __initdata eb9200_mmc_data = { | 72 | static struct mci_platform_data __initdata eb9200_mci0_data = { |
73 | .slot_b = 0, | 73 | .slot[0] = { |
74 | .wire4 = 1, | 74 | .bus_width = 4, |
75 | .det_pin = -EINVAL, | 75 | .detect_pin = -EINVAL, |
76 | .wp_pin = -EINVAL, | 76 | .wp_pin = -EINVAL, |
77 | .vcc_pin = -EINVAL, | 77 | }, |
78 | }; | 78 | }; |
79 | 79 | ||
80 | static struct i2c_board_info __initdata eb9200_i2c_devices[] = { | 80 | static struct i2c_board_info __initdata eb9200_i2c_devices[] = { |
@@ -112,7 +112,7 @@ static void __init eb9200_board_init(void) | |||
112 | at91_add_device_spi(NULL, 0); | 112 | at91_add_device_spi(NULL, 0); |
113 | /* MMC */ | 113 | /* MMC */ |
114 | /* only supports 1 or 4 bit interface, not wired through to SPI */ | 114 | /* only supports 1 or 4 bit interface, not wired through to SPI */ |
115 | at91_add_device_mmc(0, &eb9200_mmc_data); | 115 | at91_add_device_mci(0, &eb9200_mci0_data); |
116 | } | 116 | } |
117 | 117 | ||
118 | MACHINE_START(ATEB9200, "Embest ATEB9200") | 118 | MACHINE_START(ATEB9200, "Embest ATEB9200") |
diff --git a/arch/arm/mach-at91/board-ecbat91.c b/arch/arm/mach-at91/board-ecbat91.c index 89cc3726a9ce..086ec5b3ebe8 100644 --- a/arch/arm/mach-at91/board-ecbat91.c +++ b/arch/arm/mach-at91/board-ecbat91.c | |||
@@ -63,12 +63,12 @@ static struct at91_usbh_data __initdata ecb_at91usbh_data = { | |||
63 | .overcurrent_pin= {-EINVAL, -EINVAL}, | 63 | .overcurrent_pin= {-EINVAL, -EINVAL}, |
64 | }; | 64 | }; |
65 | 65 | ||
66 | static struct at91_mmc_data __initdata ecb_at91mmc_data = { | 66 | static struct mci_platform_data __initdata ecbat91_mci0_data = { |
67 | .slot_b = 0, | 67 | .slot[0] = { |
68 | .wire4 = 1, | 68 | .bus_width = 4, |
69 | .det_pin = -EINVAL, | 69 | .detect_pin = -EINVAL, |
70 | .wp_pin = -EINVAL, | 70 | .wp_pin = -EINVAL, |
71 | .vcc_pin = -EINVAL, | 71 | }, |
72 | }; | 72 | }; |
73 | 73 | ||
74 | 74 | ||
@@ -160,7 +160,7 @@ static void __init ecb_at91board_init(void) | |||
160 | at91_add_device_i2c(NULL, 0); | 160 | at91_add_device_i2c(NULL, 0); |
161 | 161 | ||
162 | /* MMC */ | 162 | /* MMC */ |
163 | at91_add_device_mmc(0, &ecb_at91mmc_data); | 163 | at91_add_device_mci(0, &ecbat91_mci0_data); |
164 | 164 | ||
165 | /* SPI */ | 165 | /* SPI */ |
166 | at91_add_device_spi(ecb_at91spi_devices, ARRAY_SIZE(ecb_at91spi_devices)); | 166 | at91_add_device_spi(ecb_at91spi_devices, ARRAY_SIZE(ecb_at91spi_devices)); |
diff --git a/arch/arm/mach-at91/board-eco920.c b/arch/arm/mach-at91/board-eco920.c index 558546cf63f4..40e957d1a612 100644 --- a/arch/arm/mach-at91/board-eco920.c +++ b/arch/arm/mach-at91/board-eco920.c | |||
@@ -55,12 +55,12 @@ static struct at91_udc_data __initdata eco920_udc_data = { | |||
55 | .pullup_pin = AT91_PIN_PB13, | 55 | .pullup_pin = AT91_PIN_PB13, |
56 | }; | 56 | }; |
57 | 57 | ||
58 | static struct at91_mmc_data __initdata eco920_mmc_data = { | 58 | static struct mci_platform_data __initdata eco920_mci0_data = { |
59 | .slot_b = 0, | 59 | .slot[0] = { |
60 | .wire4 = 0, | 60 | .bus_width = 1, |
61 | .det_pin = -EINVAL, | 61 | .detect_pin = -EINVAL, |
62 | .wp_pin = -EINVAL, | 62 | .wp_pin = -EINVAL, |
63 | .vcc_pin = -EINVAL, | 63 | }, |
64 | }; | 64 | }; |
65 | 65 | ||
66 | static struct physmap_flash_data eco920_flash_data = { | 66 | static struct physmap_flash_data eco920_flash_data = { |
@@ -103,7 +103,7 @@ static void __init eco920_board_init(void) | |||
103 | at91_add_device_usbh(&eco920_usbh_data); | 103 | at91_add_device_usbh(&eco920_usbh_data); |
104 | at91_add_device_udc(&eco920_udc_data); | 104 | at91_add_device_udc(&eco920_udc_data); |
105 | 105 | ||
106 | at91_add_device_mmc(0, &eco920_mmc_data); | 106 | at91_add_device_mci(0, &eco920_mci0_data); |
107 | platform_device_register(&eco920_flash); | 107 | platform_device_register(&eco920_flash); |
108 | 108 | ||
109 | at91_ramc_write(0, AT91_SMC_CSR(7), AT91_SMC_RWHOLD_(1) | 109 | at91_ramc_write(0, AT91_SMC_CSR(7), AT91_SMC_RWHOLD_(1) |
diff --git a/arch/arm/mach-at91/board-flexibity.c b/arch/arm/mach-at91/board-flexibity.c index 47658f78105d..23ad652edad4 100644 --- a/arch/arm/mach-at91/board-flexibity.c +++ b/arch/arm/mach-at91/board-flexibity.c | |||
@@ -74,12 +74,12 @@ static struct spi_board_info flexibity_spi_devices[] = { | |||
74 | }; | 74 | }; |
75 | 75 | ||
76 | /* MCI (SD/MMC) */ | 76 | /* MCI (SD/MMC) */ |
77 | static struct at91_mmc_data __initdata flexibity_mmc_data = { | 77 | static struct mci_platform_data __initdata flexibity_mci0_data = { |
78 | .slot_b = 0, | 78 | .slot[0] = { |
79 | .wire4 = 1, | 79 | .bus_width = 4, |
80 | .det_pin = AT91_PIN_PC9, | 80 | .detect_pin = AT91_PIN_PC9, |
81 | .wp_pin = AT91_PIN_PC4, | 81 | .wp_pin = AT91_PIN_PC4, |
82 | .vcc_pin = -EINVAL, | 82 | }, |
83 | }; | 83 | }; |
84 | 84 | ||
85 | /* LEDs */ | 85 | /* LEDs */ |
@@ -151,7 +151,7 @@ static void __init flexibity_board_init(void) | |||
151 | at91_add_device_spi(flexibity_spi_devices, | 151 | at91_add_device_spi(flexibity_spi_devices, |
152 | ARRAY_SIZE(flexibity_spi_devices)); | 152 | ARRAY_SIZE(flexibity_spi_devices)); |
153 | /* MMC */ | 153 | /* MMC */ |
154 | at91_add_device_mmc(0, &flexibity_mmc_data); | 154 | at91_add_device_mci(0, &flexibity_mci0_data); |
155 | /* LEDs */ | 155 | /* LEDs */ |
156 | at91_gpio_leds(flexibity_leds, ARRAY_SIZE(flexibity_leds)); | 156 | at91_gpio_leds(flexibity_leds, ARRAY_SIZE(flexibity_leds)); |
157 | } | 157 | } |
diff --git a/arch/arm/mach-at91/board-foxg20.c b/arch/arm/mach-at91/board-foxg20.c index 33411e6ecb1f..0fc218160ae2 100644 --- a/arch/arm/mach-at91/board-foxg20.c +++ b/arch/arm/mach-at91/board-foxg20.c | |||
@@ -85,7 +85,7 @@ static struct at91_udc_data __initdata foxg20_udc_data = { | |||
85 | * SPI devices. | 85 | * SPI devices. |
86 | */ | 86 | */ |
87 | static struct spi_board_info foxg20_spi_devices[] = { | 87 | static struct spi_board_info foxg20_spi_devices[] = { |
88 | #if !defined(CONFIG_MMC_AT91) | 88 | #if !IS_ENABLED(CONFIG_MMC_ATMELMCI) |
89 | { | 89 | { |
90 | .modalias = "mtd_dataflash", | 90 | .modalias = "mtd_dataflash", |
91 | .chip_select = 1, | 91 | .chip_select = 1, |
@@ -108,12 +108,12 @@ static struct macb_platform_data __initdata foxg20_macb_data = { | |||
108 | * MCI (SD/MMC) | 108 | * MCI (SD/MMC) |
109 | * det_pin, wp_pin and vcc_pin are not connected | 109 | * det_pin, wp_pin and vcc_pin are not connected |
110 | */ | 110 | */ |
111 | static struct at91_mmc_data __initdata foxg20_mmc_data = { | 111 | static struct mci_platform_data __initdata foxg20_mci0_data = { |
112 | .slot_b = 1, | 112 | .slot[1] = { |
113 | .wire4 = 1, | 113 | .bus_width = 4, |
114 | .det_pin = -EINVAL, | 114 | .detect_pin = -EINVAL, |
115 | .wp_pin = -EINVAL, | 115 | .wp_pin = -EINVAL, |
116 | .vcc_pin = -EINVAL, | 116 | }, |
117 | }; | 117 | }; |
118 | 118 | ||
119 | 119 | ||
@@ -246,7 +246,7 @@ static void __init foxg20_board_init(void) | |||
246 | /* Ethernet */ | 246 | /* Ethernet */ |
247 | at91_add_device_eth(&foxg20_macb_data); | 247 | at91_add_device_eth(&foxg20_macb_data); |
248 | /* MMC */ | 248 | /* MMC */ |
249 | at91_add_device_mmc(0, &foxg20_mmc_data); | 249 | at91_add_device_mci(0, &foxg20_mci0_data); |
250 | /* I2C */ | 250 | /* I2C */ |
251 | at91_add_device_i2c(foxg20_i2c_devices, ARRAY_SIZE(foxg20_i2c_devices)); | 251 | at91_add_device_i2c(foxg20_i2c_devices, ARRAY_SIZE(foxg20_i2c_devices)); |
252 | /* LEDs */ | 252 | /* LEDs */ |
diff --git a/arch/arm/mach-at91/board-kb9202.c b/arch/arm/mach-at91/board-kb9202.c index ba39db5482b9..1fa6010ca504 100644 --- a/arch/arm/mach-at91/board-kb9202.c +++ b/arch/arm/mach-at91/board-kb9202.c | |||
@@ -68,12 +68,12 @@ static struct at91_udc_data __initdata kb9202_udc_data = { | |||
68 | .pullup_pin = AT91_PIN_PB22, | 68 | .pullup_pin = AT91_PIN_PB22, |
69 | }; | 69 | }; |
70 | 70 | ||
71 | static struct at91_mmc_data __initdata kb9202_mmc_data = { | 71 | static struct mci_platform_data __initdata kb9202_mci0_data = { |
72 | .det_pin = AT91_PIN_PB2, | 72 | .slot[0] = { |
73 | .slot_b = 0, | 73 | .bus_width = 4, |
74 | .wire4 = 1, | 74 | .detect_pin = AT91_PIN_PB2, |
75 | .wp_pin = -EINVAL, | 75 | .wp_pin = -EINVAL, |
76 | .vcc_pin = -EINVAL, | 76 | }, |
77 | }; | 77 | }; |
78 | 78 | ||
79 | static struct mtd_partition __initdata kb9202_nand_partition[] = { | 79 | static struct mtd_partition __initdata kb9202_nand_partition[] = { |
@@ -120,7 +120,7 @@ static void __init kb9202_board_init(void) | |||
120 | /* USB Device */ | 120 | /* USB Device */ |
121 | at91_add_device_udc(&kb9202_udc_data); | 121 | at91_add_device_udc(&kb9202_udc_data); |
122 | /* MMC */ | 122 | /* MMC */ |
123 | at91_add_device_mmc(0, &kb9202_mmc_data); | 123 | at91_add_device_mci(0, &kb9202_mci0_data); |
124 | /* I2C */ | 124 | /* I2C */ |
125 | at91_add_device_i2c(NULL, 0); | 125 | at91_add_device_i2c(NULL, 0); |
126 | /* SPI */ | 126 | /* SPI */ |
diff --git a/arch/arm/mach-at91/board-neocore926.c b/arch/arm/mach-at91/board-neocore926.c index d2f4cc161766..061168ee4f10 100644 --- a/arch/arm/mach-at91/board-neocore926.c +++ b/arch/arm/mach-at91/board-neocore926.c | |||
@@ -137,11 +137,12 @@ static struct spi_board_info neocore926_spi_devices[] = { | |||
137 | /* | 137 | /* |
138 | * MCI (SD/MMC) | 138 | * MCI (SD/MMC) |
139 | */ | 139 | */ |
140 | static struct at91_mmc_data __initdata neocore926_mmc_data = { | 140 | static struct mci_platform_data __initdata neocore926_mci0_data = { |
141 | .wire4 = 1, | 141 | .slot[0] = { |
142 | .det_pin = AT91_PIN_PE18, | 142 | .bus_width = 4, |
143 | .wp_pin = AT91_PIN_PE19, | 143 | .detect_pin = AT91_PIN_PE18, |
144 | .vcc_pin = -EINVAL, | 144 | .wp_pin = AT91_PIN_PE19, |
145 | }, | ||
145 | }; | 146 | }; |
146 | 147 | ||
147 | 148 | ||
@@ -353,7 +354,7 @@ static void __init neocore926_board_init(void) | |||
353 | neocore926_add_device_ts(); | 354 | neocore926_add_device_ts(); |
354 | 355 | ||
355 | /* MMC */ | 356 | /* MMC */ |
356 | at91_add_device_mmc(1, &neocore926_mmc_data); | 357 | at91_add_device_mci(0, &neocore926_mci0_data); |
357 | 358 | ||
358 | /* Ethernet */ | 359 | /* Ethernet */ |
359 | at91_add_device_eth(&neocore926_macb_data); | 360 | at91_add_device_eth(&neocore926_macb_data); |
diff --git a/arch/arm/mach-at91/board-picotux200.c b/arch/arm/mach-at91/board-picotux200.c index b45c0a5d5ca7..96db6b259f86 100644 --- a/arch/arm/mach-at91/board-picotux200.c +++ b/arch/arm/mach-at91/board-picotux200.c | |||
@@ -61,12 +61,12 @@ static struct at91_usbh_data __initdata picotux200_usbh_data = { | |||
61 | .overcurrent_pin= {-EINVAL, -EINVAL}, | 61 | .overcurrent_pin= {-EINVAL, -EINVAL}, |
62 | }; | 62 | }; |
63 | 63 | ||
64 | static struct at91_mmc_data __initdata picotux200_mmc_data = { | 64 | static struct mci_platform_data __initdata picotux200_mci0_data = { |
65 | .det_pin = AT91_PIN_PB27, | 65 | .slot[0] = { |
66 | .slot_b = 0, | 66 | .bus_width = 4, |
67 | .wire4 = 1, | 67 | .detect_pin = AT91_PIN_PB27, |
68 | .wp_pin = AT91_PIN_PA17, | 68 | .wp_pin = AT91_PIN_PA17, |
69 | .vcc_pin = -EINVAL, | 69 | }, |
70 | }; | 70 | }; |
71 | 71 | ||
72 | #define PICOTUX200_FLASH_BASE AT91_CHIPSELECT_0 | 72 | #define PICOTUX200_FLASH_BASE AT91_CHIPSELECT_0 |
@@ -111,7 +111,7 @@ static void __init picotux200_board_init(void) | |||
111 | at91_add_device_i2c(NULL, 0); | 111 | at91_add_device_i2c(NULL, 0); |
112 | /* MMC */ | 112 | /* MMC */ |
113 | at91_set_gpio_output(AT91_PIN_PB22, 1); /* this MMC card slot can optionally use SPI signaling (CS3). */ | 113 | at91_set_gpio_output(AT91_PIN_PB22, 1); /* this MMC card slot can optionally use SPI signaling (CS3). */ |
114 | at91_add_device_mmc(0, &picotux200_mmc_data); | 114 | at91_add_device_mci(0, &picotux200_mci0_data); |
115 | /* NOR Flash */ | 115 | /* NOR Flash */ |
116 | platform_device_register(&picotux200_flash); | 116 | platform_device_register(&picotux200_flash); |
117 | } | 117 | } |
diff --git a/arch/arm/mach-at91/board-qil-a9260.c b/arch/arm/mach-at91/board-qil-a9260.c index 0c61bf0d272c..847cc00e23df 100644 --- a/arch/arm/mach-at91/board-qil-a9260.c +++ b/arch/arm/mach-at91/board-qil-a9260.c | |||
@@ -155,12 +155,12 @@ static void __init ek_add_device_nand(void) | |||
155 | /* | 155 | /* |
156 | * MCI (SD/MMC) | 156 | * MCI (SD/MMC) |
157 | */ | 157 | */ |
158 | static struct at91_mmc_data __initdata ek_mmc_data = { | 158 | static struct mci_platform_data __initdata ek_mci0_data = { |
159 | .slot_b = 0, | 159 | .slot[0] = { |
160 | .wire4 = 1, | 160 | .bus_width = 4, |
161 | .det_pin = -EINVAL, | 161 | .detect_pin = -EINVAL, |
162 | .wp_pin = -EINVAL, | 162 | .wp_pin = -EINVAL, |
163 | .vcc_pin = -EINVAL, | 163 | }, |
164 | }; | 164 | }; |
165 | 165 | ||
166 | /* | 166 | /* |
@@ -244,7 +244,7 @@ static void __init ek_board_init(void) | |||
244 | /* Ethernet */ | 244 | /* Ethernet */ |
245 | at91_add_device_eth(&ek_macb_data); | 245 | at91_add_device_eth(&ek_macb_data); |
246 | /* MMC */ | 246 | /* MMC */ |
247 | at91_add_device_mmc(0, &ek_mmc_data); | 247 | at91_add_device_mci(0, &ek_mci0_data); |
248 | /* Push Buttons */ | 248 | /* Push Buttons */ |
249 | ek_add_device_buttons(); | 249 | ek_add_device_buttons(); |
250 | /* LEDs */ | 250 | /* LEDs */ |
diff --git a/arch/arm/mach-at91/board-rm9200dk.c b/arch/arm/mach-at91/board-rm9200dk.c index afd7a4713766..6564c13f5e22 100644 --- a/arch/arm/mach-at91/board-rm9200dk.c +++ b/arch/arm/mach-at91/board-rm9200dk.c | |||
@@ -76,12 +76,12 @@ static struct at91_cf_data __initdata dk_cf_data = { | |||
76 | }; | 76 | }; |
77 | 77 | ||
78 | #ifndef CONFIG_MTD_AT91_DATAFLASH_CARD | 78 | #ifndef CONFIG_MTD_AT91_DATAFLASH_CARD |
79 | static struct at91_mmc_data __initdata dk_mmc_data = { | 79 | static struct mci_platform_data __initdata dk_mci0_data = { |
80 | .slot_b = 0, | 80 | .slot[0] = { |
81 | .wire4 = 1, | 81 | .bus_width = 4, |
82 | .det_pin = -EINVAL, | 82 | .detect_pin = -EINVAL, |
83 | .wp_pin = -EINVAL, | 83 | .wp_pin = -EINVAL, |
84 | .vcc_pin = -EINVAL, | 84 | }, |
85 | }; | 85 | }; |
86 | #endif | 86 | #endif |
87 | 87 | ||
@@ -207,7 +207,7 @@ static void __init dk_board_init(void) | |||
207 | #else | 207 | #else |
208 | /* MMC */ | 208 | /* MMC */ |
209 | at91_set_gpio_output(AT91_PIN_PB7, 1); /* this MMC card slot can optionally use SPI signaling (CS3). */ | 209 | at91_set_gpio_output(AT91_PIN_PB7, 1); /* this MMC card slot can optionally use SPI signaling (CS3). */ |
210 | at91_add_device_mmc(0, &dk_mmc_data); | 210 | at91_add_device_mci(0, &dk_mci0_data); |
211 | #endif | 211 | #endif |
212 | /* NAND */ | 212 | /* NAND */ |
213 | at91_add_device_nand(&dk_nand_data); | 213 | at91_add_device_nand(&dk_nand_data); |
diff --git a/arch/arm/mach-at91/board-rm9200ek.c b/arch/arm/mach-at91/board-rm9200ek.c index 2b15b8adec4c..58144a0a5388 100644 --- a/arch/arm/mach-at91/board-rm9200ek.c +++ b/arch/arm/mach-at91/board-rm9200ek.c | |||
@@ -69,12 +69,12 @@ static struct at91_udc_data __initdata ek_udc_data = { | |||
69 | }; | 69 | }; |
70 | 70 | ||
71 | #ifndef CONFIG_MTD_AT91_DATAFLASH_CARD | 71 | #ifndef CONFIG_MTD_AT91_DATAFLASH_CARD |
72 | static struct at91_mmc_data __initdata ek_mmc_data = { | 72 | static struct mci_platform_data __initdata ek_mci0_data = { |
73 | .det_pin = AT91_PIN_PB27, | 73 | .slot[0] = { |
74 | .slot_b = 0, | 74 | .bus_width = 4, |
75 | .wire4 = 1, | 75 | .detect_pin = AT91_PIN_PB27, |
76 | .wp_pin = AT91_PIN_PA17, | 76 | .wp_pin = AT91_PIN_PA17, |
77 | .vcc_pin = -EINVAL, | 77 | } |
78 | }; | 78 | }; |
79 | #endif | 79 | #endif |
80 | 80 | ||
@@ -176,7 +176,7 @@ static void __init ek_board_init(void) | |||
176 | #else | 176 | #else |
177 | /* MMC */ | 177 | /* MMC */ |
178 | at91_set_gpio_output(AT91_PIN_PB22, 1); /* this MMC card slot can optionally use SPI signaling (CS3). */ | 178 | at91_set_gpio_output(AT91_PIN_PB22, 1); /* this MMC card slot can optionally use SPI signaling (CS3). */ |
179 | at91_add_device_mmc(0, &ek_mmc_data); | 179 | at91_add_device_mci(0, &ek_mci0_data); |
180 | #endif | 180 | #endif |
181 | /* NOR Flash */ | 181 | /* NOR Flash */ |
182 | platform_device_register(&ek_flash); | 182 | platform_device_register(&ek_flash); |
diff --git a/arch/arm/mach-at91/board-rsi-ews.c b/arch/arm/mach-at91/board-rsi-ews.c index 24ab9be7510f..f63158f1f022 100644 --- a/arch/arm/mach-at91/board-rsi-ews.c +++ b/arch/arm/mach-at91/board-rsi-ews.c | |||
@@ -57,11 +57,12 @@ static struct at91_usbh_data rsi_ews_usbh_data __initdata = { | |||
57 | /* | 57 | /* |
58 | * SD/MC | 58 | * SD/MC |
59 | */ | 59 | */ |
60 | static struct at91_mmc_data rsi_ews_mmc_data __initdata = { | 60 | static struct mci_platform_data __initdata rsi_ews_mci0_data = { |
61 | .slot_b = 0, | 61 | .slot[0] = { |
62 | .wire4 = 1, | 62 | .bus_width = 4, |
63 | .det_pin = AT91_PIN_PB27, | 63 | .detect_pin = AT91_PIN_PB27, |
64 | .wp_pin = AT91_PIN_PB29, | 64 | .wp_pin = AT91_PIN_PB29, |
65 | }, | ||
65 | }; | 66 | }; |
66 | 67 | ||
67 | /* | 68 | /* |
@@ -214,7 +215,7 @@ static void __init rsi_ews_board_init(void) | |||
214 | at91_add_device_spi(rsi_ews_spi_devices, | 215 | at91_add_device_spi(rsi_ews_spi_devices, |
215 | ARRAY_SIZE(rsi_ews_spi_devices)); | 216 | ARRAY_SIZE(rsi_ews_spi_devices)); |
216 | /* MMC */ | 217 | /* MMC */ |
217 | at91_add_device_mmc(0, &rsi_ews_mmc_data); | 218 | at91_add_device_mci(0, &rsi_ews_mci0_data); |
218 | /* NOR Flash */ | 219 | /* NOR Flash */ |
219 | platform_device_register(&rsiews_nor_flash); | 220 | platform_device_register(&rsiews_nor_flash); |
220 | /* LEDs */ | 221 | /* LEDs */ |
diff --git a/arch/arm/mach-at91/board-sam9-l9260.c b/arch/arm/mach-at91/board-sam9-l9260.c index cdd21f2595d2..0af92e6cce64 100644 --- a/arch/arm/mach-at91/board-sam9-l9260.c +++ b/arch/arm/mach-at91/board-sam9-l9260.c | |||
@@ -72,7 +72,7 @@ static struct at91_udc_data __initdata ek_udc_data = { | |||
72 | * SPI devices. | 72 | * SPI devices. |
73 | */ | 73 | */ |
74 | static struct spi_board_info ek_spi_devices[] = { | 74 | static struct spi_board_info ek_spi_devices[] = { |
75 | #if !defined(CONFIG_MMC_AT91) | 75 | #if !IS_ENABLED(CONFIG_MMC_ATMELMCI) |
76 | { /* DataFlash chip */ | 76 | { /* DataFlash chip */ |
77 | .modalias = "mtd_dataflash", | 77 | .modalias = "mtd_dataflash", |
78 | .chip_select = 1, | 78 | .chip_select = 1, |
@@ -157,12 +157,12 @@ static void __init ek_add_device_nand(void) | |||
157 | /* | 157 | /* |
158 | * MCI (SD/MMC) | 158 | * MCI (SD/MMC) |
159 | */ | 159 | */ |
160 | static struct at91_mmc_data __initdata ek_mmc_data = { | 160 | static struct mci_platform_data __initdata ek_mci0_data = { |
161 | .slot_b = 1, | 161 | .slot[1] = { |
162 | .wire4 = 1, | 162 | .bus_width = 4, |
163 | .det_pin = AT91_PIN_PC8, | 163 | .detect_pin = AT91_PIN_PC8, |
164 | .wp_pin = AT91_PIN_PC4, | 164 | .wp_pin = AT91_PIN_PC4, |
165 | .vcc_pin = -EINVAL, | 165 | }, |
166 | }; | 166 | }; |
167 | 167 | ||
168 | static void __init ek_board_init(void) | 168 | static void __init ek_board_init(void) |
@@ -193,7 +193,7 @@ static void __init ek_board_init(void) | |||
193 | /* Ethernet */ | 193 | /* Ethernet */ |
194 | at91_add_device_eth(&ek_macb_data); | 194 | at91_add_device_eth(&ek_macb_data); |
195 | /* MMC */ | 195 | /* MMC */ |
196 | at91_add_device_mmc(0, &ek_mmc_data); | 196 | at91_add_device_mci(0, &ek_mci0_data); |
197 | /* I2C */ | 197 | /* I2C */ |
198 | at91_add_device_i2c(NULL, 0); | 198 | at91_add_device_i2c(NULL, 0); |
199 | } | 199 | } |
diff --git a/arch/arm/mach-at91/board-sam9260ek.c b/arch/arm/mach-at91/board-sam9260ek.c index 7b3c3913551a..55f0104c0a4b 100644 --- a/arch/arm/mach-at91/board-sam9260ek.c +++ b/arch/arm/mach-at91/board-sam9260ek.c | |||
@@ -107,7 +107,7 @@ static void __init at73c213_set_clk(struct at73c213_board_info *info) {} | |||
107 | * SPI devices. | 107 | * SPI devices. |
108 | */ | 108 | */ |
109 | static struct spi_board_info ek_spi_devices[] = { | 109 | static struct spi_board_info ek_spi_devices[] = { |
110 | #if !defined(CONFIG_MMC_AT91) | 110 | #if !IS_ENABLED(CONFIG_MMC_ATMELMCI) |
111 | { /* DataFlash chip */ | 111 | { /* DataFlash chip */ |
112 | .modalias = "mtd_dataflash", | 112 | .modalias = "mtd_dataflash", |
113 | .chip_select = 1, | 113 | .chip_select = 1, |
@@ -210,12 +210,12 @@ static void __init ek_add_device_nand(void) | |||
210 | /* | 210 | /* |
211 | * MCI (SD/MMC) | 211 | * MCI (SD/MMC) |
212 | */ | 212 | */ |
213 | static struct at91_mmc_data __initdata ek_mmc_data = { | 213 | static struct mci_platform_data __initdata ek_mci0_data = { |
214 | .slot_b = 1, | 214 | .slot[1] = { |
215 | .wire4 = 1, | 215 | .bus_width = 4, |
216 | .det_pin = -EINVAL, | 216 | .detect_pin = -EINVAL, |
217 | .wp_pin = -EINVAL, | 217 | .wp_pin = -EINVAL, |
218 | .vcc_pin = -EINVAL, | 218 | }, |
219 | }; | 219 | }; |
220 | 220 | ||
221 | 221 | ||
@@ -328,7 +328,7 @@ static void __init ek_board_init(void) | |||
328 | /* Ethernet */ | 328 | /* Ethernet */ |
329 | at91_add_device_eth(&ek_macb_data); | 329 | at91_add_device_eth(&ek_macb_data); |
330 | /* MMC */ | 330 | /* MMC */ |
331 | at91_add_device_mmc(0, &ek_mmc_data); | 331 | at91_add_device_mci(0, &ek_mci0_data); |
332 | /* I2C */ | 332 | /* I2C */ |
333 | at91_add_device_i2c(ek_i2c_devices, ARRAY_SIZE(ek_i2c_devices)); | 333 | at91_add_device_i2c(ek_i2c_devices, ARRAY_SIZE(ek_i2c_devices)); |
334 | /* SSC (to AT73C213) */ | 334 | /* SSC (to AT73C213) */ |
diff --git a/arch/arm/mach-at91/board-sam9261ek.c b/arch/arm/mach-at91/board-sam9261ek.c index 2736453821b0..f3b2fe24fc56 100644 --- a/arch/arm/mach-at91/board-sam9261ek.c +++ b/arch/arm/mach-at91/board-sam9261ek.c | |||
@@ -339,11 +339,12 @@ static struct spi_board_info ek_spi_devices[] = { | |||
339 | * MCI (SD/MMC) | 339 | * MCI (SD/MMC) |
340 | * det_pin, wp_pin and vcc_pin are not connected | 340 | * det_pin, wp_pin and vcc_pin are not connected |
341 | */ | 341 | */ |
342 | static struct at91_mmc_data __initdata ek_mmc_data = { | 342 | static struct mci_platform_data __initdata mci0_data = { |
343 | .wire4 = 1, | 343 | .slot[0] = { |
344 | .det_pin = -EINVAL, | 344 | .bus_width = 4, |
345 | .wp_pin = -EINVAL, | 345 | .detect_pin = -EINVAL, |
346 | .vcc_pin = -EINVAL, | 346 | .wp_pin = -EINVAL, |
347 | }, | ||
347 | }; | 348 | }; |
348 | 349 | ||
349 | #endif /* CONFIG_SPI_ATMEL_* */ | 350 | #endif /* CONFIG_SPI_ATMEL_* */ |
@@ -597,7 +598,7 @@ static void __init ek_board_init(void) | |||
597 | at91_add_device_ssc(AT91SAM9261_ID_SSC1, ATMEL_SSC_TX); | 598 | at91_add_device_ssc(AT91SAM9261_ID_SSC1, ATMEL_SSC_TX); |
598 | #else | 599 | #else |
599 | /* MMC */ | 600 | /* MMC */ |
600 | at91_add_device_mmc(0, &ek_mmc_data); | 601 | at91_add_device_mci(0, &mci0_data); |
601 | #endif | 602 | #endif |
602 | /* LCD Controller */ | 603 | /* LCD Controller */ |
603 | at91_add_device_lcdc(&ek_lcdc_data); | 604 | at91_add_device_lcdc(&ek_lcdc_data); |
diff --git a/arch/arm/mach-at91/board-sam9263ek.c b/arch/arm/mach-at91/board-sam9263ek.c index 983cb98d2465..4c8d92a2ea17 100644 --- a/arch/arm/mach-at91/board-sam9263ek.c +++ b/arch/arm/mach-at91/board-sam9263ek.c | |||
@@ -140,11 +140,12 @@ static struct spi_board_info ek_spi_devices[] = { | |||
140 | /* | 140 | /* |
141 | * MCI (SD/MMC) | 141 | * MCI (SD/MMC) |
142 | */ | 142 | */ |
143 | static struct at91_mmc_data __initdata ek_mmc_data = { | 143 | static struct mci_platform_data __initdata mci1_data = { |
144 | .wire4 = 1, | 144 | .slot[0] = { |
145 | .det_pin = AT91_PIN_PE18, | 145 | .bus_width = 4, |
146 | .wp_pin = AT91_PIN_PE19, | 146 | .detect_pin = AT91_PIN_PE18, |
147 | .vcc_pin = -EINVAL, | 147 | .wp_pin = AT91_PIN_PE19, |
148 | }, | ||
148 | }; | 149 | }; |
149 | 150 | ||
150 | 151 | ||
@@ -419,7 +420,7 @@ static void __init ek_board_init(void) | |||
419 | /* Touchscreen */ | 420 | /* Touchscreen */ |
420 | ek_add_device_ts(); | 421 | ek_add_device_ts(); |
421 | /* MMC */ | 422 | /* MMC */ |
422 | at91_add_device_mmc(1, &ek_mmc_data); | 423 | at91_add_device_mci(1, &mci1_data); |
423 | /* Ethernet */ | 424 | /* Ethernet */ |
424 | at91_add_device_eth(&ek_macb_data); | 425 | at91_add_device_eth(&ek_macb_data); |
425 | /* NAND */ | 426 | /* NAND */ |
diff --git a/arch/arm/mach-at91/board-sam9g20ek.c b/arch/arm/mach-at91/board-sam9g20ek.c index 6860d3451100..40d595aaed28 100644 --- a/arch/arm/mach-at91/board-sam9g20ek.c +++ b/arch/arm/mach-at91/board-sam9g20ek.c | |||
@@ -91,7 +91,7 @@ static struct at91_udc_data __initdata ek_udc_data = { | |||
91 | * SPI devices. | 91 | * SPI devices. |
92 | */ | 92 | */ |
93 | static struct spi_board_info ek_spi_devices[] = { | 93 | static struct spi_board_info ek_spi_devices[] = { |
94 | #if !(defined(CONFIG_MMC_ATMELMCI) || defined(CONFIG_MMC_AT91)) | 94 | #if !IS_ENABLED(CONFIG_MMC_ATMELMCI) |
95 | { /* DataFlash chip */ | 95 | { /* DataFlash chip */ |
96 | .modalias = "mtd_dataflash", | 96 | .modalias = "mtd_dataflash", |
97 | .chip_select = 1, | 97 | .chip_select = 1, |
@@ -198,7 +198,6 @@ static void __init ek_add_device_nand(void) | |||
198 | * MCI (SD/MMC) | 198 | * MCI (SD/MMC) |
199 | * wp_pin and vcc_pin are not connected | 199 | * wp_pin and vcc_pin are not connected |
200 | */ | 200 | */ |
201 | #if defined(CONFIG_MMC_ATMELMCI) || defined(CONFIG_MMC_ATMELMCI_MODULE) | ||
202 | static struct mci_platform_data __initdata ek_mmc_data = { | 201 | static struct mci_platform_data __initdata ek_mmc_data = { |
203 | .slot[1] = { | 202 | .slot[1] = { |
204 | .bus_width = 4, | 203 | .bus_width = 4, |
@@ -207,28 +206,15 @@ static struct mci_platform_data __initdata ek_mmc_data = { | |||
207 | }, | 206 | }, |
208 | 207 | ||
209 | }; | 208 | }; |
210 | #else | ||
211 | static struct at91_mmc_data __initdata ek_mmc_data = { | ||
212 | .slot_b = 1, /* Only one slot so use slot B */ | ||
213 | .wire4 = 1, | ||
214 | .det_pin = AT91_PIN_PC9, | ||
215 | .wp_pin = -EINVAL, | ||
216 | .vcc_pin = -EINVAL, | ||
217 | }; | ||
218 | #endif | ||
219 | 209 | ||
220 | static void __init ek_add_device_mmc(void) | 210 | static void __init ek_add_device_mmc(void) |
221 | { | 211 | { |
222 | #if defined(CONFIG_MMC_ATMELMCI) || defined(CONFIG_MMC_ATMELMCI_MODULE) | ||
223 | if (ek_have_2mmc()) { | 212 | if (ek_have_2mmc()) { |
224 | ek_mmc_data.slot[0].bus_width = 4; | 213 | ek_mmc_data.slot[0].bus_width = 4; |
225 | ek_mmc_data.slot[0].detect_pin = AT91_PIN_PC2; | 214 | ek_mmc_data.slot[0].detect_pin = AT91_PIN_PC2; |
226 | ek_mmc_data.slot[0].wp_pin = -1; | 215 | ek_mmc_data.slot[0].wp_pin = -1; |
227 | } | 216 | } |
228 | at91_add_device_mci(0, &ek_mmc_data); | 217 | at91_add_device_mci(0, &ek_mmc_data); |
229 | #else | ||
230 | at91_add_device_mmc(0, &ek_mmc_data); | ||
231 | #endif | ||
232 | } | 218 | } |
233 | 219 | ||
234 | /* | 220 | /* |
diff --git a/arch/arm/mach-at91/board-sam9rlek.c b/arch/arm/mach-at91/board-sam9rlek.c index be3239f13daa..61d2ba8a4e57 100644 --- a/arch/arm/mach-at91/board-sam9rlek.c +++ b/arch/arm/mach-at91/board-sam9rlek.c | |||
@@ -55,11 +55,12 @@ static struct usba_platform_data __initdata ek_usba_udc_data = { | |||
55 | /* | 55 | /* |
56 | * MCI (SD/MMC) | 56 | * MCI (SD/MMC) |
57 | */ | 57 | */ |
58 | static struct at91_mmc_data __initdata ek_mmc_data = { | 58 | static struct mci_platform_data __initdata mci0_data = { |
59 | .wire4 = 1, | 59 | .slot[0] = { |
60 | .det_pin = AT91_PIN_PA15, | 60 | .bus_width = 4, |
61 | .wp_pin = -EINVAL, | 61 | .detect_pin = AT91_PIN_PA15, |
62 | .vcc_pin = -EINVAL, | 62 | .wp_pin = -EINVAL, |
63 | }, | ||
63 | }; | 64 | }; |
64 | 65 | ||
65 | 66 | ||
@@ -302,7 +303,7 @@ static void __init ek_board_init(void) | |||
302 | /* SPI */ | 303 | /* SPI */ |
303 | at91_add_device_spi(ek_spi_devices, ARRAY_SIZE(ek_spi_devices)); | 304 | at91_add_device_spi(ek_spi_devices, ARRAY_SIZE(ek_spi_devices)); |
304 | /* MMC */ | 305 | /* MMC */ |
305 | at91_add_device_mmc(0, &ek_mmc_data); | 306 | at91_add_device_mci(0, &mci0_data); |
306 | /* LCD Controller */ | 307 | /* LCD Controller */ |
307 | at91_add_device_lcdc(&ek_lcdc_data); | 308 | at91_add_device_lcdc(&ek_lcdc_data); |
308 | /* AC97 */ | 309 | /* AC97 */ |
diff --git a/arch/arm/mach-at91/board-stamp9g20.c b/arch/arm/mach-at91/board-stamp9g20.c index ee86f9d7ee72..7d890a065bb9 100644 --- a/arch/arm/mach-at91/board-stamp9g20.c +++ b/arch/arm/mach-at91/board-stamp9g20.c | |||
@@ -82,7 +82,6 @@ static void __init add_device_nand(void) | |||
82 | * MCI (SD/MMC) | 82 | * MCI (SD/MMC) |
83 | * det_pin, wp_pin and vcc_pin are not connected | 83 | * det_pin, wp_pin and vcc_pin are not connected |
84 | */ | 84 | */ |
85 | #if defined(CONFIG_MMC_ATMELMCI) || defined(CONFIG_MMC_ATMELMCI_MODULE) | ||
86 | static struct mci_platform_data __initdata mmc_data = { | 85 | static struct mci_platform_data __initdata mmc_data = { |
87 | .slot[0] = { | 86 | .slot[0] = { |
88 | .bus_width = 4, | 87 | .bus_width = 4, |
@@ -90,15 +89,6 @@ static struct mci_platform_data __initdata mmc_data = { | |||
90 | .wp_pin = -1, | 89 | .wp_pin = -1, |
91 | }, | 90 | }, |
92 | }; | 91 | }; |
93 | #else | ||
94 | static struct at91_mmc_data __initdata mmc_data = { | ||
95 | .slot_b = 0, | ||
96 | .wire4 = 1, | ||
97 | .det_pin = -EINVAL, | ||
98 | .wp_pin = -EINVAL, | ||
99 | .vcc_pin = -EINVAL, | ||
100 | }; | ||
101 | #endif | ||
102 | 92 | ||
103 | 93 | ||
104 | /* | 94 | /* |
@@ -222,11 +212,7 @@ void __init stamp9g20_board_init(void) | |||
222 | /* NAND */ | 212 | /* NAND */ |
223 | add_device_nand(); | 213 | add_device_nand(); |
224 | /* MMC */ | 214 | /* MMC */ |
225 | #if defined(CONFIG_MMC_ATMELMCI) || defined(CONFIG_MMC_ATMELMCI_MODULE) | ||
226 | at91_add_device_mci(0, &mmc_data); | 215 | at91_add_device_mci(0, &mmc_data); |
227 | #else | ||
228 | at91_add_device_mmc(0, &mmc_data); | ||
229 | #endif | ||
230 | /* W1 */ | 216 | /* W1 */ |
231 | add_w1(); | 217 | add_w1(); |
232 | } | 218 | } |
diff --git a/arch/arm/mach-at91/board-usb-a926x.c b/arch/arm/mach-at91/board-usb-a926x.c index 95393fcaf199..c87ea80fd121 100644 --- a/arch/arm/mach-at91/board-usb-a926x.c +++ b/arch/arm/mach-at91/board-usb-a926x.c | |||
@@ -108,14 +108,12 @@ static struct mmc_spi_platform_data at91_mmc_spi_pdata = { | |||
108 | * SPI devices. | 108 | * SPI devices. |
109 | */ | 109 | */ |
110 | static struct spi_board_info usb_a9263_spi_devices[] = { | 110 | static struct spi_board_info usb_a9263_spi_devices[] = { |
111 | #if !defined(CONFIG_MMC_AT91) | ||
112 | { /* DataFlash chip */ | 111 | { /* DataFlash chip */ |
113 | .modalias = "mtd_dataflash", | 112 | .modalias = "mtd_dataflash", |
114 | .chip_select = 0, | 113 | .chip_select = 0, |
115 | .max_speed_hz = 15 * 1000 * 1000, | 114 | .max_speed_hz = 15 * 1000 * 1000, |
116 | .bus_num = 0, | 115 | .bus_num = 0, |
117 | } | 116 | } |
118 | #endif | ||
119 | }; | 117 | }; |
120 | 118 | ||
121 | static struct spi_board_info usb_a9g20_spi_devices[] = { | 119 | static struct spi_board_info usb_a9g20_spi_devices[] = { |
diff --git a/arch/arm/mach-at91/board-yl-9200.c b/arch/arm/mach-at91/board-yl-9200.c index d56665ea4b55..6cb972e2f1e7 100644 --- a/arch/arm/mach-at91/board-yl-9200.c +++ b/arch/arm/mach-at91/board-yl-9200.c | |||
@@ -118,11 +118,12 @@ static struct at91_udc_data __initdata yl9200_udc_data = { | |||
118 | /* | 118 | /* |
119 | * MMC | 119 | * MMC |
120 | */ | 120 | */ |
121 | static struct at91_mmc_data __initdata yl9200_mmc_data = { | 121 | static struct mci_platform_data __initdata yl9200_mci0_data = { |
122 | .det_pin = AT91_PIN_PB9, | 122 | .slot[0] = { |
123 | .wire4 = 1, | 123 | .bus_width = 4, |
124 | .wp_pin = -EINVAL, | 124 | .detect_pin = AT91_PIN_PB9, |
125 | .vcc_pin = -EINVAL, | 125 | .wp_pin = -EINVAL, |
126 | }, | ||
126 | }; | 127 | }; |
127 | 128 | ||
128 | /* | 129 | /* |
@@ -567,7 +568,7 @@ static void __init yl9200_board_init(void) | |||
567 | /* I2C */ | 568 | /* I2C */ |
568 | at91_add_device_i2c(yl9200_i2c_devices, ARRAY_SIZE(yl9200_i2c_devices)); | 569 | at91_add_device_i2c(yl9200_i2c_devices, ARRAY_SIZE(yl9200_i2c_devices)); |
569 | /* MMC */ | 570 | /* MMC */ |
570 | at91_add_device_mmc(0, &yl9200_mmc_data); | 571 | at91_add_device_mci(0, &yl9200_mci0_data); |
571 | /* NAND */ | 572 | /* NAND */ |
572 | at91_add_device_nand(&yl9200_nand_data); | 573 | at91_add_device_nand(&yl9200_nand_data); |
573 | /* NOR Flash */ | 574 | /* NOR Flash */ |