xref: /linux/drivers/net/wireless/broadcom/b43legacy/radio.h (revision 423e3ce336499ddb4e094f40649d12d9820f785b)
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