xref: /freebsd/sys/dev/rtwn/pci/rtwn_pci_reg.c (revision 7453645f2a9411a3f9d982b768bcc323f41cf906)
1*7453645fSAndriy Voskoboinyk /*      $OpenBSD: if_rtwn.c,v 1.6 2015/08/28 00:03:53 deraadt Exp $     */
2*7453645fSAndriy Voskoboinyk 
3*7453645fSAndriy Voskoboinyk /*-
4*7453645fSAndriy Voskoboinyk  * Copyright (c) 2010 Damien Bergamini <damien.bergamini@free.fr>
5*7453645fSAndriy Voskoboinyk  * Copyright (c) 2015 Stefan Sperling <stsp@openbsd.org>
6*7453645fSAndriy Voskoboinyk  * Copyright (c) 2016 Andriy Voskoboinyk <avos@FreeBSD.org>
7*7453645fSAndriy Voskoboinyk  *
8*7453645fSAndriy Voskoboinyk  * Permission to use, copy, modify, and distribute this software for any
9*7453645fSAndriy Voskoboinyk  * purpose with or without fee is hereby granted, provided that the above
10*7453645fSAndriy Voskoboinyk  * copyright notice and this permission notice appear in all copies.
11*7453645fSAndriy Voskoboinyk  *
12*7453645fSAndriy Voskoboinyk  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
13*7453645fSAndriy Voskoboinyk  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
14*7453645fSAndriy Voskoboinyk  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
15*7453645fSAndriy Voskoboinyk  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
16*7453645fSAndriy Voskoboinyk  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
17*7453645fSAndriy Voskoboinyk  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
18*7453645fSAndriy Voskoboinyk  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
19*7453645fSAndriy Voskoboinyk  */
20*7453645fSAndriy Voskoboinyk 
21*7453645fSAndriy Voskoboinyk #include <sys/cdefs.h>
22*7453645fSAndriy Voskoboinyk __FBSDID("$FreeBSD$");
23*7453645fSAndriy Voskoboinyk 
24*7453645fSAndriy Voskoboinyk #include <sys/param.h>
25*7453645fSAndriy Voskoboinyk #include <sys/lock.h>
26*7453645fSAndriy Voskoboinyk #include <sys/mutex.h>
27*7453645fSAndriy Voskoboinyk #include <sys/mbuf.h>
28*7453645fSAndriy Voskoboinyk #include <sys/kernel.h>
29*7453645fSAndriy Voskoboinyk #include <sys/socket.h>
30*7453645fSAndriy Voskoboinyk #include <sys/systm.h>
31*7453645fSAndriy Voskoboinyk #include <sys/malloc.h>
32*7453645fSAndriy Voskoboinyk #include <sys/queue.h>
33*7453645fSAndriy Voskoboinyk #include <sys/taskqueue.h>
34*7453645fSAndriy Voskoboinyk #include <sys/bus.h>
35*7453645fSAndriy Voskoboinyk #include <sys/endian.h>
36*7453645fSAndriy Voskoboinyk 
37*7453645fSAndriy Voskoboinyk #include <machine/bus.h>
38*7453645fSAndriy Voskoboinyk #include <machine/resource.h>
39*7453645fSAndriy Voskoboinyk #include <sys/rman.h>
40*7453645fSAndriy Voskoboinyk 
41*7453645fSAndriy Voskoboinyk #include <net/if.h>
42*7453645fSAndriy Voskoboinyk #include <net/ethernet.h>
43*7453645fSAndriy Voskoboinyk #include <net/if_media.h>
44*7453645fSAndriy Voskoboinyk 
45*7453645fSAndriy Voskoboinyk #include <net80211/ieee80211_var.h>
46*7453645fSAndriy Voskoboinyk #include <net80211/ieee80211_radiotap.h>
47*7453645fSAndriy Voskoboinyk 
48*7453645fSAndriy Voskoboinyk #include <dev/rtwn/if_rtwnvar.h>
49*7453645fSAndriy Voskoboinyk 
50*7453645fSAndriy Voskoboinyk #include <dev/rtwn/pci/rtwn_pci_var.h>
51*7453645fSAndriy Voskoboinyk #include <dev/rtwn/pci/rtwn_pci_reg.h>
52*7453645fSAndriy Voskoboinyk 
53*7453645fSAndriy Voskoboinyk 
54*7453645fSAndriy Voskoboinyk int
55*7453645fSAndriy Voskoboinyk rtwn_pci_write_1(struct rtwn_softc *sc, uint16_t addr, uint8_t val)
56*7453645fSAndriy Voskoboinyk {
57*7453645fSAndriy Voskoboinyk 	struct rtwn_pci_softc *pc = RTWN_PCI_SOFTC(sc);
58*7453645fSAndriy Voskoboinyk 
59*7453645fSAndriy Voskoboinyk 	bus_space_write_1(pc->pc_st, pc->pc_sh, addr, val);
60*7453645fSAndriy Voskoboinyk 
61*7453645fSAndriy Voskoboinyk 	return (0);
62*7453645fSAndriy Voskoboinyk }
63*7453645fSAndriy Voskoboinyk 
64*7453645fSAndriy Voskoboinyk int
65*7453645fSAndriy Voskoboinyk rtwn_pci_write_2(struct rtwn_softc *sc, uint16_t addr, uint16_t val)
66*7453645fSAndriy Voskoboinyk {
67*7453645fSAndriy Voskoboinyk 	struct rtwn_pci_softc *pc = RTWN_PCI_SOFTC(sc);
68*7453645fSAndriy Voskoboinyk 
69*7453645fSAndriy Voskoboinyk 	val = htole16(val);
70*7453645fSAndriy Voskoboinyk 	bus_space_write_2(pc->pc_st, pc->pc_sh, addr, val);
71*7453645fSAndriy Voskoboinyk 
72*7453645fSAndriy Voskoboinyk 	return (0);
73*7453645fSAndriy Voskoboinyk }
74*7453645fSAndriy Voskoboinyk 
75*7453645fSAndriy Voskoboinyk int
76*7453645fSAndriy Voskoboinyk rtwn_pci_write_4(struct rtwn_softc *sc, uint16_t addr, uint32_t val)
77*7453645fSAndriy Voskoboinyk {
78*7453645fSAndriy Voskoboinyk 	struct rtwn_pci_softc *pc = RTWN_PCI_SOFTC(sc);
79*7453645fSAndriy Voskoboinyk 
80*7453645fSAndriy Voskoboinyk 	val = htole32(val);
81*7453645fSAndriy Voskoboinyk 	bus_space_write_4(pc->pc_st, pc->pc_sh, addr, val);
82*7453645fSAndriy Voskoboinyk 
83*7453645fSAndriy Voskoboinyk 	return (0);
84*7453645fSAndriy Voskoboinyk }
85*7453645fSAndriy Voskoboinyk 
86*7453645fSAndriy Voskoboinyk uint8_t
87*7453645fSAndriy Voskoboinyk rtwn_pci_read_1(struct rtwn_softc *sc, uint16_t addr)
88*7453645fSAndriy Voskoboinyk {
89*7453645fSAndriy Voskoboinyk 	struct rtwn_pci_softc *pc = RTWN_PCI_SOFTC(sc);
90*7453645fSAndriy Voskoboinyk 
91*7453645fSAndriy Voskoboinyk 	return (bus_space_read_1(pc->pc_st, pc->pc_sh, addr));
92*7453645fSAndriy Voskoboinyk }
93*7453645fSAndriy Voskoboinyk 
94*7453645fSAndriy Voskoboinyk uint16_t
95*7453645fSAndriy Voskoboinyk rtwn_pci_read_2(struct rtwn_softc *sc, uint16_t addr)
96*7453645fSAndriy Voskoboinyk {
97*7453645fSAndriy Voskoboinyk 	struct rtwn_pci_softc *pc = RTWN_PCI_SOFTC(sc);
98*7453645fSAndriy Voskoboinyk 	uint16_t val;
99*7453645fSAndriy Voskoboinyk 
100*7453645fSAndriy Voskoboinyk 	val = bus_space_read_2(pc->pc_st, pc->pc_sh, addr);
101*7453645fSAndriy Voskoboinyk 	return le16toh(val);
102*7453645fSAndriy Voskoboinyk }
103*7453645fSAndriy Voskoboinyk 
104*7453645fSAndriy Voskoboinyk uint32_t
105*7453645fSAndriy Voskoboinyk rtwn_pci_read_4(struct rtwn_softc *sc, uint16_t addr)
106*7453645fSAndriy Voskoboinyk {
107*7453645fSAndriy Voskoboinyk 	struct rtwn_pci_softc *pc = RTWN_PCI_SOFTC(sc);
108*7453645fSAndriy Voskoboinyk 	uint32_t val;
109*7453645fSAndriy Voskoboinyk 
110*7453645fSAndriy Voskoboinyk 	val = bus_space_read_4(pc->pc_st, pc->pc_sh, addr);
111*7453645fSAndriy Voskoboinyk 	return le32toh(val);
112*7453645fSAndriy Voskoboinyk }
113*7453645fSAndriy Voskoboinyk 
114*7453645fSAndriy Voskoboinyk void
115*7453645fSAndriy Voskoboinyk rtwn_pci_delay(struct rtwn_softc *sc, int usec)
116*7453645fSAndriy Voskoboinyk {
117*7453645fSAndriy Voskoboinyk 	if (usec < 1000)
118*7453645fSAndriy Voskoboinyk 		DELAY(usec);
119*7453645fSAndriy Voskoboinyk 	else {
120*7453645fSAndriy Voskoboinyk 		(void) mtx_sleep(sc, &sc->sc_mtx, 0, "rtwn_pci",
121*7453645fSAndriy Voskoboinyk 		    MAX(msecs_to_ticks(usec / 1000), 1));
122*7453645fSAndriy Voskoboinyk 	}
123*7453645fSAndriy Voskoboinyk }
124