gapspci.c revision 1.2 1 1.2 marcus /* $NetBSD: gapspci.c,v 1.2 2001/02/01 19:35:04 marcus 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.1 thorpej struct cfattach gapspci_ca = {
62 1.1 thorpej sizeof(struct gaps_softc),
63 1.1 thorpej gaps_match,
64 1.1 thorpej gaps_attach,
65 1.1 thorpej };
66 1.1 thorpej
67 1.1 thorpej int
68 1.1 thorpej gaps_match(struct device *parent, struct cfdata *match, void *aux)
69 1.1 thorpej {
70 1.2 marcus struct g2bus_attach_args *ga = aux;
71 1.1 thorpej char idbuf[16];
72 1.2 marcus bus_space_handle_t tmp_memh;
73 1.1 thorpej
74 1.1 thorpej if(strcmp("gapspci", match->cf_driver->cd_name))
75 1.1 thorpej return 0;
76 1.1 thorpej
77 1.2 marcus if (bus_space_map(ga->ga_memt, 0x01001400, 0x100, 0, &tmp_memh) != 0)
78 1.2 marcus return 0;
79 1.2 marcus
80 1.2 marcus bus_space_read_region_1(ga->ga_memt, tmp_memh, 0,
81 1.2 marcus idbuf, sizeof(idbuf));
82 1.2 marcus
83 1.2 marcus bus_space_unmap(ga->ga_memt, tmp_memh, 0x100);
84 1.1 thorpej
85 1.1 thorpej if(strncmp(idbuf, "GAPSPCI_BRIDGE_2", 16))
86 1.1 thorpej return 0;
87 1.1 thorpej
88 1.1 thorpej return (1);
89 1.1 thorpej }
90 1.1 thorpej
91 1.1 thorpej void
92 1.1 thorpej gaps_attach(struct device *parent, struct device *self, void *aux)
93 1.1 thorpej {
94 1.1 thorpej struct g2bus_attach_args *ga = aux;
95 1.1 thorpej struct gaps_softc *sc = (void *) self;
96 1.1 thorpej struct pcibus_attach_args pba;
97 1.1 thorpej int i;
98 1.1 thorpej
99 1.1 thorpej printf(": SEGA GAPS PCI Bridge\n");
100 1.1 thorpej
101 1.2 marcus sc->sc_memt = ga->ga_memt;
102 1.2 marcus
103 1.1 thorpej sc->sc_dmabase = 0x1840000;
104 1.2 marcus sc->sc_dmasize = 32768;
105 1.2 marcus
106 1.2 marcus if (bus_space_map(sc->sc_memt, 0x01001400, 0x100,
107 1.2 marcus 0, &sc->sc_gaps_memh) != 0)
108 1.2 marcus panic("gaps_attach: can't map GAPS register space");
109 1.1 thorpej
110 1.2 marcus bus_space_write_4(sc->sc_memt, sc->sc_gaps_memh, 0x18, 0x5a14a501);
111 1.1 thorpej
112 1.1 thorpej for(i=0; i<1000000; i++)
113 1.1 thorpej ;
114 1.1 thorpej
115 1.2 marcus if(bus_space_read_4(sc->sc_memt, sc->sc_gaps_memh, 0x18) != 1)
116 1.2 marcus panic("gaps_attach: GAPS PCI bridge not responding");
117 1.1 thorpej
118 1.2 marcus bus_space_write_4(sc->sc_memt, sc->sc_gaps_memh, 0x20, 0x1000000);
119 1.2 marcus bus_space_write_4(sc->sc_memt, sc->sc_gaps_memh, 0x24, 0x1000000);
120 1.2 marcus bus_space_write_4(sc->sc_memt, sc->sc_gaps_memh, 0x28, sc->sc_dmabase);
121 1.2 marcus bus_space_write_4(sc->sc_memt, sc->sc_gaps_memh, 0x2c,
122 1.2 marcus sc->sc_dmabase + sc->sc_dmasize);
123 1.2 marcus bus_space_write_4(sc->sc_memt, sc->sc_gaps_memh, 0x14, 1);
124 1.2 marcus bus_space_write_4(sc->sc_memt, sc->sc_gaps_memh, 0x34, 1);
125 1.1 thorpej
126 1.1 thorpej gaps_pci_init(sc);
127 1.1 thorpej gaps_dma_init(sc);
128 1.1 thorpej
129 1.1 thorpej memset(&pba, 0, sizeof(pba));
130 1.1 thorpej
131 1.1 thorpej pba.pba_busname = "pci";
132 1.1 thorpej pba.pba_memt = sc->sc_memt;
133 1.1 thorpej pba.pba_dmat = &sc->sc_dmat;
134 1.1 thorpej pba.pba_bus = 0;
135 1.1 thorpej pba.pba_flags = PCI_FLAGS_MEM_ENABLED;
136 1.1 thorpej pba.pba_pc = &sc->sc_pc;
137 1.1 thorpej
138 1.1 thorpej (void) config_found(self, &pba, gaps_print);
139 1.1 thorpej }
140 1.1 thorpej
141 1.1 thorpej int
142 1.1 thorpej gaps_print(void *aux, const char *pnp)
143 1.1 thorpej {
144 1.1 thorpej struct pcibus_attach_args *pba = aux;
145 1.1 thorpej
146 1.1 thorpej if (pnp)
147 1.1 thorpej printf("%s at %s", pba->pba_busname, pnp);
148 1.1 thorpej printf(" bus %d", pba->pba_bus);
149 1.1 thorpej
150 1.1 thorpej return (UNCONF);
151 1.1 thorpej }
152