gapspci.c revision 1.6 1 1.6 thorpej /* $NetBSD: gapspci.c,v 1.6 2002/10/01 03:04:43 thorpej Exp $ */
2 1.1 thorpej
3 1.1 thorpej /*-
4 1.1 thorpej * Copyright (c) 2001 Marcus Comstedt
5 1.1 thorpej * All rights reserved.
6 1.1 thorpej *
7 1.1 thorpej * Redistribution and use in source and binary forms, with or without
8 1.1 thorpej * modification, are permitted provided that the following conditions
9 1.1 thorpej * are met:
10 1.1 thorpej * 1. Redistributions of source code must retain the above copyright
11 1.1 thorpej * notice, this list of conditions and the following disclaimer.
12 1.1 thorpej * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 thorpej * notice, this list of conditions and the following disclaimer in the
14 1.1 thorpej * documentation and/or other materials provided with the distribution.
15 1.1 thorpej * 3. All advertising materials mentioning features or use of this software
16 1.1 thorpej * must display the following acknowledgement:
17 1.1 thorpej * This product includes software developed by Marcus Comstedt.
18 1.1 thorpej * 4. Neither the name of The NetBSD Foundation nor the names of its
19 1.1 thorpej * contributors may be used to endorse or promote products derived
20 1.1 thorpej * from this software without specific prior written permission.
21 1.1 thorpej *
22 1.1 thorpej * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
23 1.1 thorpej * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
24 1.1 thorpej * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
25 1.1 thorpej * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
26 1.1 thorpej * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
27 1.1 thorpej * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
28 1.1 thorpej * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
29 1.1 thorpej * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
30 1.1 thorpej * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
31 1.1 thorpej * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32 1.1 thorpej * POSSIBILITY OF SUCH DAMAGE.
33 1.1 thorpej */
34 1.1 thorpej
35 1.1 thorpej #include <sys/cdefs.h> /* RCS ID & Copyright macro defns */
36 1.1 thorpej
37 1.1 thorpej #include <sys/param.h>
38 1.1 thorpej #include <sys/systm.h>
39 1.1 thorpej #include <sys/kernel.h>
40 1.1 thorpej #include <sys/device.h>
41 1.1 thorpej #include <sys/malloc.h>
42 1.1 thorpej #include <sys/conf.h>
43 1.1 thorpej #include <sys/mbuf.h>
44 1.1 thorpej
45 1.1 thorpej #include <machine/cpu.h>
46 1.1 thorpej #include <machine/bus.h>
47 1.1 thorpej
48 1.1 thorpej #include <dev/pci/pcivar.h>
49 1.1 thorpej #include <dev/pci/pcireg.h>
50 1.1 thorpej
51 1.1 thorpej #include <dev/pci/pcidevs.h>
52 1.1 thorpej
53 1.1 thorpej #include <dreamcast/dev/g2/g2busvar.h>
54 1.1 thorpej #include <dreamcast/dev/g2/gapspcivar.h>
55 1.1 thorpej
56 1.1 thorpej int gaps_match(struct device *, struct cfdata *, void *);
57 1.1 thorpej void gaps_attach(struct device *, struct device *, void *);
58 1.1 thorpej
59 1.1 thorpej int gaps_print(void *, const char *);
60 1.1 thorpej
61 1.6 thorpej CFATTACH_DECL(gapspci, sizeof(struct gaps_softc),
62 1.6 thorpej gaps_match, gaps_attach, NULL)
63 1.1 thorpej
64 1.1 thorpej int
65 1.1 thorpej gaps_match(struct device *parent, struct cfdata *match, void *aux)
66 1.1 thorpej {
67 1.2 marcus struct g2bus_attach_args *ga = aux;
68 1.1 thorpej char idbuf[16];
69 1.2 marcus bus_space_handle_t tmp_memh;
70 1.1 thorpej
71 1.2 marcus if (bus_space_map(ga->ga_memt, 0x01001400, 0x100, 0, &tmp_memh) != 0)
72 1.2 marcus return 0;
73 1.2 marcus
74 1.2 marcus bus_space_read_region_1(ga->ga_memt, tmp_memh, 0,
75 1.2 marcus idbuf, sizeof(idbuf));
76 1.2 marcus
77 1.2 marcus bus_space_unmap(ga->ga_memt, tmp_memh, 0x100);
78 1.1 thorpej
79 1.1 thorpej if(strncmp(idbuf, "GAPSPCI_BRIDGE_2", 16))
80 1.1 thorpej return 0;
81 1.1 thorpej
82 1.1 thorpej return (1);
83 1.1 thorpej }
84 1.1 thorpej
85 1.1 thorpej void
86 1.1 thorpej gaps_attach(struct device *parent, struct device *self, void *aux)
87 1.1 thorpej {
88 1.1 thorpej struct g2bus_attach_args *ga = aux;
89 1.1 thorpej struct gaps_softc *sc = (void *) self;
90 1.1 thorpej struct pcibus_attach_args pba;
91 1.1 thorpej int i;
92 1.1 thorpej
93 1.1 thorpej printf(": SEGA GAPS PCI Bridge\n");
94 1.1 thorpej
95 1.2 marcus sc->sc_memt = ga->ga_memt;
96 1.2 marcus
97 1.1 thorpej sc->sc_dmabase = 0x1840000;
98 1.2 marcus sc->sc_dmasize = 32768;
99 1.2 marcus
100 1.2 marcus if (bus_space_map(sc->sc_memt, 0x01001400, 0x100,
101 1.2 marcus 0, &sc->sc_gaps_memh) != 0)
102 1.2 marcus panic("gaps_attach: can't map GAPS register space");
103 1.1 thorpej
104 1.2 marcus bus_space_write_4(sc->sc_memt, sc->sc_gaps_memh, 0x18, 0x5a14a501);
105 1.1 thorpej
106 1.1 thorpej for(i=0; i<1000000; i++)
107 1.1 thorpej ;
108 1.1 thorpej
109 1.2 marcus if(bus_space_read_4(sc->sc_memt, sc->sc_gaps_memh, 0x18) != 1)
110 1.2 marcus panic("gaps_attach: GAPS PCI bridge not responding");
111 1.1 thorpej
112 1.2 marcus bus_space_write_4(sc->sc_memt, sc->sc_gaps_memh, 0x20, 0x1000000);
113 1.2 marcus bus_space_write_4(sc->sc_memt, sc->sc_gaps_memh, 0x24, 0x1000000);
114 1.2 marcus bus_space_write_4(sc->sc_memt, sc->sc_gaps_memh, 0x28, sc->sc_dmabase);
115 1.2 marcus bus_space_write_4(sc->sc_memt, sc->sc_gaps_memh, 0x2c,
116 1.2 marcus sc->sc_dmabase + sc->sc_dmasize);
117 1.2 marcus bus_space_write_4(sc->sc_memt, sc->sc_gaps_memh, 0x14, 1);
118 1.2 marcus bus_space_write_4(sc->sc_memt, sc->sc_gaps_memh, 0x34, 1);
119 1.1 thorpej
120 1.1 thorpej gaps_pci_init(sc);
121 1.1 thorpej gaps_dma_init(sc);
122 1.1 thorpej
123 1.1 thorpej memset(&pba, 0, sizeof(pba));
124 1.1 thorpej
125 1.1 thorpej pba.pba_busname = "pci";
126 1.1 thorpej pba.pba_memt = sc->sc_memt;
127 1.1 thorpej pba.pba_dmat = &sc->sc_dmat;
128 1.1 thorpej pba.pba_bus = 0;
129 1.3 thorpej pba.pba_bridgetag = NULL;
130 1.1 thorpej pba.pba_flags = PCI_FLAGS_MEM_ENABLED;
131 1.1 thorpej pba.pba_pc = &sc->sc_pc;
132 1.1 thorpej
133 1.1 thorpej (void) config_found(self, &pba, gaps_print);
134 1.1 thorpej }
135 1.1 thorpej
136 1.1 thorpej int
137 1.1 thorpej gaps_print(void *aux, const char *pnp)
138 1.1 thorpej {
139 1.1 thorpej struct pcibus_attach_args *pba = aux;
140 1.1 thorpej
141 1.1 thorpej if (pnp)
142 1.1 thorpej printf("%s at %s", pba->pba_busname, pnp);
143 1.1 thorpej printf(" bus %d", pba->pba_bus);
144 1.1 thorpej
145 1.1 thorpej return (UNCONF);
146 1.1 thorpej }
147