Merge branch 'stanton-cs1-driver' of git://git.alsa-project.org/alsa-kprivate into...
[linux-2.6-block.git] / arch / sh / boards / mach-rsk / setup.c
CommitLineData
6feb3487 1/*
ea0aac1e 2 * Renesas Technology Europe RSK+ Support.
6feb3487 3 *
ea0aac1e 4 * Copyright (C) 2008 Paul Mundt
6feb3487
PG
5 * Copyright (C) 2008 Peter Griffin <pgriffin@mpc-data.co.uk>
6 *
7 * This file is subject to the terms and conditions of the GNU General Public
8 * License. See the file "COPYING" in the main directory of this archive
9 * for more details.
10 */
11#include <linux/init.h>
12#include <linux/types.h>
13#include <linux/platform_device.h>
14#include <linux/interrupt.h>
15#include <linux/mtd/mtd.h>
16#include <linux/mtd/partitions.h>
17#include <linux/mtd/physmap.h>
18#include <linux/mtd/map.h>
1190ef92
GL
19#include <linux/regulator/fixed.h>
20#include <linux/regulator/machine.h>
6feb3487
PG
21#include <asm/machvec.h>
22#include <asm/io.h>
23
1190ef92
GL
24/* Dummy supplies, where voltage doesn't matter */
25static struct regulator_consumer_supply dummy_supplies[] = {
26 REGULATOR_SUPPLY("vddvario", "smsc911x"),
27 REGULATOR_SUPPLY("vdd33a", "smsc911x"),
28};
29
603129af
PM
30static const char *part_probes[] = { "cmdlinepart", NULL };
31
ea0aac1e 32static struct mtd_partition rsk_partitions[] = {
6feb3487
PG
33 {
34 .name = "Bootloader",
35 .offset = 0x00000000,
36 .size = 0x00040000,
37 .mask_flags = MTD_WRITEABLE,
38 }, {
39 .name = "Kernel",
40 .offset = MTDPART_OFS_NXTBLK,
41 .size = 0x001c0000,
42 }, {
43 .name = "Flash_FS",
44 .offset = MTDPART_OFS_NXTBLK,
45 .size = MTDPART_SIZ_FULL,
46 }
47};
48
49static struct physmap_flash_data flash_data = {
603129af
PM
50 .parts = rsk_partitions,
51 .nr_parts = ARRAY_SIZE(rsk_partitions),
52 .width = 2,
53 .part_probe_types = part_probes,
6feb3487
PG
54};
55
56static struct resource flash_resource = {
57 .start = 0x20000000,
58 .end = 0x20400000,
59 .flags = IORESOURCE_MEM,
60};
61
62static struct platform_device flash_device = {
63 .name = "physmap-flash",
64 .id = -1,
65 .resource = &flash_resource,
66 .num_resources = 1,
67 .dev = {
68 .platform_data = &flash_data,
69 },
70};
71
ea0aac1e 72static struct platform_device *rsk_devices[] __initdata = {
6feb3487
PG
73 &flash_device,
74};
75
ea0aac1e 76static int __init rsk_devices_setup(void)
6feb3487 77{
1190ef92
GL
78 regulator_register_fixed(0, dummy_supplies, ARRAY_SIZE(dummy_supplies));
79
ea0aac1e
PM
80 return platform_add_devices(rsk_devices,
81 ARRAY_SIZE(rsk_devices));
6feb3487 82}
ea0aac1e 83device_initcall(rsk_devices_setup);
6feb3487
PG
84
85/*
86 * The Machine Vector
87 */
ea0aac1e
PM
88static struct sh_machine_vector mv_rsk __initmv = {
89 .mv_name = "RSK+",
6feb3487 90};