/* * Renesas Technology Europe RSK+ 7203 Support. * * Copyright (C) 2008 Paul Mundt * * This file is subject to the terms and conditions of the GNU General Public * License. See the file "COPYING" in the main directory of this archive * for more details. */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include static struct smc911x_platdata smc911x_info = { .flags = SMC911X_USE_16BIT, .irq_flags = IRQF_TRIGGER_LOW, }; static struct resource smc911x_resources[] = { [0] = { .start = 0x24000000, .end = 0x24000000 + 0x100, .flags = IORESOURCE_MEM, }, [1] = { .start = 64, .end = 64, .flags = IORESOURCE_IRQ, }, }; static struct platform_device smc911x_device = { .name = "smc911x", .id = -1, .num_resources = ARRAY_SIZE(smc911x_resources), .resource = smc911x_resources, .dev = { .platform_data = &smc911x_info, }, }; static struct gpio_led rsk7203_gpio_leds[] = { { .name = "green", .gpio = GPIO_PE10, .active_low = 1, }, { .name = "orange", .default_trigger = "nand-disk", .gpio = GPIO_PE12, .active_low = 1, }, { .name = "red:timer", .default_trigger = "timer", .gpio = GPIO_PC14, .active_low = 1, }, { .name = "red:heartbeat", .default_trigger = "heartbeat", .gpio = GPIO_PE11, .active_low = 1, }, }; static struct gpio_led_platform_data rsk7203_gpio_leds_info = { .leds = rsk7203_gpio_leds, .num_leds = ARRAY_SIZE(rsk7203_gpio_leds), }; static struct platform_device led_device = { .name = "leds-gpio", .id = -1, .dev = { .platform_data = &rsk7203_gpio_leds_info, }, }; static struct platform_device *rsk7203_devices[] __initdata = { &smc911x_device, &led_device, }; static int __init rsk7203_devices_setup(void) { /* Select pins for SCIF0 */ gpio_request(GPIO_FN_TXD0, NULL); gpio_request(GPIO_FN_RXD0, NULL); return platform_add_devices(rsk7203_devices, ARRAY_SIZE(rsk7203_devices)); } device_initcall(rsk7203_devices_setup);