Lauri Leukkunen | ffe7f95 | 2009-03-23 18:38:17 -0700 | [diff] [blame] | 1 | /* |
| 2 | * linux/arch/arm/mach-omap2/board-rx51.c |
| 3 | * |
| 4 | * Copyright (C) 2007, 2008 Nokia |
| 5 | * |
| 6 | * This program is free software; you can redistribute it and/or modify |
| 7 | * it under the terms of the GNU General Public License version 2 as |
| 8 | * published by the Free Software Foundation. |
| 9 | */ |
| 10 | |
| 11 | #include <linux/kernel.h> |
| 12 | #include <linux/init.h> |
| 13 | #include <linux/platform_device.h> |
| 14 | #include <linux/delay.h> |
| 15 | #include <linux/err.h> |
| 16 | #include <linux/clk.h> |
| 17 | #include <linux/io.h> |
Lauri Leukkunen | ffe7f95 | 2009-03-23 18:38:17 -0700 | [diff] [blame] | 18 | #include <linux/gpio.h> |
Kevin Hilman | a4b41d8 | 2009-10-02 08:17:56 -0700 | [diff] [blame] | 19 | #include <linux/leds.h> |
Lauri Leukkunen | ffe7f95 | 2009-03-23 18:38:17 -0700 | [diff] [blame] | 20 | |
| 21 | #include <mach/hardware.h> |
| 22 | #include <asm/mach-types.h> |
| 23 | #include <asm/mach/arch.h> |
| 24 | #include <asm/mach/map.h> |
| 25 | |
Tony Lindgren | ce491cf | 2009-10-20 09:40:47 -0700 | [diff] [blame] | 26 | #include <plat/mcspi.h> |
Tony Lindgren | ce491cf | 2009-10-20 09:40:47 -0700 | [diff] [blame] | 27 | #include <plat/board.h> |
| 28 | #include <plat/common.h> |
Tony Lindgren | ce491cf | 2009-10-20 09:40:47 -0700 | [diff] [blame] | 29 | #include <plat/dma.h> |
| 30 | #include <plat/gpmc.h> |
| 31 | #include <plat/usb.h> |
Lauri Leukkunen | ffe7f95 | 2009-03-23 18:38:17 -0700 | [diff] [blame] | 32 | |
Tony Lindgren | ca5742b | 2009-12-11 16:16:32 -0800 | [diff] [blame] | 33 | #include "mux.h" |
Kalle Jokiniemi | 5a1b1d3 | 2009-10-29 10:30:20 +0200 | [diff] [blame] | 34 | #include "pm.h" |
Aaro Koskinen | fcd8d846 | 2010-12-17 15:13:44 -0800 | [diff] [blame] | 35 | #include "sdram-nokia.h" |
Tony Lindgren | ca5742b | 2009-12-11 16:16:32 -0800 | [diff] [blame] | 36 | |
Kevin Hilman | a4b41d8 | 2009-10-02 08:17:56 -0700 | [diff] [blame] | 37 | #define RX51_GPIO_SLEEP_IND 162 |
Lauri Leukkunen | ffe7f95 | 2009-03-23 18:38:17 -0700 | [diff] [blame] | 38 | |
Roger Quadros | 03e1110 | 2010-05-10 10:35:17 +0200 | [diff] [blame] | 39 | extern void rx51_video_mem_init(void); |
Tero Kristo | 2000655 | 2009-11-22 10:11:36 -0800 | [diff] [blame] | 40 | |
Kevin Hilman | a4b41d8 | 2009-10-02 08:17:56 -0700 | [diff] [blame] | 41 | static struct gpio_led gpio_leds[] = { |
| 42 | { |
| 43 | .name = "sleep_ind", |
| 44 | .gpio = RX51_GPIO_SLEEP_IND, |
| 45 | }, |
| 46 | }; |
| 47 | |
| 48 | static struct gpio_led_platform_data gpio_led_info = { |
| 49 | .leds = gpio_leds, |
| 50 | .num_leds = ARRAY_SIZE(gpio_leds), |
| 51 | }; |
| 52 | |
| 53 | static struct platform_device leds_gpio = { |
| 54 | .name = "leds-gpio", |
| 55 | .id = -1, |
| 56 | .dev = { |
| 57 | .platform_data = &gpio_led_info, |
| 58 | }, |
| 59 | }; |
| 60 | |
Jean Pihet | 866ba0e | 2011-05-09 12:02:13 +0200 | [diff] [blame] | 61 | /* |
| 62 | * cpuidle C-states definition override from the default values. |
| 63 | * The 'exit_latency' field is the sum of sleep and wake-up latencies. |
| 64 | */ |
Kalle Jokiniemi | 5a1b1d3 | 2009-10-29 10:30:20 +0200 | [diff] [blame] | 65 | static struct cpuidle_params rx51_cpuidle_params[] = { |
| 66 | /* C1 */ |
Jean Pihet | 866ba0e | 2011-05-09 12:02:13 +0200 | [diff] [blame] | 67 | {110 + 162, 5 , 1}, |
Kalle Jokiniemi | 5a1b1d3 | 2009-10-29 10:30:20 +0200 | [diff] [blame] | 68 | /* C2 */ |
Jean Pihet | 866ba0e | 2011-05-09 12:02:13 +0200 | [diff] [blame] | 69 | {106 + 180, 309, 1}, |
Kalle Jokiniemi | 5a1b1d3 | 2009-10-29 10:30:20 +0200 | [diff] [blame] | 70 | /* C3 */ |
Jean Pihet | 866ba0e | 2011-05-09 12:02:13 +0200 | [diff] [blame] | 71 | {107 + 410, 46057, 0}, |
Kalle Jokiniemi | 5a1b1d3 | 2009-10-29 10:30:20 +0200 | [diff] [blame] | 72 | /* C4 */ |
Jean Pihet | 866ba0e | 2011-05-09 12:02:13 +0200 | [diff] [blame] | 73 | {121 + 3374, 46057, 0}, |
Kalle Jokiniemi | 5a1b1d3 | 2009-10-29 10:30:20 +0200 | [diff] [blame] | 74 | /* C5 */ |
Jean Pihet | 866ba0e | 2011-05-09 12:02:13 +0200 | [diff] [blame] | 75 | {855 + 1146, 46057, 1}, |
Kalle Jokiniemi | 5a1b1d3 | 2009-10-29 10:30:20 +0200 | [diff] [blame] | 76 | /* C6 */ |
Jean Pihet | 866ba0e | 2011-05-09 12:02:13 +0200 | [diff] [blame] | 77 | {7580 + 4134, 484329, 0}, |
Kalle Jokiniemi | 5a1b1d3 | 2009-10-29 10:30:20 +0200 | [diff] [blame] | 78 | /* C7 */ |
Jean Pihet | 866ba0e | 2011-05-09 12:02:13 +0200 | [diff] [blame] | 79 | {7505 + 15274, 484329, 1}, |
Kalle Jokiniemi | 5a1b1d3 | 2009-10-29 10:30:20 +0200 | [diff] [blame] | 80 | }; |
| 81 | |
Lauri Leukkunen | ffe7f95 | 2009-03-23 18:38:17 -0700 | [diff] [blame] | 82 | static struct omap_lcd_config rx51_lcd_config = { |
| 83 | .ctrl_name = "internal", |
| 84 | }; |
| 85 | |
| 86 | static struct omap_fbmem_config rx51_fbmem0_config = { |
| 87 | .size = 752 * 1024, |
| 88 | }; |
| 89 | |
| 90 | static struct omap_fbmem_config rx51_fbmem1_config = { |
| 91 | .size = 752 * 1024, |
| 92 | }; |
| 93 | |
| 94 | static struct omap_fbmem_config rx51_fbmem2_config = { |
| 95 | .size = 752 * 1024, |
| 96 | }; |
| 97 | |
| 98 | static struct omap_board_config_kernel rx51_config[] = { |
Lauri Leukkunen | ffe7f95 | 2009-03-23 18:38:17 -0700 | [diff] [blame] | 99 | { OMAP_TAG_FBMEM, &rx51_fbmem0_config }, |
| 100 | { OMAP_TAG_FBMEM, &rx51_fbmem1_config }, |
| 101 | { OMAP_TAG_FBMEM, &rx51_fbmem2_config }, |
| 102 | { OMAP_TAG_LCD, &rx51_lcd_config }, |
| 103 | }; |
| 104 | |
Lauri Leukkunen | ffe7f95 | 2009-03-23 18:38:17 -0700 | [diff] [blame] | 105 | extern void __init rx51_peripherals_init(void); |
| 106 | |
Tony Lindgren | ca5742b | 2009-12-11 16:16:32 -0800 | [diff] [blame] | 107 | #ifdef CONFIG_OMAP_MUX |
| 108 | static struct omap_board_mux board_mux[] __initdata = { |
| 109 | { .reg_offset = OMAP_MUX_TERMINATOR }, |
| 110 | }; |
Tony Lindgren | ca5742b | 2009-12-11 16:16:32 -0800 | [diff] [blame] | 111 | #endif |
| 112 | |
Maulik Mankad | 884b836 | 2010-02-17 14:09:30 -0800 | [diff] [blame] | 113 | static struct omap_musb_board_data musb_board_data = { |
| 114 | .interface_type = MUSB_INTERFACE_ULPI, |
| 115 | .mode = MUSB_PERIPHERAL, |
| 116 | .power = 0, |
| 117 | }; |
| 118 | |
Lauri Leukkunen | ffe7f95 | 2009-03-23 18:38:17 -0700 | [diff] [blame] | 119 | static void __init rx51_init(void) |
| 120 | { |
Tony Lindgren | a4ca9db | 2011-08-22 23:57:23 -0700 | [diff] [blame] | 121 | struct omap_sdrc_params *sdrc_params; |
| 122 | |
Tony Lindgren | ca5742b | 2009-12-11 16:16:32 -0800 | [diff] [blame] | 123 | omap3_mux_init(board_mux, OMAP_PACKAGE_CBB); |
Tony Lindgren | e41cccf | 2011-02-24 14:36:03 -0800 | [diff] [blame] | 124 | omap_board_config = rx51_config; |
| 125 | omap_board_config_size = ARRAY_SIZE(rx51_config); |
| 126 | omap3_pm_init_cpuidle(rx51_cpuidle_params); |
Lauri Leukkunen | ffe7f95 | 2009-03-23 18:38:17 -0700 | [diff] [blame] | 127 | omap_serial_init(); |
Tony Lindgren | a4ca9db | 2011-08-22 23:57:23 -0700 | [diff] [blame] | 128 | |
| 129 | sdrc_params = nokia_get_sdram_timings(); |
| 130 | omap_sdrc_init(sdrc_params, sdrc_params); |
| 131 | |
Maulik Mankad | 884b836 | 2010-02-17 14:09:30 -0800 | [diff] [blame] | 132 | usb_musb_init(&musb_board_data); |
Lauri Leukkunen | ffe7f95 | 2009-03-23 18:38:17 -0700 | [diff] [blame] | 133 | rx51_peripherals_init(); |
Jean Pihet | 9fb9741 | 2009-07-24 19:43:25 -0600 | [diff] [blame] | 134 | |
| 135 | /* Ensure SDRC pins are mux'd for self-refresh */ |
Tony Lindgren | 4896e39 | 2009-12-11 16:16:32 -0800 | [diff] [blame] | 136 | omap_mux_init_signal("sdrc_cke0", OMAP_PIN_OUTPUT); |
| 137 | omap_mux_init_signal("sdrc_cke1", OMAP_PIN_OUTPUT); |
Kevin Hilman | a4b41d8 | 2009-10-02 08:17:56 -0700 | [diff] [blame] | 138 | |
| 139 | platform_device_register(&leds_gpio); |
Lauri Leukkunen | ffe7f95 | 2009-03-23 18:38:17 -0700 | [diff] [blame] | 140 | } |
| 141 | |
| 142 | static void __init rx51_map_io(void) |
| 143 | { |
Sergio Aguirre | c573bcf | 2010-08-04 14:43:18 +0300 | [diff] [blame] | 144 | omap2_set_globals_3xxx(); |
Tony Lindgren | 6fbd55d | 2010-02-12 12:26:47 -0800 | [diff] [blame] | 145 | omap34xx_map_common_io(); |
Lauri Leukkunen | ffe7f95 | 2009-03-23 18:38:17 -0700 | [diff] [blame] | 146 | } |
| 147 | |
Felipe Contreras | 26a064d | 2011-04-26 02:45:28 -0700 | [diff] [blame] | 148 | static void __init rx51_reserve(void) |
| 149 | { |
| 150 | rx51_video_mem_init(); |
| 151 | omap_reserve(); |
| 152 | } |
| 153 | |
Lauri Leukkunen | ffe7f95 | 2009-03-23 18:38:17 -0700 | [diff] [blame] | 154 | MACHINE_START(NOKIA_RX51, "Nokia RX-51 board") |
| 155 | /* Maintainer: Lauri Leukkunen <lauri.leukkunen@nokia.com> */ |
Lauri Leukkunen | ffe7f95 | 2009-03-23 18:38:17 -0700 | [diff] [blame] | 156 | .boot_params = 0x80000100, |
Felipe Contreras | 26a064d | 2011-04-26 02:45:28 -0700 | [diff] [blame] | 157 | .reserve = rx51_reserve, |
Russell King - ARM Linux | 3dc3bad | 2011-02-14 15:40:20 -0800 | [diff] [blame] | 158 | .map_io = rx51_map_io, |
Tony Lindgren | 8f5b5a4 | 2011-08-22 23:57:24 -0700 | [diff] [blame^] | 159 | .init_early = omap3430_init_early, |
Tony Lindgren | 741e3a8 | 2011-05-17 03:51:26 -0700 | [diff] [blame] | 160 | .init_irq = omap3_init_irq, |
Lauri Leukkunen | ffe7f95 | 2009-03-23 18:38:17 -0700 | [diff] [blame] | 161 | .init_machine = rx51_init, |
Tony Lindgren | e74984e | 2011-03-29 15:54:48 -0700 | [diff] [blame] | 162 | .timer = &omap3_timer, |
Lauri Leukkunen | ffe7f95 | 2009-03-23 18:38:17 -0700 | [diff] [blame] | 163 | MACHINE_END |