xref: /linux/drivers/net/wireless/broadcom/b43/tables_phy_lcn.h (revision e2be04c7f9958dde770eeb8b30e829ca969b37bb)
1 /* SPDX-License-Identifier: GPL-2.0 */
2 #ifndef B43_TABLES_PHY_LCN_H_
3 #define B43_TABLES_PHY_LCN_H_
4 
5 /* The LCN-PHY tables. */
6 #define B43_LCNTAB_TYPEMASK		0xF0000000
7 #define B43_LCNTAB_8BIT			0x10000000
8 #define B43_LCNTAB_16BIT		0x20000000
9 #define B43_LCNTAB_32BIT		0x30000000
10 #define B43_LCNTAB8(table, offset)	(((table) << 10) | (offset) | B43_LCNTAB_8BIT)
11 #define B43_LCNTAB16(table, offset)	(((table) << 10) | (offset) | B43_LCNTAB_16BIT)
12 #define B43_LCNTAB32(table, offset)	(((table) << 10) | (offset) | B43_LCNTAB_32BIT)
13 
14 #define B43_LCNTAB_TX_GAIN_SIZE		128
15 
16 u32 b43_lcntab_read(struct b43_wldev *dev, u32 offset);
17 void b43_lcntab_read_bulk(struct b43_wldev *dev, u32 offset,
18 			  unsigned int nr_elements, void *_data);
19 void b43_lcntab_write(struct b43_wldev *dev, u32 offset, u32 value);
20 void b43_lcntab_write_bulk(struct b43_wldev *dev, u32 offset,
21 			   unsigned int nr_elements, const void *_data);
22 
23 void b43_phy_lcn_tables_init(struct b43_wldev *dev);
24 
25 #endif /* B43_TABLES_PHY_LCN_H_ */
26