2  * linux/arch/arm/mach-omap1/board-osk.c
 
   4  * Board specific init for OMAP5912 OSK
 
   6  * Written by Dirk Behme <dirk.behme@de.bosch.com>
 
   8  * This program is free software; you can redistribute it and/or modify it
 
   9  * under the terms of the GNU General Public License as published by the
 
  10  * Free Software Foundation; either version 2 of the License, or (at your
 
  11  * option) any later version.
 
  13  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED
 
  14  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
 
  15  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN
 
  16  * NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
 
  17  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
 
  18  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
 
  19  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
 
  20  * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 
  21  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
 
  22  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 
  24  * You should have received a copy of the  GNU General Public License along
 
  25  * with this program; if not, write  to the Free Software Foundation, Inc.,
 
  26  * 675 Mass Ave, Cambridge, MA 02139, USA.
 
  29 #include <linux/kernel.h>
 
  30 #include <linux/init.h>
 
  31 #include <linux/platform_device.h>
 
  32 #include <linux/interrupt.h>
 
  34 #include <linux/mtd/mtd.h>
 
  35 #include <linux/mtd/partitions.h>
 
  37 #include <asm/hardware.h>
 
  38 #include <asm/mach-types.h>
 
  39 #include <asm/mach/arch.h>
 
  40 #include <asm/mach/map.h>
 
  41 #include <asm/mach/flash.h>
 
  43 #include <asm/arch/gpio.h>
 
  44 #include <asm/arch/usb.h>
 
  45 #include <asm/arch/mux.h>
 
  46 #include <asm/arch/tc.h>
 
  47 #include <asm/arch/common.h>
 
  49 static struct mtd_partition osk_partitions[] = {
 
  50         /* bootloader (U-Boot, etc) in first sector */
 
  55               .mask_flags       = MTD_WRITEABLE, /* force read-only */
 
  57         /* bootloader params in the next sector */
 
  60               .offset           = MTDPART_OFS_APPEND,
 
  65               .offset           = MTDPART_OFS_APPEND,
 
  70               .offset           = MTDPART_OFS_APPEND,
 
  71               .size             = MTDPART_SIZ_FULL,
 
  76 static struct flash_platform_data osk_flash_data = {
 
  77         .map_name       = "cfi_probe",
 
  79         .parts          = osk_partitions,
 
  80         .nr_parts       = ARRAY_SIZE(osk_partitions),
 
  83 static struct resource osk_flash_resource = {
 
  84         /* this is on CS3, wherever it's mapped */
 
  85         .flags          = IORESOURCE_MEM,
 
  88 static struct platform_device osk5912_flash_device = {
 
  92                 .platform_data  = &osk_flash_data,
 
  95         .resource       = &osk_flash_resource,
 
  98 static struct resource osk5912_smc91x_resources[] = {
 
 100                 .start  = OMAP_OSK_ETHR_START,          /* Physical */
 
 101                 .end    = OMAP_OSK_ETHR_START + 0xf,
 
 102                 .flags  = IORESOURCE_MEM,
 
 105                 .start  = OMAP_GPIO_IRQ(0),
 
 106                 .end    = OMAP_GPIO_IRQ(0),
 
 107                 .flags  = IORESOURCE_IRQ,
 
 111 static struct platform_device osk5912_smc91x_device = {
 
 114         .num_resources  = ARRAY_SIZE(osk5912_smc91x_resources),
 
 115         .resource       = osk5912_smc91x_resources,
 
 118 static struct resource osk5912_cf_resources[] = {
 
 120                 .start  = OMAP_GPIO_IRQ(62),
 
 121                 .end    = OMAP_GPIO_IRQ(62),
 
 122                 .flags  = IORESOURCE_IRQ,
 
 126 static struct platform_device osk5912_cf_device = {
 
 130                 .platform_data  = (void *) 2 /* CS2 */,
 
 132         .num_resources  = ARRAY_SIZE(osk5912_cf_resources),
 
 133         .resource       = osk5912_cf_resources,
 
 136 static struct platform_device osk5912_mcbsp1_device = {
 
 137         .name           = "omap_mcbsp",
 
 141 static struct platform_device *osk5912_devices[] __initdata = {
 
 142         &osk5912_flash_device,
 
 143         &osk5912_smc91x_device,
 
 145         &osk5912_mcbsp1_device,
 
 148 static void __init osk_init_smc91x(void)
 
 150         if ((omap_request_gpio(0)) < 0) {
 
 151                 printk("Error requesting gpio 0 for smc91x irq\n");
 
 155         /* Check EMIFS wait states to fix errors with SMC_GET_PKT_HDR */
 
 159 static void __init osk_init_cf(void)
 
 161         omap_cfg_reg(M7_1610_GPIO62);
 
 162         if ((omap_request_gpio(62)) < 0) {
 
 163                 printk("Error requesting gpio 62 for CF irq\n");
 
 166         /* the CF I/O IRQ is really active-low */
 
 167         set_irq_type(OMAP_GPIO_IRQ(62), IRQT_FALLING);
 
 170 static void __init osk_init_irq(void)
 
 178 static struct omap_usb_config osk_usb_config __initdata = {
 
 179         /* has usb host connector (A) ... for development it can also
 
 180          * be used, with a NONSTANDARD gender-bending cable/dongle, as
 
 183 #ifdef  CONFIG_USB_GADGET_OMAP
 
 194 static struct omap_uart_config osk_uart_config __initdata = {
 
 195         .enabled_uarts = (1 << 0),
 
 198 static struct omap_lcd_config osk_lcd_config __initdata = {
 
 200         .ctrl_name      = "internal",
 
 203 static struct omap_board_config_kernel osk_config[] = {
 
 204         { OMAP_TAG_USB,           &osk_usb_config },
 
 205         { OMAP_TAG_UART,                &osk_uart_config },
 
 206         { OMAP_TAG_LCD,                 &osk_lcd_config },
 
 209 #ifdef  CONFIG_OMAP_OSK_MISTRAL
 
 213 osk_mistral_wake_interrupt(int irq, void *ignored, struct pt_regs *regs)
 
 219 static void __init osk_mistral_init(void)
 
 221         /* FIXME here's where to feed in framebuffer, touchpad, and
 
 222          * keyboard setup ...  not in the drivers for those devices!
 
 224          * NOTE:  we could actually tell if there's a Mistral board
 
 225          * attached, e.g. by trying to read something from the ads7846.
 
 226          * But this is too early for that...
 
 229         /* the sideways button (SW1) is for use as a "wakeup" button */
 
 230         omap_cfg_reg(N15_1610_MPUIO2);
 
 231         if (omap_request_gpio(OMAP_MPUIO(2)) == 0) {
 
 233                 omap_set_gpio_direction(OMAP_MPUIO(2), 1);
 
 234                 set_irq_type(OMAP_GPIO_IRQ(OMAP_MPUIO(2)), IRQT_RISING);
 
 236                 /* share the IRQ in case someone wants to use the
 
 237                  * button for more than wakeup from system sleep.
 
 239                 ret = request_irq(OMAP_GPIO_IRQ(OMAP_MPUIO(2)),
 
 240                                 &osk_mistral_wake_interrupt,
 
 241                                 SA_SHIRQ, "mistral_wakeup",
 
 242                                 &osk_mistral_wake_interrupt);
 
 244                         omap_free_gpio(OMAP_MPUIO(2));
 
 245                         printk(KERN_ERR "OSK+Mistral: no wakeup irq, %d?\n",
 
 248                         enable_irq_wake(OMAP_GPIO_IRQ(OMAP_MPUIO(2)));
 
 251                 printk(KERN_ERR "OSK+Mistral: wakeup button is awol\n");
 
 254 static void __init osk_mistral_init(void) { }
 
 257 static void __init osk_init(void)
 
 259         osk_flash_resource.end = osk_flash_resource.start = omap_cs3_phys();
 
 260         osk_flash_resource.end += SZ_32M - 1;
 
 261         platform_add_devices(osk5912_devices, ARRAY_SIZE(osk5912_devices));
 
 262         omap_board_config = osk_config;
 
 263         omap_board_config_size = ARRAY_SIZE(osk_config);
 
 264         USB_TRANSCEIVER_CTRL_REG |= (3 << 1);
 
 270 static void __init osk_map_io(void)
 
 272         omap_map_common_io();
 
 275 MACHINE_START(OMAP_OSK, "TI-OSK")
 
 276         /* Maintainer: Dirk Behme <dirk.behme@de.bosch.com> */
 
 277         .phys_io        = 0xfff00000,
 
 278         .io_pg_offst    = ((0xfef00000) >> 18) & 0xfffc,
 
 279         .boot_params    = 0x10000100,
 
 280         .map_io         = osk_map_io,
 
 281         .init_irq       = osk_init_irq,
 
 282         .init_machine   = osk_init,
 
 283         .timer          = &omap_timer,