1*423e3ce3SKalle Valo /* 2*423e3ce3SKalle Valo 3*423e3ce3SKalle Valo Broadcom B43legacy wireless driver 4*423e3ce3SKalle Valo 5*423e3ce3SKalle Valo Copyright (c) 2005 Martin Langer <martin-langer@gmx.de>, 6*423e3ce3SKalle Valo Stefano Brivio <stefano.brivio@polimi.it> 7*423e3ce3SKalle Valo Michael Buesch <m@bues.ch> 8*423e3ce3SKalle Valo Danny van Dyk <kugelfang@gentoo.org> 9*423e3ce3SKalle Valo Andreas Jaggi <andreas.jaggi@waterwave.ch> 10*423e3ce3SKalle Valo 11*423e3ce3SKalle Valo Some parts of the code in this file are derived from the ipw2200 12*423e3ce3SKalle Valo driver Copyright(c) 2003 - 2004 Intel Corporation. 13*423e3ce3SKalle Valo 14*423e3ce3SKalle Valo This program is free software; you can redistribute it and/or modify 15*423e3ce3SKalle Valo it under the terms of the GNU General Public License as published by 16*423e3ce3SKalle Valo the Free Software Foundation; either version 2 of the License, or 17*423e3ce3SKalle Valo (at your option) any later version. 18*423e3ce3SKalle Valo 19*423e3ce3SKalle Valo This program is distributed in the hope that it will be useful, 20*423e3ce3SKalle Valo but WITHOUT ANY WARRANTY; without even the implied warranty of 21*423e3ce3SKalle Valo MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 22*423e3ce3SKalle Valo GNU General Public License for more details. 23*423e3ce3SKalle Valo 24*423e3ce3SKalle Valo You should have received a copy of the GNU General Public License 25*423e3ce3SKalle Valo along with this program; see the file COPYING. If not, write to 26*423e3ce3SKalle Valo the Free Software Foundation, Inc., 51 Franklin Steet, Fifth Floor, 27*423e3ce3SKalle Valo Boston, MA 02110-1301, USA. 28*423e3ce3SKalle Valo 29*423e3ce3SKalle Valo */ 30*423e3ce3SKalle Valo 31*423e3ce3SKalle Valo #ifndef B43legacy_RADIO_H_ 32*423e3ce3SKalle Valo #define B43legacy_RADIO_H_ 33*423e3ce3SKalle Valo 34*423e3ce3SKalle Valo #include "b43legacy.h" 35*423e3ce3SKalle Valo 36*423e3ce3SKalle Valo 37*423e3ce3SKalle Valo #define B43legacy_RADIO_DEFAULT_CHANNEL_BG 6 38*423e3ce3SKalle Valo 39*423e3ce3SKalle Valo /* Force antenna 0. */ 40*423e3ce3SKalle Valo #define B43legacy_RADIO_TXANTENNA_0 0 41*423e3ce3SKalle Valo /* Force antenna 1. */ 42*423e3ce3SKalle Valo #define B43legacy_RADIO_TXANTENNA_1 1 43*423e3ce3SKalle Valo /* Use the RX antenna, that was selected for the most recently 44*423e3ce3SKalle Valo * received good PLCP header. 45*423e3ce3SKalle Valo */ 46*423e3ce3SKalle Valo #define B43legacy_RADIO_TXANTENNA_LASTPLCP 3 47*423e3ce3SKalle Valo #define B43legacy_RADIO_TXANTENNA_DEFAULT B43legacy_RADIO_TXANTENNA_LASTPLCP 48*423e3ce3SKalle Valo 49*423e3ce3SKalle Valo #define B43legacy_RADIO_INTERFMODE_NONE 0 50*423e3ce3SKalle Valo #define B43legacy_RADIO_INTERFMODE_NONWLAN 1 51*423e3ce3SKalle Valo #define B43legacy_RADIO_INTERFMODE_MANUALWLAN 2 52*423e3ce3SKalle Valo #define B43legacy_RADIO_INTERFMODE_AUTOWLAN 3 53*423e3ce3SKalle Valo 54*423e3ce3SKalle Valo 55*423e3ce3SKalle Valo void b43legacy_radio_lock(struct b43legacy_wldev *dev); 56*423e3ce3SKalle Valo void b43legacy_radio_unlock(struct b43legacy_wldev *dev); 57*423e3ce3SKalle Valo 58*423e3ce3SKalle Valo u16 b43legacy_radio_read16(struct b43legacy_wldev *dev, u16 offset); 59*423e3ce3SKalle Valo void b43legacy_radio_write16(struct b43legacy_wldev *dev, u16 offset, u16 val); 60*423e3ce3SKalle Valo 61*423e3ce3SKalle Valo u16 b43legacy_radio_init2050(struct b43legacy_wldev *dev); 62*423e3ce3SKalle Valo 63*423e3ce3SKalle Valo void b43legacy_radio_turn_on(struct b43legacy_wldev *dev); 64*423e3ce3SKalle Valo void b43legacy_radio_turn_off(struct b43legacy_wldev *dev, bool force); 65*423e3ce3SKalle Valo 66*423e3ce3SKalle Valo int b43legacy_radio_selectchannel(struct b43legacy_wldev *dev, u8 channel, 67*423e3ce3SKalle Valo int synthetic_pu_workaround); 68*423e3ce3SKalle Valo 69*423e3ce3SKalle Valo void b43legacy_radio_set_txpower_a(struct b43legacy_wldev *dev, u16 txpower); 70*423e3ce3SKalle Valo void b43legacy_radio_set_txpower_bg(struct b43legacy_wldev *dev, 71*423e3ce3SKalle Valo u16 baseband_attenuation, u16 attenuation, 72*423e3ce3SKalle Valo u16 txpower); 73*423e3ce3SKalle Valo 74*423e3ce3SKalle Valo u16 b43legacy_default_baseband_attenuation(struct b43legacy_wldev *dev); 75*423e3ce3SKalle Valo u16 b43legacy_default_radio_attenuation(struct b43legacy_wldev *dev); 76*423e3ce3SKalle Valo u16 b43legacy_default_txctl1(struct b43legacy_wldev *dev); 77*423e3ce3SKalle Valo 78*423e3ce3SKalle Valo void b43legacy_radio_set_txantenna(struct b43legacy_wldev *dev, u32 val); 79*423e3ce3SKalle Valo 80*423e3ce3SKalle Valo void b43legacy_radio_clear_tssi(struct b43legacy_wldev *dev); 81*423e3ce3SKalle Valo 82*423e3ce3SKalle Valo u8 b43legacy_radio_aci_detect(struct b43legacy_wldev *dev, u8 channel); 83*423e3ce3SKalle Valo u8 b43legacy_radio_aci_scan(struct b43legacy_wldev *dev); 84*423e3ce3SKalle Valo 85*423e3ce3SKalle Valo int b43legacy_radio_set_interference_mitigation(struct b43legacy_wldev *dev, 86*423e3ce3SKalle Valo int mode); 87*423e3ce3SKalle Valo 88*423e3ce3SKalle Valo void b43legacy_calc_nrssi_slope(struct b43legacy_wldev *dev); 89*423e3ce3SKalle Valo void b43legacy_calc_nrssi_threshold(struct b43legacy_wldev *dev); 90*423e3ce3SKalle Valo s16 b43legacy_nrssi_hw_read(struct b43legacy_wldev *dev, u16 offset); 91*423e3ce3SKalle Valo void b43legacy_nrssi_hw_write(struct b43legacy_wldev *dev, u16 offset, s16 val); 92*423e3ce3SKalle Valo void b43legacy_nrssi_hw_update(struct b43legacy_wldev *dev, u16 val); 93*423e3ce3SKalle Valo void b43legacy_nrssi_mem_update(struct b43legacy_wldev *dev); 94*423e3ce3SKalle Valo 95*423e3ce3SKalle Valo u16 b43legacy_radio_calibrationvalue(struct b43legacy_wldev *dev); 96*423e3ce3SKalle Valo 97*423e3ce3SKalle Valo #endif /* B43legacy_RADIO_H_ */ 98