2 * This program is free software; you can redistribute it and/or modify it
3 * under the terms of the GNU General Public License version 2 as published
4 * by the Free Software Foundation.
6 * Copyright (C) 2010 John Crispin <blogic@openwrt.org>
9 #include <linux/init.h>
10 #include <linux/module.h>
11 #include <linux/types.h>
12 #include <linux/string.h>
13 #include <linux/mtd/physmap.h>
14 #include <linux/kernel.h>
15 #include <linux/reboot.h>
16 #include <linux/platform_device.h>
17 #include <linux/leds.h>
18 #include <linux/etherdevice.h>
19 #include <linux/reboot.h>
20 #include <linux/time.h>
22 #include <linux/gpio.h>
23 #include <linux/leds.h>
25 #include <asm/bootinfo.h>
28 #include <lantiq_soc.h>
29 #include <lantiq_irq.h>
30 #include <lantiq_platform.h>
35 static struct resource ltq_gpio_resource
[] = {
38 .start
= LTQ_GPIO0_BASE_ADDR
,
39 .end
= LTQ_GPIO0_BASE_ADDR
+ LTQ_GPIO_SIZE
- 1,
40 .flags
= IORESOURCE_MEM
,
43 .start
= LTQ_GPIO1_BASE_ADDR
,
44 .end
= LTQ_GPIO1_BASE_ADDR
+ LTQ_GPIO_SIZE
- 1,
45 .flags
= IORESOURCE_MEM
,
48 .start
= LTQ_GPIO2_BASE_ADDR
,
49 .end
= LTQ_GPIO2_BASE_ADDR
+ LTQ_GPIO_SIZE
- 1,
50 .flags
= IORESOURCE_MEM
,
54 void __init
ltq_register_gpio(void)
56 platform_device_register_simple("ltq_gpio", 0,
57 <q_gpio_resource
[0], 1);
58 platform_device_register_simple("ltq_gpio", 1,
59 <q_gpio_resource
[1], 1);
61 /* AR9 and VR9 have an extra gpio block */
62 if (ltq_is_ar9() || ltq_is_vr9()) {
63 platform_device_register_simple("ltq_gpio", 2,
64 <q_gpio_resource
[2], 1);
68 /* serial to parallel conversion */
69 static struct resource ltq_stp_resource
= {
71 .start
= LTQ_STP_BASE_ADDR
,
72 .end
= LTQ_STP_BASE_ADDR
+ LTQ_STP_SIZE
- 1,
73 .flags
= IORESOURCE_MEM
,
76 void __init
ltq_register_gpio_stp(void)
78 platform_device_register_simple("ltq_stp", 0, <q_stp_resource
, 1);
81 /* asc ports - amazon se has its own serial mapping */
82 static struct resource ltq_ase_asc_resources
[] = {
85 .start
= LTQ_ASC1_BASE_ADDR
,
86 .end
= LTQ_ASC1_BASE_ADDR
+ LTQ_ASC_SIZE
- 1,
87 .flags
= IORESOURCE_MEM
,
89 IRQ_RES(tx
, LTQ_ASC_ASE_TIR
),
90 IRQ_RES(rx
, LTQ_ASC_ASE_RIR
),
91 IRQ_RES(err
, LTQ_ASC_ASE_EIR
),
94 void __init
ltq_register_ase_asc(void)
96 platform_device_register_simple("ltq_asc", 0,
97 ltq_ase_asc_resources
, ARRAY_SIZE(ltq_ase_asc_resources
));
101 static struct resource ltq_etop_resources
= {
103 .start
= LTQ_ETOP_BASE_ADDR
,
104 .end
= LTQ_ETOP_BASE_ADDR
+ LTQ_ETOP_SIZE
- 1,
105 .flags
= IORESOURCE_MEM
,
108 static struct platform_device ltq_etop
= {
110 .resource
= <q_etop_resources
,
115 ltq_register_etop(struct ltq_eth_data
*eth
)
118 ltq_etop
.dev
.platform_data
= eth
;
119 platform_device_register(<q_etop
);