blob: 5e52af5810d93bd2def50cf201efbc475c1c53a6 [file] [log] [blame]
Lauri Leukkunenffe7f952009-03-23 18:38:17 -07001/*
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 Leukkunenffe7f952009-03-23 18:38:17 -070018#include <linux/gpio.h>
Kevin Hilmana4b41d82009-10-02 08:17:56 -070019#include <linux/leds.h>
Lauri Leukkunenffe7f952009-03-23 18:38:17 -070020
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 Lindgrence491cf2009-10-20 09:40:47 -070026#include <plat/mcspi.h>
Tony Lindgrence491cf2009-10-20 09:40:47 -070027#include <plat/board.h>
28#include <plat/common.h>
Tony Lindgrence491cf2009-10-20 09:40:47 -070029#include <plat/dma.h>
30#include <plat/gpmc.h>
31#include <plat/usb.h>
Lauri Leukkunenffe7f952009-03-23 18:38:17 -070032
Tony Lindgrenca5742b2009-12-11 16:16:32 -080033#include "mux.h"
Kalle Jokiniemi5a1b1d32009-10-29 10:30:20 +020034#include "pm.h"
Aaro Koskinenfcd8d8462010-12-17 15:13:44 -080035#include "sdram-nokia.h"
Tony Lindgrenca5742b2009-12-11 16:16:32 -080036
Kevin Hilmana4b41d82009-10-02 08:17:56 -070037#define RX51_GPIO_SLEEP_IND 162
Lauri Leukkunenffe7f952009-03-23 18:38:17 -070038
Roger Quadros03e11102010-05-10 10:35:17 +020039extern void rx51_video_mem_init(void);
Tero Kristo20006552009-11-22 10:11:36 -080040
Kevin Hilmana4b41d82009-10-02 08:17:56 -070041static struct gpio_led gpio_leds[] = {
42 {
43 .name = "sleep_ind",
44 .gpio = RX51_GPIO_SLEEP_IND,
45 },
46};
47
48static struct gpio_led_platform_data gpio_led_info = {
49 .leds = gpio_leds,
50 .num_leds = ARRAY_SIZE(gpio_leds),
51};
52
53static struct platform_device leds_gpio = {
54 .name = "leds-gpio",
55 .id = -1,
56 .dev = {
57 .platform_data = &gpio_led_info,
58 },
59};
60
Jean Pihet866ba0e2011-05-09 12:02:13 +020061/*
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 Jokiniemi5a1b1d32009-10-29 10:30:20 +020065static struct cpuidle_params rx51_cpuidle_params[] = {
66 /* C1 */
Jean Pihet866ba0e2011-05-09 12:02:13 +020067 {110 + 162, 5 , 1},
Kalle Jokiniemi5a1b1d32009-10-29 10:30:20 +020068 /* C2 */
Jean Pihet866ba0e2011-05-09 12:02:13 +020069 {106 + 180, 309, 1},
Kalle Jokiniemi5a1b1d32009-10-29 10:30:20 +020070 /* C3 */
Jean Pihet866ba0e2011-05-09 12:02:13 +020071 {107 + 410, 46057, 0},
Kalle Jokiniemi5a1b1d32009-10-29 10:30:20 +020072 /* C4 */
Jean Pihet866ba0e2011-05-09 12:02:13 +020073 {121 + 3374, 46057, 0},
Kalle Jokiniemi5a1b1d32009-10-29 10:30:20 +020074 /* C5 */
Jean Pihet866ba0e2011-05-09 12:02:13 +020075 {855 + 1146, 46057, 1},
Kalle Jokiniemi5a1b1d32009-10-29 10:30:20 +020076 /* C6 */
Jean Pihet866ba0e2011-05-09 12:02:13 +020077 {7580 + 4134, 484329, 0},
Kalle Jokiniemi5a1b1d32009-10-29 10:30:20 +020078 /* C7 */
Jean Pihet866ba0e2011-05-09 12:02:13 +020079 {7505 + 15274, 484329, 1},
Kalle Jokiniemi5a1b1d32009-10-29 10:30:20 +020080};
81
Lauri Leukkunenffe7f952009-03-23 18:38:17 -070082extern void __init rx51_peripherals_init(void);
83
Tony Lindgrenca5742b2009-12-11 16:16:32 -080084#ifdef CONFIG_OMAP_MUX
85static struct omap_board_mux board_mux[] __initdata = {
86 { .reg_offset = OMAP_MUX_TERMINATOR },
87};
Tony Lindgrenca5742b2009-12-11 16:16:32 -080088#endif
89
Maulik Mankad884b8362010-02-17 14:09:30 -080090static struct omap_musb_board_data musb_board_data = {
91 .interface_type = MUSB_INTERFACE_ULPI,
92 .mode = MUSB_PERIPHERAL,
93 .power = 0,
94};
95
Lauri Leukkunenffe7f952009-03-23 18:38:17 -070096static void __init rx51_init(void)
97{
Tony Lindgrena4ca9db2011-08-22 23:57:23 -070098 struct omap_sdrc_params *sdrc_params;
99
Tony Lindgrenca5742b2009-12-11 16:16:32 -0800100 omap3_mux_init(board_mux, OMAP_PACKAGE_CBB);
Tony Lindgrene41cccf2011-02-24 14:36:03 -0800101 omap3_pm_init_cpuidle(rx51_cpuidle_params);
Lauri Leukkunenffe7f952009-03-23 18:38:17 -0700102 omap_serial_init();
Tony Lindgrena4ca9db2011-08-22 23:57:23 -0700103
104 sdrc_params = nokia_get_sdram_timings();
105 omap_sdrc_init(sdrc_params, sdrc_params);
106
Maulik Mankad884b8362010-02-17 14:09:30 -0800107 usb_musb_init(&musb_board_data);
Lauri Leukkunenffe7f952009-03-23 18:38:17 -0700108 rx51_peripherals_init();
Jean Pihet9fb97412009-07-24 19:43:25 -0600109
110 /* Ensure SDRC pins are mux'd for self-refresh */
Tony Lindgren4896e392009-12-11 16:16:32 -0800111 omap_mux_init_signal("sdrc_cke0", OMAP_PIN_OUTPUT);
112 omap_mux_init_signal("sdrc_cke1", OMAP_PIN_OUTPUT);
Kevin Hilmana4b41d82009-10-02 08:17:56 -0700113
114 platform_device_register(&leds_gpio);
Lauri Leukkunenffe7f952009-03-23 18:38:17 -0700115}
116
Felipe Contreras26a064d2011-04-26 02:45:28 -0700117static void __init rx51_reserve(void)
118{
119 rx51_video_mem_init();
120 omap_reserve();
121}
122
Lauri Leukkunenffe7f952009-03-23 18:38:17 -0700123MACHINE_START(NOKIA_RX51, "Nokia RX-51 board")
124 /* Maintainer: Lauri Leukkunen <lauri.leukkunen@nokia.com> */
Nicolas Pitre5e52b432011-07-05 22:38:15 -0400125 .atag_offset = 0x100,
Felipe Contreras26a064d2011-04-26 02:45:28 -0700126 .reserve = rx51_reserve,
Tony Lindgrene990a402011-09-26 14:52:55 -0700127 .map_io = omap3_map_io,
Tony Lindgren8f5b5a42011-08-22 23:57:24 -0700128 .init_early = omap3430_init_early,
Tony Lindgren741e3a82011-05-17 03:51:26 -0700129 .init_irq = omap3_init_irq,
Marc Zyngier6b2f55d2011-09-06 10:23:45 +0100130 .handle_irq = omap3_intc_handle_irq,
Lauri Leukkunenffe7f952009-03-23 18:38:17 -0700131 .init_machine = rx51_init,
Tony Lindgrene74984e2011-03-29 15:54:48 -0700132 .timer = &omap3_timer,
Lauri Leukkunenffe7f952009-03-23 18:38:17 -0700133MACHINE_END