b43: N-PHY: add table for antenna software control
Signed-off-by: Rafał Miłecki <zajec5@gmail.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
committed by
John W. Linville
parent
9a2e85de2c
commit
66d80a51e8
@@ -2171,6 +2171,48 @@ static const u16 b43_ntab_loftlt1_r3[] = {
|
|||||||
0x0000, 0x0000,
|
0x0000, 0x0000,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* volatile tables, PHY revision >= 3 */
|
||||||
|
|
||||||
|
/* indexed by antswctl2g */
|
||||||
|
static const u16 b43_ntab_antswctl2g_r3[4][32] = {
|
||||||
|
{
|
||||||
|
0x0082, 0x0082, 0x0211, 0x0222, 0x0328,
|
||||||
|
0x0000, 0x0000, 0x0000, 0x0144, 0x0000,
|
||||||
|
0x0000, 0x0000, 0x0188, 0x0000, 0x0000,
|
||||||
|
0x0000, 0x0082, 0x0082, 0x0211, 0x0222,
|
||||||
|
0x0328, 0x0000, 0x0000, 0x0000, 0x0144,
|
||||||
|
0x0000, 0x0000, 0x0000, 0x0188, 0x0000,
|
||||||
|
0x0000, 0x0000,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
0x0022, 0x0022, 0x0011, 0x0022, 0x0022,
|
||||||
|
0x0000, 0x0000, 0x0000, 0x0011, 0x0000,
|
||||||
|
0x0000, 0x0000, 0x0022, 0x0000, 0x0000,
|
||||||
|
0x0000, 0x0022, 0x0022, 0x0011, 0x0022,
|
||||||
|
0x0022, 0x0000, 0x0000, 0x0000, 0x0011,
|
||||||
|
0x0000, 0x0000, 0x0000, 0x0022, 0x0000,
|
||||||
|
0x0000, 0x0000,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
0x0088, 0x0088, 0x0044, 0x0088, 0x0088,
|
||||||
|
0x0000, 0x0000, 0x0000, 0x0044, 0x0000,
|
||||||
|
0x0000, 0x0000, 0x0088, 0x0000, 0x0000,
|
||||||
|
0x0000, 0x0088, 0x0088, 0x0044, 0x0088,
|
||||||
|
0x0088, 0x0000, 0x0000, 0x0000, 0x0044,
|
||||||
|
0x0000, 0x0000, 0x0000, 0x0088, 0x0000,
|
||||||
|
0x0000, 0x0000,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
0x0022, 0x0022, 0x0011, 0x0022, 0x0000,
|
||||||
|
0x0000, 0x0000, 0x0000, 0x0011, 0x0000,
|
||||||
|
0x0000, 0x0000, 0x0022, 0x0000, 0x0000,
|
||||||
|
0x03cc, 0x0022, 0x0022, 0x0011, 0x0022,
|
||||||
|
0x0000, 0x0000, 0x0000, 0x0000, 0x0011,
|
||||||
|
0x0000, 0x0000, 0x0000, 0x0022, 0x0000,
|
||||||
|
0x0000, 0x03cc,
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
/* TX gain tables */
|
/* TX gain tables */
|
||||||
const u32 b43_ntab_tx_gain_rev0_1_2[] = {
|
const u32 b43_ntab_tx_gain_rev0_1_2[] = {
|
||||||
0x03cc2b44, 0x03cc2b42, 0x03cc2a44, 0x03cc2a42,
|
0x03cc2b44, 0x03cc2b42, 0x03cc2a44, 0x03cc2a42,
|
||||||
@@ -3006,6 +3048,8 @@ void b43_nphy_rev0_1_2_tables_init(struct b43_wldev *dev)
|
|||||||
} while (0)
|
} while (0)
|
||||||
void b43_nphy_rev3plus_tables_init(struct b43_wldev *dev)
|
void b43_nphy_rev3plus_tables_init(struct b43_wldev *dev)
|
||||||
{
|
{
|
||||||
|
struct ssb_sprom *sprom = dev->dev->bus_sprom;
|
||||||
|
|
||||||
/* Static tables */
|
/* Static tables */
|
||||||
ntab_upload_r3(dev, B43_NTAB_FRAMESTRUCT_R3, b43_ntab_framestruct_r3);
|
ntab_upload_r3(dev, B43_NTAB_FRAMESTRUCT_R3, b43_ntab_framestruct_r3);
|
||||||
ntab_upload_r3(dev, B43_NTAB_PILOT_R3, b43_ntab_pilot_r3);
|
ntab_upload_r3(dev, B43_NTAB_PILOT_R3, b43_ntab_pilot_r3);
|
||||||
@@ -3036,7 +3080,11 @@ void b43_nphy_rev3plus_tables_init(struct b43_wldev *dev)
|
|||||||
ntab_upload_r3(dev, B43_NTAB_C1_LOFEEDTH_R3, b43_ntab_loftlt1_r3);
|
ntab_upload_r3(dev, B43_NTAB_C1_LOFEEDTH_R3, b43_ntab_loftlt1_r3);
|
||||||
|
|
||||||
/* Volatile tables */
|
/* Volatile tables */
|
||||||
/* TODO */
|
if (sprom->fem.ghz2.antswlut < ARRAY_SIZE(b43_ntab_antswctl2g_r3))
|
||||||
|
ntab_upload_r3(dev, B43_NTAB_ANT_SW_CTL_R3,
|
||||||
|
b43_ntab_antswctl2g_r3[sprom->fem.ghz2.antswlut]);
|
||||||
|
else
|
||||||
|
B43_WARN_ON(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
struct nphy_gain_ctl_workaround_entry *b43_nphy_get_gain_ctl_workaround_ent(
|
struct nphy_gain_ctl_workaround_entry *b43_nphy_get_gain_ctl_workaround_ent(
|
||||||
|
@@ -126,6 +126,9 @@ struct nphy_gain_ctl_workaround_entry *b43_nphy_get_gain_ctl_workaround_ent(
|
|||||||
#define B43_NTAB_C1_LOFEEDTH B43_NTAB16(0x1B, 0x1C0) /* Local Oscillator Feed Through Lookup Table Core 1 */
|
#define B43_NTAB_C1_LOFEEDTH B43_NTAB16(0x1B, 0x1C0) /* Local Oscillator Feed Through Lookup Table Core 1 */
|
||||||
#define B43_NTAB_C1_LOFEEDTH_SIZE 128
|
#define B43_NTAB_C1_LOFEEDTH_SIZE 128
|
||||||
|
|
||||||
|
/* Volatile N-PHY tables, PHY revision >= 3 */
|
||||||
|
#define B43_NTAB_ANT_SW_CTL_R3 B43_NTAB16( 9, 0) /* antenna software control */
|
||||||
|
|
||||||
/* Static N-PHY tables, PHY revision >= 3 */
|
/* Static N-PHY tables, PHY revision >= 3 */
|
||||||
#define B43_NTAB_FRAMESTRUCT_R3 B43_NTAB32(10, 0) /* frame struct */
|
#define B43_NTAB_FRAMESTRUCT_R3 B43_NTAB32(10, 0) /* frame struct */
|
||||||
#define B43_NTAB_PILOT_R3 B43_NTAB16(11, 0) /* pilot */
|
#define B43_NTAB_PILOT_R3 B43_NTAB16(11, 0) /* pilot */
|
||||||
|
Reference in New Issue
Block a user