diff options
author | Paul Mundt <lethal@linux-sh.org> | 2009-04-20 07:22:05 -0400 |
---|---|---|
committer | Paul Mundt <lethal@linux-sh.org> | 2009-04-20 07:22:05 -0400 |
commit | 3444f5ec49bc6cb901ffea38e085db1d76e1189c (patch) | |
tree | 2d5870e1d7287cca6cc87ec630cab75dca1fccc6 /arch/sh/drivers/pci/ops-dreamcast.c | |
parent | 0db38cea69fc478a5c25b3c915ec680cc5538783 (diff) |
sh: pci: Tidy up the dreamcast PCI support.
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'arch/sh/drivers/pci/ops-dreamcast.c')
-rw-r--r-- | arch/sh/drivers/pci/ops-dreamcast.c | 98 |
1 files changed, 10 insertions, 88 deletions
diff --git a/arch/sh/drivers/pci/ops-dreamcast.c b/arch/sh/drivers/pci/ops-dreamcast.c index 529aa4f27a89..e83d0d3aabe2 100644 --- a/arch/sh/drivers/pci/ops-dreamcast.c +++ b/arch/sh/drivers/pci/ops-dreamcast.c | |||
@@ -1,15 +1,9 @@ | |||
1 | /* | 1 | /* |
2 | * arch/sh/drivers/pci/ops-dreamcast.c | ||
3 | * | ||
4 | * PCI operations for the Sega Dreamcast | 2 | * PCI operations for the Sega Dreamcast |
5 | * | 3 | * |
6 | * Copyright (C) 2001, 2002 M. R. Brown | 4 | * Copyright (C) 2001, 2002 M. R. Brown |
7 | * Copyright (C) 2002, 2003 Paul Mundt | 5 | * Copyright (C) 2002, 2003 Paul Mundt |
8 | * | 6 | * |
9 | * This file originally bore the message (with enclosed-$): | ||
10 | * Id: pci.c,v 1.3 2003/05/04 19:29:46 lethal Exp | ||
11 | * Dreamcast PCI: Supports SEGA Broadband Adaptor only. | ||
12 | * | ||
13 | * This file is subject to the terms and conditions of the GNU General Public | 7 | * This file is subject to the terms and conditions of the GNU General Public |
14 | * License. See the file "COPYING" in the main directory of this archive | 8 | * License. See the file "COPYING" in the main directory of this archive |
15 | * for more details. | 9 | * for more details. |
@@ -23,25 +17,10 @@ | |||
23 | #include <linux/irq.h> | 17 | #include <linux/irq.h> |
24 | #include <linux/pci.h> | 18 | #include <linux/pci.h> |
25 | #include <linux/module.h> | 19 | #include <linux/module.h> |
26 | 20 | #include <linux/io.h> | |
27 | #include <asm/io.h> | 21 | #include <linux/irq.h> |
28 | #include <asm/irq.h> | ||
29 | #include <mach/pci.h> | 22 | #include <mach/pci.h> |
30 | 23 | ||
31 | static struct resource gapspci_io_resource = { | ||
32 | .name = "GAPSPCI IO", | ||
33 | .start = GAPSPCI_BBA_CONFIG, | ||
34 | .end = GAPSPCI_BBA_CONFIG + GAPSPCI_BBA_CONFIG_SIZE - 1, | ||
35 | .flags = IORESOURCE_IO, | ||
36 | }; | ||
37 | |||
38 | static struct resource gapspci_mem_resource = { | ||
39 | .name = "GAPSPCI mem", | ||
40 | .start = GAPSPCI_DMA_BASE, | ||
41 | .end = GAPSPCI_DMA_BASE + GAPSPCI_DMA_SIZE - 1, | ||
42 | .flags = IORESOURCE_MEM, | ||
43 | }; | ||
44 | |||
45 | /* | 24 | /* |
46 | * The !gapspci_config_access case really shouldn't happen, ever, unless | 25 | * The !gapspci_config_access case really shouldn't happen, ever, unless |
47 | * someone implicitly messes around with the last devfn value.. otherwise we | 26 | * someone implicitly messes around with the last devfn value.. otherwise we |
@@ -76,10 +55,10 @@ static int gapspci_read(struct pci_bus *bus, unsigned int devfn, int where, int | |||
76 | return PCIBIOS_DEVICE_NOT_FOUND; | 55 | return PCIBIOS_DEVICE_NOT_FOUND; |
77 | 56 | ||
78 | switch (size) { | 57 | switch (size) { |
79 | case 1: *val = inb(GAPSPCI_BBA_CONFIG+where); break; | 58 | case 1: *val = inb(GAPSPCI_BBA_CONFIG+where); break; |
80 | case 2: *val = inw(GAPSPCI_BBA_CONFIG+where); break; | 59 | case 2: *val = inw(GAPSPCI_BBA_CONFIG+where); break; |
81 | case 4: *val = inl(GAPSPCI_BBA_CONFIG+where); break; | 60 | case 4: *val = inl(GAPSPCI_BBA_CONFIG+where); break; |
82 | } | 61 | } |
83 | 62 | ||
84 | return PCIBIOS_SUCCESSFUL; | 63 | return PCIBIOS_SUCCESSFUL; |
85 | } | 64 | } |
@@ -90,72 +69,15 @@ static int gapspci_write(struct pci_bus *bus, unsigned int devfn, int where, int | |||
90 | return PCIBIOS_DEVICE_NOT_FOUND; | 69 | return PCIBIOS_DEVICE_NOT_FOUND; |
91 | 70 | ||
92 | switch (size) { | 71 | switch (size) { |
93 | case 1: outb(( u8)val, GAPSPCI_BBA_CONFIG+where); break; | 72 | case 1: outb(( u8)val, GAPSPCI_BBA_CONFIG+where); break; |
94 | case 2: outw((u16)val, GAPSPCI_BBA_CONFIG+where); break; | 73 | case 2: outw((u16)val, GAPSPCI_BBA_CONFIG+where); break; |
95 | case 4: outl((u32)val, GAPSPCI_BBA_CONFIG+where); break; | 74 | case 4: outl((u32)val, GAPSPCI_BBA_CONFIG+where); break; |
96 | } | 75 | } |
97 | 76 | ||
98 | return PCIBIOS_SUCCESSFUL; | 77 | return PCIBIOS_SUCCESSFUL; |
99 | } | 78 | } |
100 | 79 | ||
101 | static struct pci_ops gapspci_pci_ops = { | 80 | struct pci_ops gapspci_pci_ops = { |
102 | .read = gapspci_read, | 81 | .read = gapspci_read, |
103 | .write = gapspci_write, | 82 | .write = gapspci_write, |
104 | }; | 83 | }; |
105 | |||
106 | /* | ||
107 | * gapspci init | ||
108 | */ | ||
109 | |||
110 | static int __init gapspci_init(struct pci_channel *chan) | ||
111 | { | ||
112 | char idbuf[16]; | ||
113 | int i; | ||
114 | |||
115 | /* | ||
116 | * FIXME: All of this wants documenting to some degree, | ||
117 | * even some basic register definitions would be nice. | ||
118 | * | ||
119 | * I haven't seen anything this ugly since.. maple. | ||
120 | */ | ||
121 | |||
122 | for (i=0; i<16; i++) | ||
123 | idbuf[i] = inb(GAPSPCI_REGS+i); | ||
124 | |||
125 | if (strncmp(idbuf, "GAPSPCI_BRIDGE_2", 16)) | ||
126 | return -ENODEV; | ||
127 | |||
128 | outl(0x5a14a501, GAPSPCI_REGS+0x18); | ||
129 | |||
130 | for (i=0; i<1000000; i++) | ||
131 | ; | ||
132 | |||
133 | if (inl(GAPSPCI_REGS+0x18) != 1) | ||
134 | return -EINVAL; | ||
135 | |||
136 | outl(0x01000000, GAPSPCI_REGS+0x20); | ||
137 | outl(0x01000000, GAPSPCI_REGS+0x24); | ||
138 | |||
139 | outl(GAPSPCI_DMA_BASE, GAPSPCI_REGS+0x28); | ||
140 | outl(GAPSPCI_DMA_BASE+GAPSPCI_DMA_SIZE, GAPSPCI_REGS+0x2c); | ||
141 | |||
142 | outl(1, GAPSPCI_REGS+0x14); | ||
143 | outl(1, GAPSPCI_REGS+0x34); | ||
144 | |||
145 | /* Setting Broadband Adapter */ | ||
146 | outw(0xf900, GAPSPCI_BBA_CONFIG+0x06); | ||
147 | outl(0x00000000, GAPSPCI_BBA_CONFIG+0x30); | ||
148 | outb(0x00, GAPSPCI_BBA_CONFIG+0x3c); | ||
149 | outb(0xf0, GAPSPCI_BBA_CONFIG+0x0d); | ||
150 | outw(0x0006, GAPSPCI_BBA_CONFIG+0x04); | ||
151 | outl(0x00002001, GAPSPCI_BBA_CONFIG+0x10); | ||
152 | outl(0x01000000, GAPSPCI_BBA_CONFIG+0x14); | ||
153 | |||
154 | return 0; | ||
155 | } | ||
156 | |||
157 | struct pci_channel board_pci_channels[] = { | ||
158 | { gapspci_init, &gapspci_pci_ops, &gapspci_io_resource, | ||
159 | &gapspci_mem_resource, 0, 1 }, | ||
160 | { 0, } | ||
161 | }; | ||