17453645fSAndriy Voskoboinyk /* $OpenBSD: if_urtwn.c,v 1.16 2011/02/10 17:26:40 jakemsr Exp $ */
27453645fSAndriy Voskoboinyk
37453645fSAndriy Voskoboinyk /*-
47453645fSAndriy Voskoboinyk * Copyright (c) 2010 Damien Bergamini <damien.bergamini@free.fr>
57453645fSAndriy Voskoboinyk * Copyright (c) 2014 Kevin Lo <kevlo@FreeBSD.org>
67453645fSAndriy Voskoboinyk * Copyright (c) 2015-2016 Andriy Voskoboinyk <avos@FreeBSD.org>
77453645fSAndriy Voskoboinyk *
87453645fSAndriy Voskoboinyk * Permission to use, copy, modify, and distribute this software for any
97453645fSAndriy Voskoboinyk * purpose with or without fee is hereby granted, provided that the above
107453645fSAndriy Voskoboinyk * copyright notice and this permission notice appear in all copies.
117453645fSAndriy Voskoboinyk *
127453645fSAndriy Voskoboinyk * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
137453645fSAndriy Voskoboinyk * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
147453645fSAndriy Voskoboinyk * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
157453645fSAndriy Voskoboinyk * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
167453645fSAndriy Voskoboinyk * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
177453645fSAndriy Voskoboinyk * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
187453645fSAndriy Voskoboinyk * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
197453645fSAndriy Voskoboinyk */
207453645fSAndriy Voskoboinyk
217453645fSAndriy Voskoboinyk #include <sys/cdefs.h>
227453645fSAndriy Voskoboinyk #include "opt_wlan.h"
237453645fSAndriy Voskoboinyk
247453645fSAndriy Voskoboinyk #include <sys/param.h>
257453645fSAndriy Voskoboinyk #include <sys/lock.h>
267453645fSAndriy Voskoboinyk #include <sys/mutex.h>
277453645fSAndriy Voskoboinyk #include <sys/mbuf.h>
287453645fSAndriy Voskoboinyk #include <sys/kernel.h>
297453645fSAndriy Voskoboinyk #include <sys/socket.h>
307453645fSAndriy Voskoboinyk #include <sys/systm.h>
317453645fSAndriy Voskoboinyk #include <sys/malloc.h>
327453645fSAndriy Voskoboinyk #include <sys/queue.h>
337453645fSAndriy Voskoboinyk #include <sys/taskqueue.h>
347453645fSAndriy Voskoboinyk #include <sys/bus.h>
357453645fSAndriy Voskoboinyk #include <sys/endian.h>
367453645fSAndriy Voskoboinyk #include <sys/linker.h>
377453645fSAndriy Voskoboinyk
387453645fSAndriy Voskoboinyk #include <net/if.h>
397453645fSAndriy Voskoboinyk #include <net/ethernet.h>
407453645fSAndriy Voskoboinyk #include <net/if_media.h>
417453645fSAndriy Voskoboinyk
427453645fSAndriy Voskoboinyk #include <net80211/ieee80211_var.h>
437453645fSAndriy Voskoboinyk #include <net80211/ieee80211_radiotap.h>
447453645fSAndriy Voskoboinyk
457453645fSAndriy Voskoboinyk #include <dev/rtwn/if_rtwnreg.h>
467453645fSAndriy Voskoboinyk #include <dev/rtwn/if_rtwnvar.h>
477453645fSAndriy Voskoboinyk
487453645fSAndriy Voskoboinyk #include <dev/rtwn/if_rtwn_debug.h>
497453645fSAndriy Voskoboinyk
507453645fSAndriy Voskoboinyk #include <dev/rtwn/rtl8192c/r92c.h>
517453645fSAndriy Voskoboinyk #include <dev/rtwn/rtl8192c/r92c_var.h>
527453645fSAndriy Voskoboinyk
537453645fSAndriy Voskoboinyk #include <dev/rtwn/rtl8188e/r88e.h>
547453645fSAndriy Voskoboinyk #include <dev/rtwn/rtl8188e/r88e_reg.h>
557453645fSAndriy Voskoboinyk
567453645fSAndriy Voskoboinyk static void
r88e_crystalcap_write(struct rtwn_softc * sc)577453645fSAndriy Voskoboinyk r88e_crystalcap_write(struct rtwn_softc *sc)
587453645fSAndriy Voskoboinyk {
597453645fSAndriy Voskoboinyk struct r92c_softc *rs = sc->sc_priv;
607453645fSAndriy Voskoboinyk uint32_t reg;
617453645fSAndriy Voskoboinyk uint8_t val;
627453645fSAndriy Voskoboinyk
637453645fSAndriy Voskoboinyk val = rs->crystalcap & 0x3f;
647453645fSAndriy Voskoboinyk reg = rtwn_bb_read(sc, R92C_AFE_XTAL_CTRL);
657453645fSAndriy Voskoboinyk rtwn_bb_write(sc, R92C_AFE_XTAL_CTRL,
667453645fSAndriy Voskoboinyk RW(reg, R92C_AFE_XTAL_CTRL_ADDR, val | val << 6));
677453645fSAndriy Voskoboinyk }
687453645fSAndriy Voskoboinyk
697453645fSAndriy Voskoboinyk void
r88e_init_bb_common(struct rtwn_softc * sc)70*4e4bcfcfSAndriy Voskoboinyk r88e_init_bb_common(struct rtwn_softc *sc)
717453645fSAndriy Voskoboinyk {
727453645fSAndriy Voskoboinyk r92c_init_bb_common(sc);
737453645fSAndriy Voskoboinyk
747453645fSAndriy Voskoboinyk rtwn_bb_write(sc, R92C_OFDM0_AGCCORE1(0), 0x69553422);
757453645fSAndriy Voskoboinyk rtwn_delay(sc, 1);
767453645fSAndriy Voskoboinyk rtwn_bb_write(sc, R92C_OFDM0_AGCCORE1(0), 0x69553420);
777453645fSAndriy Voskoboinyk rtwn_delay(sc, 1);
787453645fSAndriy Voskoboinyk
797453645fSAndriy Voskoboinyk r88e_crystalcap_write(sc);
807453645fSAndriy Voskoboinyk }
81