2  * arch/arm/mach-at91/at91sam9261_devices.c
 
   4  *  Copyright (C) 2005 Thibaut VARENE <varenet@parisc-linux.org>
 
   5  *  Copyright (C) 2005 David Brownell
 
   7  * This program is free software; you can redistribute it and/or modify
 
   8  * it under the terms of the GNU General Public License as published by
 
   9  * the Free Software Foundation; either version 2 of the License, or
 
  10  * (at your option) any later version.
 
  13 #include <asm/mach/arch.h>
 
  14 #include <asm/mach/map.h>
 
  16 #include <linux/dma-mapping.h>
 
  17 #include <linux/platform_device.h>
 
  18 #include <linux/i2c-gpio.h>
 
  21 #include <video/atmel_lcdc.h>
 
  23 #include <mach/board.h>
 
  24 #include <mach/gpio.h>
 
  25 #include <mach/at91sam9261.h>
 
  26 #include <mach/at91sam9261_matrix.h>
 
  27 #include <mach/at91sam9_smc.h>
 
  32 /* --------------------------------------------------------------------
 
  34  * -------------------------------------------------------------------- */
 
  36 #if defined(CONFIG_USB_OHCI_HCD) || defined(CONFIG_USB_OHCI_HCD_MODULE)
 
  37 static u64 ohci_dmamask = DMA_BIT_MASK(32);
 
  38 static struct at91_usbh_data usbh_data;
 
  40 static struct resource usbh_resources[] = {
 
  42                 .start  = AT91SAM9261_UHP_BASE,
 
  43                 .end    = AT91SAM9261_UHP_BASE + SZ_1M - 1,
 
  44                 .flags  = IORESOURCE_MEM,
 
  47                 .start  = AT91SAM9261_ID_UHP,
 
  48                 .end    = AT91SAM9261_ID_UHP,
 
  49                 .flags  = IORESOURCE_IRQ,
 
  53 static struct platform_device at91sam9261_usbh_device = {
 
  57                                 .dma_mask               = &ohci_dmamask,
 
  58                                 .coherent_dma_mask      = DMA_BIT_MASK(32),
 
  59                                 .platform_data          = &usbh_data,
 
  61         .resource       = usbh_resources,
 
  62         .num_resources  = ARRAY_SIZE(usbh_resources),
 
  65 void __init at91_add_device_usbh(struct at91_usbh_data *data)
 
  71         platform_device_register(&at91sam9261_usbh_device);
 
  74 void __init at91_add_device_usbh(struct at91_usbh_data *data) {}
 
  78 /* --------------------------------------------------------------------
 
  80  * -------------------------------------------------------------------- */
 
  82 #ifdef CONFIG_USB_GADGET_AT91
 
  83 static struct at91_udc_data udc_data;
 
  85 static struct resource udc_resources[] = {
 
  87                 .start  = AT91SAM9261_BASE_UDP,
 
  88                 .end    = AT91SAM9261_BASE_UDP + SZ_16K - 1,
 
  89                 .flags  = IORESOURCE_MEM,
 
  92                 .start  = AT91SAM9261_ID_UDP,
 
  93                 .end    = AT91SAM9261_ID_UDP,
 
  94                 .flags  = IORESOURCE_IRQ,
 
  98 static struct platform_device at91sam9261_udc_device = {
 
 102                                 .platform_data          = &udc_data,
 
 104         .resource       = udc_resources,
 
 105         .num_resources  = ARRAY_SIZE(udc_resources),
 
 108 void __init at91_add_device_udc(struct at91_udc_data *data)
 
 113         if (data->vbus_pin) {
 
 114                 at91_set_gpio_input(data->vbus_pin, 0);
 
 115                 at91_set_deglitch(data->vbus_pin, 1);
 
 118         /* Pullup pin is handled internally by USB device peripheral */
 
 121         platform_device_register(&at91sam9261_udc_device);
 
 124 void __init at91_add_device_udc(struct at91_udc_data *data) {}
 
 127 /* --------------------------------------------------------------------
 
 129  * -------------------------------------------------------------------- */
 
 131 #if defined(CONFIG_MMC_AT91) || defined(CONFIG_MMC_AT91_MODULE)
 
 132 static u64 mmc_dmamask = DMA_BIT_MASK(32);
 
 133 static struct at91_mmc_data mmc_data;
 
 135 static struct resource mmc_resources[] = {
 
 137                 .start  = AT91SAM9261_BASE_MCI,
 
 138                 .end    = AT91SAM9261_BASE_MCI + SZ_16K - 1,
 
 139                 .flags  = IORESOURCE_MEM,
 
 142                 .start  = AT91SAM9261_ID_MCI,
 
 143                 .end    = AT91SAM9261_ID_MCI,
 
 144                 .flags  = IORESOURCE_IRQ,
 
 148 static struct platform_device at91sam9261_mmc_device = {
 
 152                                 .dma_mask               = &mmc_dmamask,
 
 153                                 .coherent_dma_mask      = DMA_BIT_MASK(32),
 
 154                                 .platform_data          = &mmc_data,
 
 156         .resource       = mmc_resources,
 
 157         .num_resources  = ARRAY_SIZE(mmc_resources),
 
 160 void __init at91_add_device_mmc(short mmc_id, struct at91_mmc_data *data)
 
 167                 at91_set_gpio_input(data->det_pin, 1);
 
 168                 at91_set_deglitch(data->det_pin, 1);
 
 171                 at91_set_gpio_input(data->wp_pin, 1);
 
 173                 at91_set_gpio_output(data->vcc_pin, 0);
 
 176         at91_set_B_periph(AT91_PIN_PA2, 0);
 
 179         at91_set_B_periph(AT91_PIN_PA1, 1);
 
 181         /* DAT0, maybe DAT1..DAT3 */
 
 182         at91_set_B_periph(AT91_PIN_PA0, 1);
 
 184                 at91_set_B_periph(AT91_PIN_PA4, 1);
 
 185                 at91_set_B_periph(AT91_PIN_PA5, 1);
 
 186                 at91_set_B_periph(AT91_PIN_PA6, 1);
 
 190         platform_device_register(&at91sam9261_mmc_device);
 
 193 void __init at91_add_device_mmc(short mmc_id, struct at91_mmc_data *data) {}
 
 197 /* --------------------------------------------------------------------
 
 199  * -------------------------------------------------------------------- */
 
 201 #if defined(CONFIG_MTD_NAND_ATMEL) || defined(CONFIG_MTD_NAND_ATMEL_MODULE)
 
 202 static struct atmel_nand_data nand_data;
 
 204 #define NAND_BASE       AT91_CHIPSELECT_3
 
 206 static struct resource nand_resources[] = {
 
 209                 .end    = NAND_BASE + SZ_256M - 1,
 
 210                 .flags  = IORESOURCE_MEM,
 
 214 static struct platform_device atmel_nand_device = {
 
 215         .name           = "atmel_nand",
 
 218                                 .platform_data  = &nand_data,
 
 220         .resource       = nand_resources,
 
 221         .num_resources  = ARRAY_SIZE(nand_resources),
 
 224 void __init at91_add_device_nand(struct atmel_nand_data *data)
 
 231         csa = at91_sys_read(AT91_MATRIX_EBICSA);
 
 232         at91_sys_write(AT91_MATRIX_EBICSA, csa | AT91_MATRIX_CS3A_SMC_SMARTMEDIA);
 
 235         if (data->enable_pin)
 
 236                 at91_set_gpio_output(data->enable_pin, 1);
 
 240                 at91_set_gpio_input(data->rdy_pin, 1);
 
 242         /* card detect pin */
 
 244                 at91_set_gpio_input(data->det_pin, 1);
 
 246         at91_set_A_periph(AT91_PIN_PC0, 0);             /* NANDOE */
 
 247         at91_set_A_periph(AT91_PIN_PC1, 0);             /* NANDWE */
 
 250         platform_device_register(&atmel_nand_device);
 
 254 void __init at91_add_device_nand(struct atmel_nand_data *data) {}
 
 258 /* --------------------------------------------------------------------
 
 260  * -------------------------------------------------------------------- */
 
 263  * Prefer the GPIO code since the TWI controller isn't robust
 
 264  * (gets overruns and underruns under load) and can only issue
 
 265  * repeated STARTs in one scenario (the driver doesn't yet handle them).
 
 267 #if defined(CONFIG_I2C_GPIO) || defined(CONFIG_I2C_GPIO_MODULE)
 
 269 static struct i2c_gpio_platform_data pdata = {
 
 270         .sda_pin                = AT91_PIN_PA7,
 
 271         .sda_is_open_drain      = 1,
 
 272         .scl_pin                = AT91_PIN_PA8,
 
 273         .scl_is_open_drain      = 1,
 
 274         .udelay                 = 2,            /* ~100 kHz */
 
 277 static struct platform_device at91sam9261_twi_device = {
 
 280         .dev.platform_data      = &pdata,
 
 283 void __init at91_add_device_i2c(struct i2c_board_info *devices, int nr_devices)
 
 285         at91_set_GPIO_periph(AT91_PIN_PA7, 1);          /* TWD (SDA) */
 
 286         at91_set_multi_drive(AT91_PIN_PA7, 1);
 
 288         at91_set_GPIO_periph(AT91_PIN_PA8, 1);          /* TWCK (SCL) */
 
 289         at91_set_multi_drive(AT91_PIN_PA8, 1);
 
 291         i2c_register_board_info(0, devices, nr_devices);
 
 292         platform_device_register(&at91sam9261_twi_device);
 
 295 #elif defined(CONFIG_I2C_AT91) || defined(CONFIG_I2C_AT91_MODULE)
 
 297 static struct resource twi_resources[] = {
 
 299                 .start  = AT91SAM9261_BASE_TWI,
 
 300                 .end    = AT91SAM9261_BASE_TWI + SZ_16K - 1,
 
 301                 .flags  = IORESOURCE_MEM,
 
 304                 .start  = AT91SAM9261_ID_TWI,
 
 305                 .end    = AT91SAM9261_ID_TWI,
 
 306                 .flags  = IORESOURCE_IRQ,
 
 310 static struct platform_device at91sam9261_twi_device = {
 
 313         .resource       = twi_resources,
 
 314         .num_resources  = ARRAY_SIZE(twi_resources),
 
 317 void __init at91_add_device_i2c(struct i2c_board_info *devices, int nr_devices)
 
 319         /* pins used for TWI interface */
 
 320         at91_set_A_periph(AT91_PIN_PA7, 0);             /* TWD */
 
 321         at91_set_multi_drive(AT91_PIN_PA7, 1);
 
 323         at91_set_A_periph(AT91_PIN_PA8, 0);             /* TWCK */
 
 324         at91_set_multi_drive(AT91_PIN_PA8, 1);
 
 326         i2c_register_board_info(0, devices, nr_devices);
 
 327         platform_device_register(&at91sam9261_twi_device);
 
 330 void __init at91_add_device_i2c(struct i2c_board_info *devices, int nr_devices) {}
 
 334 /* --------------------------------------------------------------------
 
 336  * -------------------------------------------------------------------- */
 
 338 #if defined(CONFIG_SPI_ATMEL) || defined(CONFIG_SPI_ATMEL_MODULE)
 
 339 static u64 spi_dmamask = DMA_BIT_MASK(32);
 
 341 static struct resource spi0_resources[] = {
 
 343                 .start  = AT91SAM9261_BASE_SPI0,
 
 344                 .end    = AT91SAM9261_BASE_SPI0 + SZ_16K - 1,
 
 345                 .flags  = IORESOURCE_MEM,
 
 348                 .start  = AT91SAM9261_ID_SPI0,
 
 349                 .end    = AT91SAM9261_ID_SPI0,
 
 350                 .flags  = IORESOURCE_IRQ,
 
 354 static struct platform_device at91sam9261_spi0_device = {
 
 358                                 .dma_mask               = &spi_dmamask,
 
 359                                 .coherent_dma_mask      = DMA_BIT_MASK(32),
 
 361         .resource       = spi0_resources,
 
 362         .num_resources  = ARRAY_SIZE(spi0_resources),
 
 365 static const unsigned spi0_standard_cs[4] = { AT91_PIN_PA3, AT91_PIN_PA4, AT91_PIN_PA5, AT91_PIN_PA6 };
 
 367 static struct resource spi1_resources[] = {
 
 369                 .start  = AT91SAM9261_BASE_SPI1,
 
 370                 .end    = AT91SAM9261_BASE_SPI1 + SZ_16K - 1,
 
 371                 .flags  = IORESOURCE_MEM,
 
 374                 .start  = AT91SAM9261_ID_SPI1,
 
 375                 .end    = AT91SAM9261_ID_SPI1,
 
 376                 .flags  = IORESOURCE_IRQ,
 
 380 static struct platform_device at91sam9261_spi1_device = {
 
 384                                 .dma_mask               = &spi_dmamask,
 
 385                                 .coherent_dma_mask      = DMA_BIT_MASK(32),
 
 387         .resource       = spi1_resources,
 
 388         .num_resources  = ARRAY_SIZE(spi1_resources),
 
 391 static const unsigned spi1_standard_cs[4] = { AT91_PIN_PB28, AT91_PIN_PA24, AT91_PIN_PA25, AT91_PIN_PA26 };
 
 393 void __init at91_add_device_spi(struct spi_board_info *devices, int nr_devices)
 
 396         unsigned long cs_pin;
 
 397         short enable_spi0 = 0;
 
 398         short enable_spi1 = 0;
 
 400         /* Choose SPI chip-selects */
 
 401         for (i = 0; i < nr_devices; i++) {
 
 402                 if (devices[i].controller_data)
 
 403                         cs_pin = (unsigned long) devices[i].controller_data;
 
 404                 else if (devices[i].bus_num == 0)
 
 405                         cs_pin = spi0_standard_cs[devices[i].chip_select];
 
 407                         cs_pin = spi1_standard_cs[devices[i].chip_select];
 
 409                 if (devices[i].bus_num == 0)
 
 414                 /* enable chip-select pin */
 
 415                 at91_set_gpio_output(cs_pin, 1);
 
 417                 /* pass chip-select pin to driver */
 
 418                 devices[i].controller_data = (void *) cs_pin;
 
 421         spi_register_board_info(devices, nr_devices);
 
 423         /* Configure SPI bus(es) */
 
 425                 at91_set_A_periph(AT91_PIN_PA0, 0);     /* SPI0_MISO */
 
 426                 at91_set_A_periph(AT91_PIN_PA1, 0);     /* SPI0_MOSI */
 
 427                 at91_set_A_periph(AT91_PIN_PA2, 0);     /* SPI0_SPCK */
 
 429                 at91_clock_associate("spi0_clk", &at91sam9261_spi0_device.dev, "spi_clk");
 
 430                 platform_device_register(&at91sam9261_spi0_device);
 
 433                 at91_set_A_periph(AT91_PIN_PB30, 0);    /* SPI1_MISO */
 
 434                 at91_set_A_periph(AT91_PIN_PB31, 0);    /* SPI1_MOSI */
 
 435                 at91_set_A_periph(AT91_PIN_PB29, 0);    /* SPI1_SPCK */
 
 437                 at91_clock_associate("spi1_clk", &at91sam9261_spi1_device.dev, "spi_clk");
 
 438                 platform_device_register(&at91sam9261_spi1_device);
 
 442 void __init at91_add_device_spi(struct spi_board_info *devices, int nr_devices) {}
 
 446 /* --------------------------------------------------------------------
 
 448  * -------------------------------------------------------------------- */
 
 450 #if defined(CONFIG_FB_ATMEL) || defined(CONFIG_FB_ATMEL_MODULE)
 
 451 static u64 lcdc_dmamask = DMA_BIT_MASK(32);
 
 452 static struct atmel_lcdfb_info lcdc_data;
 
 454 static struct resource lcdc_resources[] = {
 
 456                 .start  = AT91SAM9261_LCDC_BASE,
 
 457                 .end    = AT91SAM9261_LCDC_BASE + SZ_4K - 1,
 
 458                 .flags  = IORESOURCE_MEM,
 
 461                 .start  = AT91SAM9261_ID_LCDC,
 
 462                 .end    = AT91SAM9261_ID_LCDC,
 
 463                 .flags  = IORESOURCE_IRQ,
 
 465 #if defined(CONFIG_FB_INTSRAM)
 
 467                 .start  = AT91SAM9261_SRAM_BASE,
 
 468                 .end    = AT91SAM9261_SRAM_BASE + AT91SAM9261_SRAM_SIZE - 1,
 
 469                 .flags  = IORESOURCE_MEM,
 
 474 static struct platform_device at91_lcdc_device = {
 
 475         .name           = "atmel_lcdfb",
 
 478                                 .dma_mask               = &lcdc_dmamask,
 
 479                                 .coherent_dma_mask      = DMA_BIT_MASK(32),
 
 480                                 .platform_data          = &lcdc_data,
 
 482         .resource       = lcdc_resources,
 
 483         .num_resources  = ARRAY_SIZE(lcdc_resources),
 
 486 void __init at91_add_device_lcdc(struct atmel_lcdfb_info *data)
 
 492 #if defined(CONFIG_FB_ATMEL_STN)
 
 493         at91_set_A_periph(AT91_PIN_PB0, 0);     /* LCDVSYNC */
 
 494         at91_set_A_periph(AT91_PIN_PB1, 0);     /* LCDHSYNC */
 
 495         at91_set_A_periph(AT91_PIN_PB2, 0);     /* LCDDOTCK */
 
 496         at91_set_A_periph(AT91_PIN_PB3, 0);     /* LCDDEN */
 
 497         at91_set_A_periph(AT91_PIN_PB4, 0);     /* LCDCC */
 
 498         at91_set_A_periph(AT91_PIN_PB5, 0);     /* LCDD0 */
 
 499         at91_set_A_periph(AT91_PIN_PB6, 0);     /* LCDD1 */
 
 500         at91_set_A_periph(AT91_PIN_PB7, 0);     /* LCDD2 */
 
 501         at91_set_A_periph(AT91_PIN_PB8, 0);     /* LCDD3 */
 
 503         at91_set_A_periph(AT91_PIN_PB1, 0);     /* LCDHSYNC */
 
 504         at91_set_A_periph(AT91_PIN_PB2, 0);     /* LCDDOTCK */
 
 505         at91_set_A_periph(AT91_PIN_PB3, 0);     /* LCDDEN */
 
 506         at91_set_A_periph(AT91_PIN_PB4, 0);     /* LCDCC */
 
 507         at91_set_A_periph(AT91_PIN_PB7, 0);     /* LCDD2 */
 
 508         at91_set_A_periph(AT91_PIN_PB8, 0);     /* LCDD3 */
 
 509         at91_set_A_periph(AT91_PIN_PB9, 0);     /* LCDD4 */
 
 510         at91_set_A_periph(AT91_PIN_PB10, 0);    /* LCDD5 */
 
 511         at91_set_A_periph(AT91_PIN_PB11, 0);    /* LCDD6 */
 
 512         at91_set_A_periph(AT91_PIN_PB12, 0);    /* LCDD7 */
 
 513         at91_set_A_periph(AT91_PIN_PB15, 0);    /* LCDD10 */
 
 514         at91_set_A_periph(AT91_PIN_PB16, 0);    /* LCDD11 */
 
 515         at91_set_A_periph(AT91_PIN_PB17, 0);    /* LCDD12 */
 
 516         at91_set_A_periph(AT91_PIN_PB18, 0);    /* LCDD13 */
 
 517         at91_set_A_periph(AT91_PIN_PB19, 0);    /* LCDD14 */
 
 518         at91_set_A_periph(AT91_PIN_PB20, 0);    /* LCDD15 */
 
 519         at91_set_B_periph(AT91_PIN_PB23, 0);    /* LCDD18 */
 
 520         at91_set_B_periph(AT91_PIN_PB24, 0);    /* LCDD19 */
 
 521         at91_set_B_periph(AT91_PIN_PB25, 0);    /* LCDD20 */
 
 522         at91_set_B_periph(AT91_PIN_PB26, 0);    /* LCDD21 */
 
 523         at91_set_B_periph(AT91_PIN_PB27, 0);    /* LCDD22 */
 
 524         at91_set_B_periph(AT91_PIN_PB28, 0);    /* LCDD23 */
 
 527         if (ARRAY_SIZE(lcdc_resources) > 2) {
 
 529                 struct resource *fb_res = &lcdc_resources[2];
 
 530                 size_t fb_len = fb_res->end - fb_res->start + 1;
 
 532                 fb = ioremap(fb_res->start, fb_len);
 
 534                         memset(fb, 0, fb_len);
 
 539         platform_device_register(&at91_lcdc_device);
 
 542 void __init at91_add_device_lcdc(struct atmel_lcdfb_info *data) {}
 
 546 /* --------------------------------------------------------------------
 
 547  *  Timer/Counter block
 
 548  * -------------------------------------------------------------------- */
 
 550 #ifdef CONFIG_ATMEL_TCLIB
 
 552 static struct resource tcb_resources[] = {
 
 554                 .start  = AT91SAM9261_BASE_TCB0,
 
 555                 .end    = AT91SAM9261_BASE_TCB0 + SZ_16K - 1,
 
 556                 .flags  = IORESOURCE_MEM,
 
 559                 .start  = AT91SAM9261_ID_TC0,
 
 560                 .end    = AT91SAM9261_ID_TC0,
 
 561                 .flags  = IORESOURCE_IRQ,
 
 564                 .start  = AT91SAM9261_ID_TC1,
 
 565                 .end    = AT91SAM9261_ID_TC1,
 
 566                 .flags  = IORESOURCE_IRQ,
 
 569                 .start  = AT91SAM9261_ID_TC2,
 
 570                 .end    = AT91SAM9261_ID_TC2,
 
 571                 .flags  = IORESOURCE_IRQ,
 
 575 static struct platform_device at91sam9261_tcb_device = {
 
 578         .resource       = tcb_resources,
 
 579         .num_resources  = ARRAY_SIZE(tcb_resources),
 
 582 static void __init at91_add_device_tc(void)
 
 584         /* this chip has a separate clock and irq for each TC channel */
 
 585         at91_clock_associate("tc0_clk", &at91sam9261_tcb_device.dev, "t0_clk");
 
 586         at91_clock_associate("tc1_clk", &at91sam9261_tcb_device.dev, "t1_clk");
 
 587         at91_clock_associate("tc2_clk", &at91sam9261_tcb_device.dev, "t2_clk");
 
 588         platform_device_register(&at91sam9261_tcb_device);
 
 591 static void __init at91_add_device_tc(void) { }
 
 595 /* --------------------------------------------------------------------
 
 597  * -------------------------------------------------------------------- */
 
 599 static struct resource rtt_resources[] = {
 
 601                 .start  = AT91_BASE_SYS + AT91_RTT,
 
 602                 .end    = AT91_BASE_SYS + AT91_RTT + SZ_16 - 1,
 
 603                 .flags  = IORESOURCE_MEM,
 
 607 static struct platform_device at91sam9261_rtt_device = {
 
 610         .resource       = rtt_resources,
 
 611         .num_resources  = ARRAY_SIZE(rtt_resources),
 
 614 static void __init at91_add_device_rtt(void)
 
 616         platform_device_register(&at91sam9261_rtt_device);
 
 620 /* --------------------------------------------------------------------
 
 622  * -------------------------------------------------------------------- */
 
 624 #if defined(CONFIG_AT91SAM9_WATCHDOG) || defined(CONFIG_AT91SAM9_WATCHDOG_MODULE)
 
 625 static struct platform_device at91sam9261_wdt_device = {
 
 631 static void __init at91_add_device_watchdog(void)
 
 633         platform_device_register(&at91sam9261_wdt_device);
 
 636 static void __init at91_add_device_watchdog(void) {}
 
 640 /* --------------------------------------------------------------------
 
 641  *  SSC -- Synchronous Serial Controller
 
 642  * -------------------------------------------------------------------- */
 
 644 #if defined(CONFIG_ATMEL_SSC) || defined(CONFIG_ATMEL_SSC_MODULE)
 
 645 static u64 ssc0_dmamask = DMA_BIT_MASK(32);
 
 647 static struct resource ssc0_resources[] = {
 
 649                 .start  = AT91SAM9261_BASE_SSC0,
 
 650                 .end    = AT91SAM9261_BASE_SSC0 + SZ_16K - 1,
 
 651                 .flags  = IORESOURCE_MEM,
 
 654                 .start  = AT91SAM9261_ID_SSC0,
 
 655                 .end    = AT91SAM9261_ID_SSC0,
 
 656                 .flags  = IORESOURCE_IRQ,
 
 660 static struct platform_device at91sam9261_ssc0_device = {
 
 664                 .dma_mask               = &ssc0_dmamask,
 
 665                 .coherent_dma_mask      = DMA_BIT_MASK(32),
 
 667         .resource       = ssc0_resources,
 
 668         .num_resources  = ARRAY_SIZE(ssc0_resources),
 
 671 static inline void configure_ssc0_pins(unsigned pins)
 
 673         if (pins & ATMEL_SSC_TF)
 
 674                 at91_set_A_periph(AT91_PIN_PB21, 1);
 
 675         if (pins & ATMEL_SSC_TK)
 
 676                 at91_set_A_periph(AT91_PIN_PB22, 1);
 
 677         if (pins & ATMEL_SSC_TD)
 
 678                 at91_set_A_periph(AT91_PIN_PB23, 1);
 
 679         if (pins & ATMEL_SSC_RD)
 
 680                 at91_set_A_periph(AT91_PIN_PB24, 1);
 
 681         if (pins & ATMEL_SSC_RK)
 
 682                 at91_set_A_periph(AT91_PIN_PB25, 1);
 
 683         if (pins & ATMEL_SSC_RF)
 
 684                 at91_set_A_periph(AT91_PIN_PB26, 1);
 
 687 static u64 ssc1_dmamask = DMA_BIT_MASK(32);
 
 689 static struct resource ssc1_resources[] = {
 
 691                 .start  = AT91SAM9261_BASE_SSC1,
 
 692                 .end    = AT91SAM9261_BASE_SSC1 + SZ_16K - 1,
 
 693                 .flags  = IORESOURCE_MEM,
 
 696                 .start  = AT91SAM9261_ID_SSC1,
 
 697                 .end    = AT91SAM9261_ID_SSC1,
 
 698                 .flags  = IORESOURCE_IRQ,
 
 702 static struct platform_device at91sam9261_ssc1_device = {
 
 706                 .dma_mask               = &ssc1_dmamask,
 
 707                 .coherent_dma_mask      = DMA_BIT_MASK(32),
 
 709         .resource       = ssc1_resources,
 
 710         .num_resources  = ARRAY_SIZE(ssc1_resources),
 
 713 static inline void configure_ssc1_pins(unsigned pins)
 
 715         if (pins & ATMEL_SSC_TF)
 
 716                 at91_set_B_periph(AT91_PIN_PA17, 1);
 
 717         if (pins & ATMEL_SSC_TK)
 
 718                 at91_set_B_periph(AT91_PIN_PA18, 1);
 
 719         if (pins & ATMEL_SSC_TD)
 
 720                 at91_set_B_periph(AT91_PIN_PA19, 1);
 
 721         if (pins & ATMEL_SSC_RD)
 
 722                 at91_set_B_periph(AT91_PIN_PA20, 1);
 
 723         if (pins & ATMEL_SSC_RK)
 
 724                 at91_set_B_periph(AT91_PIN_PA21, 1);
 
 725         if (pins & ATMEL_SSC_RF)
 
 726                 at91_set_B_periph(AT91_PIN_PA22, 1);
 
 729 static u64 ssc2_dmamask = DMA_BIT_MASK(32);
 
 731 static struct resource ssc2_resources[] = {
 
 733                 .start  = AT91SAM9261_BASE_SSC2,
 
 734                 .end    = AT91SAM9261_BASE_SSC2 + SZ_16K - 1,
 
 735                 .flags  = IORESOURCE_MEM,
 
 738                 .start  = AT91SAM9261_ID_SSC2,
 
 739                 .end    = AT91SAM9261_ID_SSC2,
 
 740                 .flags  = IORESOURCE_IRQ,
 
 744 static struct platform_device at91sam9261_ssc2_device = {
 
 748                 .dma_mask               = &ssc2_dmamask,
 
 749                 .coherent_dma_mask      = DMA_BIT_MASK(32),
 
 751         .resource       = ssc2_resources,
 
 752         .num_resources  = ARRAY_SIZE(ssc2_resources),
 
 755 static inline void configure_ssc2_pins(unsigned pins)
 
 757         if (pins & ATMEL_SSC_TF)
 
 758                 at91_set_B_periph(AT91_PIN_PC25, 1);
 
 759         if (pins & ATMEL_SSC_TK)
 
 760                 at91_set_B_periph(AT91_PIN_PC26, 1);
 
 761         if (pins & ATMEL_SSC_TD)
 
 762                 at91_set_B_periph(AT91_PIN_PC27, 1);
 
 763         if (pins & ATMEL_SSC_RD)
 
 764                 at91_set_B_periph(AT91_PIN_PC28, 1);
 
 765         if (pins & ATMEL_SSC_RK)
 
 766                 at91_set_B_periph(AT91_PIN_PC29, 1);
 
 767         if (pins & ATMEL_SSC_RF)
 
 768                 at91_set_B_periph(AT91_PIN_PC30, 1);
 
 772  * SSC controllers are accessed through library code, instead of any
 
 773  * kind of all-singing/all-dancing driver.  For example one could be
 
 774  * used by a particular I2S audio codec's driver, while another one
 
 775  * on the same system might be used by a custom data capture driver.
 
 777 void __init at91_add_device_ssc(unsigned id, unsigned pins)
 
 779         struct platform_device *pdev;
 
 782          * NOTE: caller is responsible for passing information matching
 
 783          * "pins" to whatever will be using each particular controller.
 
 786         case AT91SAM9261_ID_SSC0:
 
 787                 pdev = &at91sam9261_ssc0_device;
 
 788                 configure_ssc0_pins(pins);
 
 789                 at91_clock_associate("ssc0_clk", &pdev->dev, "pclk");
 
 791         case AT91SAM9261_ID_SSC1:
 
 792                 pdev = &at91sam9261_ssc1_device;
 
 793                 configure_ssc1_pins(pins);
 
 794                 at91_clock_associate("ssc1_clk", &pdev->dev, "pclk");
 
 796         case AT91SAM9261_ID_SSC2:
 
 797                 pdev = &at91sam9261_ssc2_device;
 
 798                 configure_ssc2_pins(pins);
 
 799                 at91_clock_associate("ssc2_clk", &pdev->dev, "pclk");
 
 805         platform_device_register(pdev);
 
 809 void __init at91_add_device_ssc(unsigned id, unsigned pins) {}
 
 813 /* --------------------------------------------------------------------
 
 815  * -------------------------------------------------------------------- */
 
 817 #if defined(CONFIG_SERIAL_ATMEL)
 
 818 static struct resource dbgu_resources[] = {
 
 820                 .start  = AT91_VA_BASE_SYS + AT91_DBGU,
 
 821                 .end    = AT91_VA_BASE_SYS + AT91_DBGU + SZ_512 - 1,
 
 822                 .flags  = IORESOURCE_MEM,
 
 825                 .start  = AT91_ID_SYS,
 
 827                 .flags  = IORESOURCE_IRQ,
 
 831 static struct atmel_uart_data dbgu_data = {
 
 833         .use_dma_rx     = 0,            /* DBGU not capable of receive DMA */
 
 834         .regs           = (void __iomem *)(AT91_VA_BASE_SYS + AT91_DBGU),
 
 837 static u64 dbgu_dmamask = DMA_BIT_MASK(32);
 
 839 static struct platform_device at91sam9261_dbgu_device = {
 
 840         .name           = "atmel_usart",
 
 843                                 .dma_mask               = &dbgu_dmamask,
 
 844                                 .coherent_dma_mask      = DMA_BIT_MASK(32),
 
 845                                 .platform_data          = &dbgu_data,
 
 847         .resource       = dbgu_resources,
 
 848         .num_resources  = ARRAY_SIZE(dbgu_resources),
 
 851 static inline void configure_dbgu_pins(void)
 
 853         at91_set_A_periph(AT91_PIN_PA9, 0);             /* DRXD */
 
 854         at91_set_A_periph(AT91_PIN_PA10, 1);            /* DTXD */
 
 857 static struct resource uart0_resources[] = {
 
 859                 .start  = AT91SAM9261_BASE_US0,
 
 860                 .end    = AT91SAM9261_BASE_US0 + SZ_16K - 1,
 
 861                 .flags  = IORESOURCE_MEM,
 
 864                 .start  = AT91SAM9261_ID_US0,
 
 865                 .end    = AT91SAM9261_ID_US0,
 
 866                 .flags  = IORESOURCE_IRQ,
 
 870 static struct atmel_uart_data uart0_data = {
 
 875 static u64 uart0_dmamask = DMA_BIT_MASK(32);
 
 877 static struct platform_device at91sam9261_uart0_device = {
 
 878         .name           = "atmel_usart",
 
 881                                 .dma_mask               = &uart0_dmamask,
 
 882                                 .coherent_dma_mask      = DMA_BIT_MASK(32),
 
 883                                 .platform_data          = &uart0_data,
 
 885         .resource       = uart0_resources,
 
 886         .num_resources  = ARRAY_SIZE(uart0_resources),
 
 889 static inline void configure_usart0_pins(unsigned pins)
 
 891         at91_set_A_periph(AT91_PIN_PC8, 1);             /* TXD0 */
 
 892         at91_set_A_periph(AT91_PIN_PC9, 0);             /* RXD0 */
 
 894         if (pins & ATMEL_UART_RTS)
 
 895                 at91_set_A_periph(AT91_PIN_PC10, 0);    /* RTS0 */
 
 896         if (pins & ATMEL_UART_CTS)
 
 897                 at91_set_A_periph(AT91_PIN_PC11, 0);    /* CTS0 */
 
 900 static struct resource uart1_resources[] = {
 
 902                 .start  = AT91SAM9261_BASE_US1,
 
 903                 .end    = AT91SAM9261_BASE_US1 + SZ_16K - 1,
 
 904                 .flags  = IORESOURCE_MEM,
 
 907                 .start  = AT91SAM9261_ID_US1,
 
 908                 .end    = AT91SAM9261_ID_US1,
 
 909                 .flags  = IORESOURCE_IRQ,
 
 913 static struct atmel_uart_data uart1_data = {
 
 918 static u64 uart1_dmamask = DMA_BIT_MASK(32);
 
 920 static struct platform_device at91sam9261_uart1_device = {
 
 921         .name           = "atmel_usart",
 
 924                                 .dma_mask               = &uart1_dmamask,
 
 925                                 .coherent_dma_mask      = DMA_BIT_MASK(32),
 
 926                                 .platform_data          = &uart1_data,
 
 928         .resource       = uart1_resources,
 
 929         .num_resources  = ARRAY_SIZE(uart1_resources),
 
 932 static inline void configure_usart1_pins(unsigned pins)
 
 934         at91_set_A_periph(AT91_PIN_PC12, 1);            /* TXD1 */
 
 935         at91_set_A_periph(AT91_PIN_PC13, 0);            /* RXD1 */
 
 937         if (pins & ATMEL_UART_RTS)
 
 938                 at91_set_B_periph(AT91_PIN_PA12, 0);    /* RTS1 */
 
 939         if (pins & ATMEL_UART_CTS)
 
 940                 at91_set_B_periph(AT91_PIN_PA13, 0);    /* CTS1 */
 
 943 static struct resource uart2_resources[] = {
 
 945                 .start  = AT91SAM9261_BASE_US2,
 
 946                 .end    = AT91SAM9261_BASE_US2 + SZ_16K - 1,
 
 947                 .flags  = IORESOURCE_MEM,
 
 950                 .start  = AT91SAM9261_ID_US2,
 
 951                 .end    = AT91SAM9261_ID_US2,
 
 952                 .flags  = IORESOURCE_IRQ,
 
 956 static struct atmel_uart_data uart2_data = {
 
 961 static u64 uart2_dmamask = DMA_BIT_MASK(32);
 
 963 static struct platform_device at91sam9261_uart2_device = {
 
 964         .name           = "atmel_usart",
 
 967                                 .dma_mask               = &uart2_dmamask,
 
 968                                 .coherent_dma_mask      = DMA_BIT_MASK(32),
 
 969                                 .platform_data          = &uart2_data,
 
 971         .resource       = uart2_resources,
 
 972         .num_resources  = ARRAY_SIZE(uart2_resources),
 
 975 static inline void configure_usart2_pins(unsigned pins)
 
 977         at91_set_A_periph(AT91_PIN_PC15, 0);            /* RXD2 */
 
 978         at91_set_A_periph(AT91_PIN_PC14, 1);            /* TXD2 */
 
 980         if (pins & ATMEL_UART_RTS)
 
 981                 at91_set_B_periph(AT91_PIN_PA15, 0);    /* RTS2*/
 
 982         if (pins & ATMEL_UART_CTS)
 
 983                 at91_set_B_periph(AT91_PIN_PA16, 0);    /* CTS2 */
 
 986 static struct platform_device *__initdata at91_uarts[ATMEL_MAX_UART];   /* the UARTs to use */
 
 987 struct platform_device *atmel_default_console_device;   /* the serial console device */
 
 989 void __init at91_register_uart(unsigned id, unsigned portnr, unsigned pins)
 
 991         struct platform_device *pdev;
 
 995                         pdev = &at91sam9261_dbgu_device;
 
 996                         configure_dbgu_pins();
 
 997                         at91_clock_associate("mck", &pdev->dev, "usart");
 
 999                 case AT91SAM9261_ID_US0:
 
1000                         pdev = &at91sam9261_uart0_device;
 
1001                         configure_usart0_pins(pins);
 
1002                         at91_clock_associate("usart0_clk", &pdev->dev, "usart");
 
1004                 case AT91SAM9261_ID_US1:
 
1005                         pdev = &at91sam9261_uart1_device;
 
1006                         configure_usart1_pins(pins);
 
1007                         at91_clock_associate("usart1_clk", &pdev->dev, "usart");
 
1009                 case AT91SAM9261_ID_US2:
 
1010                         pdev = &at91sam9261_uart2_device;
 
1011                         configure_usart2_pins(pins);
 
1012                         at91_clock_associate("usart2_clk", &pdev->dev, "usart");
 
1017         pdev->id = portnr;              /* update to mapped ID */
 
1019         if (portnr < ATMEL_MAX_UART)
 
1020                 at91_uarts[portnr] = pdev;
 
1023 void __init at91_set_serial_console(unsigned portnr)
 
1025         if (portnr < ATMEL_MAX_UART)
 
1026                 atmel_default_console_device = at91_uarts[portnr];
 
1029 void __init at91_add_device_serial(void)
 
1033         for (i = 0; i < ATMEL_MAX_UART; i++) {
 
1035                         platform_device_register(at91_uarts[i]);
 
1038         if (!atmel_default_console_device)
 
1039                 printk(KERN_INFO "AT91: No default serial console defined.\n");
 
1042 void __init at91_register_uart(unsigned id, unsigned portnr, unsigned pins) {}
 
1043 void __init at91_set_serial_console(unsigned portnr) {}
 
1044 void __init at91_add_device_serial(void) {}
 
1048 /* -------------------------------------------------------------------- */
 
1051  * These devices are always present and don't need any board-specific
 
1054 static int __init at91_add_standard_devices(void)
 
1056         at91_add_device_rtt();
 
1057         at91_add_device_watchdog();
 
1058         at91_add_device_tc();
 
1062 arch_initcall(at91_add_standard_devices);