1*7780dd71SAdrian Chadd /*- 2*7780dd71SAdrian Chadd * Copyright (c) 2009-2010 Weongyo Jeong <weongyo@freebsd.org> 3*7780dd71SAdrian Chadd * All rights reserved. 4*7780dd71SAdrian Chadd * 5*7780dd71SAdrian Chadd * Redistribution and use in source and binary forms, with or without 6*7780dd71SAdrian Chadd * modification, are permitted provided that the following conditions 7*7780dd71SAdrian Chadd * are met: 8*7780dd71SAdrian Chadd * 1. Redistributions of source code must retain the above copyright 9*7780dd71SAdrian Chadd * notice, this list of conditions and the following disclaimer, 10*7780dd71SAdrian Chadd * without modification. 11*7780dd71SAdrian Chadd * 2. Redistributions in binary form must reproduce at minimum a disclaimer 12*7780dd71SAdrian Chadd * similar to the "NO WARRANTY" disclaimer below ("Disclaimer") and any 13*7780dd71SAdrian Chadd * redistribution must be conditioned upon including a substantially 14*7780dd71SAdrian Chadd * similar Disclaimer requirement for further binary redistribution. 15*7780dd71SAdrian Chadd * 16*7780dd71SAdrian Chadd * NO WARRANTY 17*7780dd71SAdrian Chadd * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 18*7780dd71SAdrian Chadd * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 19*7780dd71SAdrian Chadd * LIMITED TO, THE IMPLIED WARRANTIES OF NONINFRINGEMENT, MERCHANTIBILITY 20*7780dd71SAdrian Chadd * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL 21*7780dd71SAdrian Chadd * THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, 22*7780dd71SAdrian Chadd * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 23*7780dd71SAdrian Chadd * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 24*7780dd71SAdrian Chadd * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER 25*7780dd71SAdrian Chadd * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 26*7780dd71SAdrian Chadd * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF 27*7780dd71SAdrian Chadd * THE POSSIBILITY OF SUCH DAMAGES. 28*7780dd71SAdrian Chadd */ 29*7780dd71SAdrian Chadd 30*7780dd71SAdrian Chadd #include <sys/cdefs.h> 31*7780dd71SAdrian Chadd __FBSDID("$FreeBSD$"); 32*7780dd71SAdrian Chadd 33*7780dd71SAdrian Chadd /* 34*7780dd71SAdrian Chadd * The Broadcom Wireless LAN controller driver. 35*7780dd71SAdrian Chadd */ 36*7780dd71SAdrian Chadd 37*7780dd71SAdrian Chadd #include <sys/param.h> 38*7780dd71SAdrian Chadd #include <sys/systm.h> 39*7780dd71SAdrian Chadd #include <sys/kernel.h> 40*7780dd71SAdrian Chadd #include <sys/malloc.h> 41*7780dd71SAdrian Chadd #include <sys/module.h> 42*7780dd71SAdrian Chadd #include <sys/endian.h> 43*7780dd71SAdrian Chadd #include <sys/errno.h> 44*7780dd71SAdrian Chadd #include <sys/firmware.h> 45*7780dd71SAdrian Chadd #include <sys/lock.h> 46*7780dd71SAdrian Chadd #include <sys/mutex.h> 47*7780dd71SAdrian Chadd #include <machine/bus.h> 48*7780dd71SAdrian Chadd #include <machine/resource.h> 49*7780dd71SAdrian Chadd #include <sys/bus.h> 50*7780dd71SAdrian Chadd #include <sys/rman.h> 51*7780dd71SAdrian Chadd #include <sys/socket.h> 52*7780dd71SAdrian Chadd #include <sys/sockio.h> 53*7780dd71SAdrian Chadd 54*7780dd71SAdrian Chadd #include <net/ethernet.h> 55*7780dd71SAdrian Chadd #include <net/if.h> 56*7780dd71SAdrian Chadd #include <net/if_var.h> 57*7780dd71SAdrian Chadd #include <net/if_arp.h> 58*7780dd71SAdrian Chadd #include <net/if_dl.h> 59*7780dd71SAdrian Chadd #include <net/if_llc.h> 60*7780dd71SAdrian Chadd #include <net/if_media.h> 61*7780dd71SAdrian Chadd #include <net/if_types.h> 62*7780dd71SAdrian Chadd 63*7780dd71SAdrian Chadd #include <dev/pci/pcivar.h> 64*7780dd71SAdrian Chadd #include <dev/pci/pcireg.h> 65*7780dd71SAdrian Chadd #include <dev/siba/siba_ids.h> 66*7780dd71SAdrian Chadd #include <dev/siba/sibareg.h> 67*7780dd71SAdrian Chadd #include <dev/siba/sibavar.h> 68*7780dd71SAdrian Chadd 69*7780dd71SAdrian Chadd #include <net80211/ieee80211_var.h> 70*7780dd71SAdrian Chadd #include <net80211/ieee80211_radiotap.h> 71*7780dd71SAdrian Chadd #include <net80211/ieee80211_regdomain.h> 72*7780dd71SAdrian Chadd #include <net80211/ieee80211_phy.h> 73*7780dd71SAdrian Chadd #include <net80211/ieee80211_ratectl.h> 74*7780dd71SAdrian Chadd 75*7780dd71SAdrian Chadd #include <dev/bwn/if_bwnreg.h> 76*7780dd71SAdrian Chadd #include <dev/bwn/if_bwnvar.h> 77*7780dd71SAdrian Chadd 78*7780dd71SAdrian Chadd #include <dev/bwn/if_bwn_chipid.h> 79*7780dd71SAdrian Chadd #include <dev/bwn/if_bwn_debug.h> 80*7780dd71SAdrian Chadd #include <dev/bwn/if_bwn_misc.h> 81*7780dd71SAdrian Chadd #include <dev/bwn/if_bwn_util.h> 82*7780dd71SAdrian Chadd 83*7780dd71SAdrian Chadd unsigned int 84*7780dd71SAdrian Chadd bwn_sqrt(struct bwn_mac *mac, unsigned int x) 85*7780dd71SAdrian Chadd { 86*7780dd71SAdrian Chadd /* Table holding (10 * sqrt(x)) for x between 1 and 256. */ 87*7780dd71SAdrian Chadd static uint8_t sqrt_table[256] = { 88*7780dd71SAdrian Chadd 10, 14, 17, 20, 22, 24, 26, 28, 89*7780dd71SAdrian Chadd 30, 31, 33, 34, 36, 37, 38, 40, 90*7780dd71SAdrian Chadd 41, 42, 43, 44, 45, 46, 47, 48, 91*7780dd71SAdrian Chadd 50, 50, 51, 52, 53, 54, 55, 56, 92*7780dd71SAdrian Chadd 57, 58, 59, 60, 60, 61, 62, 63, 93*7780dd71SAdrian Chadd 64, 64, 65, 66, 67, 67, 68, 69, 94*7780dd71SAdrian Chadd 70, 70, 71, 72, 72, 73, 74, 74, 95*7780dd71SAdrian Chadd 75, 76, 76, 77, 78, 78, 79, 80, 96*7780dd71SAdrian Chadd 80, 81, 81, 82, 83, 83, 84, 84, 97*7780dd71SAdrian Chadd 85, 86, 86, 87, 87, 88, 88, 89, 98*7780dd71SAdrian Chadd 90, 90, 91, 91, 92, 92, 93, 93, 99*7780dd71SAdrian Chadd 94, 94, 95, 95, 96, 96, 97, 97, 100*7780dd71SAdrian Chadd 98, 98, 99, 100, 100, 100, 101, 101, 101*7780dd71SAdrian Chadd 102, 102, 103, 103, 104, 104, 105, 105, 102*7780dd71SAdrian Chadd 106, 106, 107, 107, 108, 108, 109, 109, 103*7780dd71SAdrian Chadd 110, 110, 110, 111, 111, 112, 112, 113, 104*7780dd71SAdrian Chadd 113, 114, 114, 114, 115, 115, 116, 116, 105*7780dd71SAdrian Chadd 117, 117, 117, 118, 118, 119, 119, 120, 106*7780dd71SAdrian Chadd 120, 120, 121, 121, 122, 122, 122, 123, 107*7780dd71SAdrian Chadd 123, 124, 124, 124, 125, 125, 126, 126, 108*7780dd71SAdrian Chadd 126, 127, 127, 128, 128, 128, 129, 129, 109*7780dd71SAdrian Chadd 130, 130, 130, 131, 131, 131, 132, 132, 110*7780dd71SAdrian Chadd 133, 133, 133, 134, 134, 134, 135, 135, 111*7780dd71SAdrian Chadd 136, 136, 136, 137, 137, 137, 138, 138, 112*7780dd71SAdrian Chadd 138, 139, 139, 140, 140, 140, 141, 141, 113*7780dd71SAdrian Chadd 141, 142, 142, 142, 143, 143, 143, 144, 114*7780dd71SAdrian Chadd 144, 144, 145, 145, 145, 146, 146, 146, 115*7780dd71SAdrian Chadd 147, 147, 147, 148, 148, 148, 149, 149, 116*7780dd71SAdrian Chadd 150, 150, 150, 150, 151, 151, 151, 152, 117*7780dd71SAdrian Chadd 152, 152, 153, 153, 153, 154, 154, 154, 118*7780dd71SAdrian Chadd 155, 155, 155, 156, 156, 156, 157, 157, 119*7780dd71SAdrian Chadd 157, 158, 158, 158, 159, 159, 159, 160 120*7780dd71SAdrian Chadd }; 121*7780dd71SAdrian Chadd 122*7780dd71SAdrian Chadd if (x == 0) 123*7780dd71SAdrian Chadd return (0); 124*7780dd71SAdrian Chadd if (x >= 256) { 125*7780dd71SAdrian Chadd unsigned int tmp; 126*7780dd71SAdrian Chadd 127*7780dd71SAdrian Chadd for (tmp = 0; x >= (2 * tmp) + 1; x -= (2 * tmp++) + 1) 128*7780dd71SAdrian Chadd /* do nothing */ ; 129*7780dd71SAdrian Chadd return (tmp); 130*7780dd71SAdrian Chadd } 131*7780dd71SAdrian Chadd return (sqrt_table[x - 1] / 10); 132*7780dd71SAdrian Chadd } 133