Commit | Line | Data |
---|---|---|
1394f032 BW |
1 | /* |
2 | * File: arch/blackfin/mach-bf561/generic_board.c | |
3 | * Based on: arch/blackfin/mach-bf533/ezkit.c | |
4 | * Author: Aidan Williams <aidan@nicta.com.au> | |
5 | * | |
6 | * Created: | |
7 | * Description: | |
8 | * | |
9 | * Modified: | |
10 | * Copyright 2005 National ICT Australia (NICTA) | |
11 | * Copyright 2004-2006 Analog Devices Inc. | |
12 | * | |
13 | * Bugs: Enter bugs at http://blackfin.uclinux.org/ | |
14 | * | |
15 | * This program is free software; you can redistribute it and/or modify | |
16 | * it under the terms of the GNU General Public License as published by | |
17 | * the Free Software Foundation; either version 2 of the License, or | |
18 | * (at your option) any later version. | |
19 | * | |
20 | * This program is distributed in the hope that it will be useful, | |
21 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
22 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
23 | * GNU General Public License for more details. | |
24 | * | |
25 | * You should have received a copy of the GNU General Public License | |
26 | * along with this program; if not, see the file COPYING, or write | |
27 | * to the Free Software Foundation, Inc., | |
28 | * 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA | |
29 | */ | |
30 | ||
31 | #include <linux/device.h> | |
32 | #include <linux/platform_device.h> | |
1f83b8f1 | 33 | #include <linux/irq.h> |
1394f032 | 34 | |
066954a3 | 35 | const char bfin_board_name[] = "UNKNOWN BOARD"; |
1394f032 BW |
36 | |
37 | /* | |
38 | * Driver needs to know address, irq and flag pin. | |
39 | */ | |
40 | #if defined(CONFIG_SMC91X) || defined(CONFIG_SMC91X_MODULE) | |
41 | static struct resource smc91x_resources[] = { | |
42 | { | |
43 | .start = 0x2C010300, | |
44 | .end = 0x2C010300 + 16, | |
45 | .flags = IORESOURCE_MEM, | |
1f83b8f1 | 46 | }, { |
1394f032 BW |
47 | .start = IRQ_PROG_INTB, |
48 | .end = IRQ_PROG_INTB, | |
49 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHLEVEL, | |
1f83b8f1 | 50 | }, { |
1394f032 BW |
51 | .start = IRQ_PF9, |
52 | .end = IRQ_PF9, | |
53 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHLEVEL, | |
54 | }, | |
55 | }; | |
56 | ||
57 | static struct platform_device smc91x_device = { | |
58 | .name = "smc91x", | |
59 | .id = 0, | |
60 | .num_resources = ARRAY_SIZE(smc91x_resources), | |
61 | .resource = smc91x_resources, | |
62 | }; | |
63 | #endif | |
64 | ||
42bd8bcb GY |
65 | #if defined(CONFIG_BFIN_SIR) || defined(CONFIG_BFIN_SIR_MODULE) |
66 | #ifdef CONFIG_BFIN_SIR0 | |
67 | static struct resource bfin_sir0_resources[] = { | |
68 | { | |
69 | .start = 0xFFC00400, | |
70 | .end = 0xFFC004FF, | |
71 | .flags = IORESOURCE_MEM, | |
72 | }, | |
73 | { | |
74 | .start = IRQ_UART0_RX, | |
75 | .end = IRQ_UART0_RX+1, | |
76 | .flags = IORESOURCE_IRQ, | |
77 | }, | |
78 | { | |
79 | .start = CH_UART0_RX, | |
80 | .end = CH_UART0_RX+1, | |
81 | .flags = IORESOURCE_DMA, | |
82 | }, | |
83 | }; | |
84 | ||
85 | static struct platform_device bfin_sir0_device = { | |
86 | .name = "bfin_sir", | |
87 | .id = 0, | |
88 | .num_resources = ARRAY_SIZE(bfin_sir0_resources), | |
89 | .resource = bfin_sir0_resources, | |
90 | }; | |
91 | #endif | |
92 | #endif | |
93 | ||
1394f032 BW |
94 | static struct platform_device *generic_board_devices[] __initdata = { |
95 | #if defined(CONFIG_SMC91X) || defined(CONFIG_SMC91X_MODULE) | |
96 | &smc91x_device, | |
97 | #endif | |
42bd8bcb GY |
98 | |
99 | #if defined(CONFIG_BFIN_SIR) || defined(CONFIG_BFIN_SIR_MODULE) | |
100 | #ifdef CONFIG_BFIN_SIR0 | |
101 | &bfin_sir0_device, | |
102 | #endif | |
103 | #endif | |
1394f032 BW |
104 | }; |
105 | ||
106 | static int __init generic_board_init(void) | |
107 | { | |
b85d858b | 108 | printk(KERN_INFO "%s(): registering device resources\n", __func__); |
1394f032 BW |
109 | return platform_add_devices(generic_board_devices, |
110 | ARRAY_SIZE(generic_board_devices)); | |
111 | } | |
112 | ||
113 | arch_initcall(generic_board_init); |