/[gxemul]/upstream/0.3.6.2/src/devices/dev_pcic.c
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Contents of /upstream/0.3.6.2/src/devices/dev_pcic.c

Parent Directory Parent Directory | Revision Log Revision Log


Revision 19 - (show annotations)
Mon Oct 8 16:19:16 2007 UTC (16 years, 8 months ago) by dpavlin
File MIME type: text/plain
File size: 7370 byte(s)
0.3.6.2
1 /*
2 * Copyright (C) 2005 Anders Gavare. All rights reserved.
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are met:
6 *
7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
12 * 3. The name of the author may not be used to endorse or promote products
13 * derived from this software without specific prior written permission.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
16 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
19 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
20 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
21 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
23 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
24 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
25 * SUCH DAMAGE.
26 *
27 *
28 * $Id: dev_pcic.c,v 1.13 2005/10/26 14:37:04 debug Exp $
29 *
30 * Intel 82365SL PC Card Interface Controller (called "pcic" by NetBSD).
31 *
32 * TODO: Lots of stuff. This is just a quick hack. Don't rely on it.
33 */
34
35 #include <stdio.h>
36 #include <stdlib.h>
37 #include <string.h>
38
39 #include "cpu.h"
40 #include "device.h"
41 #include "emul.h"
42 #include "machine.h"
43 #include "memory.h"
44 #include "misc.h"
45
46 #include "i82365reg.h"
47 #include "pcmciareg.h"
48
49
50 /* #define debug fatal */
51
52 #define DEV_PCIC_LENGTH 2
53
54 struct pcic_data {
55 int irq_nr;
56 int regnr;
57 };
58
59
60 /*
61 * dev_pcic_cis_access():
62 */
63 int dev_pcic_cis_access(struct cpu *cpu, struct memory *mem,
64 uint64_t relative_addr, unsigned char *data, size_t len,
65 int writeflag, void *extra)
66 {
67 /* struct pcic_data *d = (struct pcic_data *) extra; */
68 uint64_t idata = 0, odata = 0;
69
70 idata = memory_readmax64(cpu, data, len);
71
72 {
73 #if 0
74 /* SMC, PCM Ethernet Adapter, CIS V1.05 (manufacturer 0x108,
75 product 0x105) */
76 unsigned char x[] = {
77 PCMCIA_CISTPL_DEVICE, 3, PCMCIA_DTYPE_FUNCSPEC, 0xff,0xff,
78 PCMCIA_CISTPL_FUNCID, 2, 0x06, 0x00,
79 PCMCIA_CISTPL_MANFID, 4, 0x08, 0x01, 0x05, 0x01,
80 PCMCIA_CISTPL_VERS_1, 0x26,
81 0x04, 0x01, 0x53, 0x4d, 0x43, 0x00, 0x50, 0x43, 0x4d, 0x20,
82 0x45, 0x74, 0x68, 0x65, 0x72, 0x6e, 0x65, 0x74, 0x20, 0x41,
83 0x64, 0x61, 0x70, 0x74, 0x65, 0x72, 0x00, 0x43, 0x49, 0x53,
84 0x20, 0x56, 0x31, 0x2e, 0x30, 0x35, 0x00, 0xff,
85 PCMCIA_CISTPL_CONFIG, 0x0a,
86 0x02, 0x01, 0x00, 0x00, 0x01, 0x03, 0x00, 0x00, 0x00, 0xff,
87 PCMCIA_CISTPL_CFTABLE_ENTRY, 0x0b,
88 0xc1, 0x01, 0x70, 0x50, 0xbc, 0x8e, 0x48, 0x40, 0x00,0x02,0xff,
89 /* unhandled CISTPL 22 */
90 0x22, 0x02, 0x01, 0x02,
91 /* unhandled CISTPL 22 */
92 0x22, 0x05, 0x02, 0x80, 0x96, 0x98, 0x00,
93 /* unhandled CISTPL 22 */
94 0x22, 0x02, 0x03, 0x01,
95 /* unhandled CISTPL 22 */
96 0x22, 0x08, 0x04, 0x06, 0x00, 0x00, 0xc0, 0x2f, 0x48, 0xd2,
97 /* unhandled CISTPL 22 */
98 0x22, 0x02, 0x05, 0x01,
99
100 PCMCIA_CISTPL_END, 0
101 };
102 #endif
103
104 /* From http://www.mail-archive.com/freebsd-current@freebsd.
105 org/msg32550.html */
106 unsigned char x[] = {
107 PCMCIA_CISTPL_DEVICE, 3, 0xdc, 0x00, 0xff,
108 PCMCIA_CISTPL_VERS_1, 0x1a,
109 0x04,0x01,0x20,0x00,0x4e,0x69,0x6e,0x6a,0x61,0x41,0x54,0x41,
110 0x2d,0x00,0x56,0x31,0x2e,0x30,0x00,0x41,0x50,0x30,0x30,0x20,
111 0x00,0xff,
112 PCMCIA_CISTPL_CONFIG, 5,
113 0x01,0x23,0x00,0x02,0x03,
114 PCMCIA_CISTPL_CFTABLE_ENTRY, 0x15,
115 0xe1,0x01,0x3d,0x11,0x55,0x1e,0xfc,0x23,0xf0,0x61,0x80,0x01,
116 0x07,0x86,0x03,0x01,0x30,0x68,0xd0,0x10,0x00,
117 #if 0
118 PCMCIA_CISTPL_CFTABLE_ENTRY, 0xf,
119 0x22,0x38,0xf0,0x61,0x90,0x01,0x07,0x96,0x03,0x01,0x30,0x68,
120 0xd0,0x10,0x00,
121 PCMCIA_CISTPL_CFTABLE_ENTRY, 0xf,
122 0x23,0x38,0xf0,0x61,0xa0,0x01,0x07,0xa6,0x03,0x01,0x30,0x68,
123 0xd0,0x10,0x00,
124 #endif
125 PCMCIA_CISTPL_NO_LINK, 0,
126
127 PCMCIA_CISTPL_END, 0
128 };
129
130 relative_addr /= 2;
131 if (relative_addr < sizeof(x))
132 odata = x[relative_addr];
133
134 debug("[ dev_pcic_cis_access: blah blah: addr=0x%x ]\n",
135 (int)relative_addr);
136 }
137
138 if (writeflag == MEM_READ)
139 memory_writemax64(cpu, data, len, odata);
140
141 return 1;
142 }
143
144
145 /*
146 * dev_pcic_access():
147 */
148 int dev_pcic_access(struct cpu *cpu, struct memory *mem,
149 uint64_t relative_addr, unsigned char *data, size_t len,
150 int writeflag, void *extra)
151 {
152 struct pcic_data *d = (struct pcic_data *) extra;
153 uint64_t idata = 0, odata = 0;
154 int controller_nr, socket_nr;
155
156 if (writeflag == MEM_WRITE)
157 idata = memory_readmax64(cpu, data, len);
158
159 controller_nr = d->regnr & 0x80? 1 : 0;
160 socket_nr = d->regnr & 0x40? 1 : 0;
161
162 switch (relative_addr) {
163 case 0: /* Register select: */
164 if (writeflag == MEM_WRITE)
165 d->regnr = idata;
166 else
167 odata = d->regnr;
168 break;
169 case 1: /* Register access: */
170 switch (d->regnr & 0x3f) {
171 case PCIC_IDENT:
172 /* This causes sockets A and B to be present on
173 controller 0, and only socket A on controller 1. */
174 if (controller_nr == 1 && socket_nr == 1)
175 odata = 0;
176 else
177 odata = PCIC_IDENT_IFTYPE_MEM_AND_IO
178 | PCIC_IDENT_REV_I82365SLR1;
179 break;
180 #if 1
181 case PCIC_INTR:
182 odata = PCIC_INTR_IRQ3;
183 break;
184 #endif
185 case PCIC_CSC:
186 odata = PCIC_CSC_GPI;
187 break;
188 case PCIC_IF_STATUS:
189 odata = PCIC_IF_STATUS_READY
190 | PCIC_IF_STATUS_POWERACTIVE;
191 if (controller_nr == 0 && socket_nr == 0)
192 odata |= PCIC_IF_STATUS_CARDDETECT_PRESENT;
193 break;
194 default:
195 if (writeflag == MEM_WRITE) {
196 debug("[ pcic: unimplemented write to "
197 "controller %i socket %c, regnr %i: "
198 "data=0x%02x ]\n", controller_nr,
199 socket_nr? 'B' : 'A',
200 d->regnr & 0x3f, (int)idata);
201 } else {
202 debug("[ pcic: unimplemented read from "
203 "controller %i socket %c, regnr %i ]\n",
204 controller_nr, socket_nr? 'B' : 'A',
205 d->regnr & 0x3f);
206 }
207 }
208 }
209
210 if (writeflag == MEM_READ)
211 memory_writemax64(cpu, data, len, odata);
212
213 return 1;
214 }
215
216
217 /*
218 * devinit_pcic():
219 */
220 int devinit_pcic(struct devinit *devinit)
221 {
222 struct pcic_data *d = malloc(sizeof(struct pcic_data));
223
224 if (d == NULL) {
225 fprintf(stderr, "out of memory\n");
226 exit(1);
227 }
228 memset(d, 0, sizeof(struct pcic_data));
229 d->irq_nr = devinit->irq_nr;
230
231 memory_device_register(devinit->machine->memory, devinit->name,
232 devinit->addr, DEV_PCIC_LENGTH,
233 dev_pcic_access, (void *)d, MEM_DEFAULT, NULL);
234
235 /* TODO: this shouldn't be hardcoded for hpcmips here! */
236 memory_device_register(devinit->machine->memory, "pcic_cis",
237 0x10070000, 0x1000, dev_pcic_cis_access, (void *)d,
238 MEM_DEFAULT, NULL);
239
240 /* TODO: find out a good way to specify the address, and the IRQ! */
241 /* IRQ 8 + 32 + 9 */
242 device_add(devinit->machine, "wdc addr=0x14000180 irq=49");
243
244 /* TODO: Linux/MobilePro looks at 0x14000170 and 0x1f0... */
245 /* Yuck. Now there are two. How should this be solved nicely? */
246 device_add(devinit->machine, "wdc addr=0x140001f0 irq=49");
247
248 return 1;
249 }
250

  ViewVC Help
Powered by ViewVC 1.1.26