mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-29 22:14:41 +08:00
rtl8xxxu: Add radio init tables for 8192eu
Add the required radio init tables for 8192eu devices. Signed-off-by: Jes Sorensen <Jes.Sorensen@redhat.com> Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
This commit is contained in:
parent
80805aa5f3
commit
19102f8419
@ -1242,6 +1242,152 @@ static struct rtl8xxxu_rfregval rtl8188ru_radioa_1t_highpa_table[] = {
|
||||
{0xff, 0xffffffff}
|
||||
};
|
||||
|
||||
static struct rtl8xxxu_rfregval rtl8192eu_radioa_init_table[] = {
|
||||
{0x7f, 0x00000082}, {0x81, 0x0003fc00},
|
||||
{0x00, 0x00030000}, {0x08, 0x00008400},
|
||||
{0x18, 0x00000407}, {0x19, 0x00000012},
|
||||
{0x1b, 0x00000064}, {0x1e, 0x00080009},
|
||||
{0x1f, 0x00000880}, {0x2f, 0x0001a060},
|
||||
{0x3f, 0x00000000}, {0x42, 0x000060c0},
|
||||
{0x57, 0x000d0000}, {0x58, 0x000be180},
|
||||
{0x67, 0x00001552}, {0x83, 0x00000000},
|
||||
{0xb0, 0x000ff9f1}, {0xb1, 0x00055418},
|
||||
{0xb2, 0x0008cc00}, {0xb4, 0x00043083},
|
||||
{0xb5, 0x00008166}, {0xb6, 0x0000803e},
|
||||
{0xb7, 0x0001c69f}, {0xb8, 0x0000407f},
|
||||
{0xb9, 0x00080001}, {0xba, 0x00040001},
|
||||
{0xbb, 0x00000400}, {0xbf, 0x000c0000},
|
||||
{0xc2, 0x00002400}, {0xc3, 0x00000009},
|
||||
{0xc4, 0x00040c91}, {0xc5, 0x00099999},
|
||||
{0xc6, 0x000000a3}, {0xc7, 0x00088820},
|
||||
{0xc8, 0x00076c06}, {0xc9, 0x00000000},
|
||||
{0xca, 0x00080000}, {0xdf, 0x00000180},
|
||||
{0xef, 0x000001a0}, {0x51, 0x00069545},
|
||||
{0x52, 0x0007e45e}, {0x53, 0x00000071},
|
||||
{0x56, 0x00051ff3}, {0x35, 0x000000a8},
|
||||
{0x35, 0x000001e2}, {0x35, 0x000002a8},
|
||||
{0x36, 0x00001c24}, {0x36, 0x00009c24},
|
||||
{0x36, 0x00011c24}, {0x36, 0x00019c24},
|
||||
{0x18, 0x00000c07}, {0x5a, 0x00048000},
|
||||
{0x19, 0x000739d0},
|
||||
#ifdef EXT_PA_8192EU
|
||||
/* External PA or external LNA */
|
||||
{0x34, 0x0000a093}, {0x34, 0x0000908f},
|
||||
{0x34, 0x0000808c}, {0x34, 0x0000704d},
|
||||
{0x34, 0x0000604a}, {0x34, 0x00005047},
|
||||
{0x34, 0x0000400a}, {0x34, 0x00003007},
|
||||
{0x34, 0x00002004}, {0x34, 0x00001001},
|
||||
{0x34, 0x00000000},
|
||||
#else
|
||||
/* Regular */
|
||||
{0x34, 0x0000add7}, {0x34, 0x00009dd4},
|
||||
{0x34, 0x00008dd1}, {0x34, 0x00007dce},
|
||||
{0x34, 0x00006dcb}, {0x34, 0x00005dc8},
|
||||
{0x34, 0x00004dc5}, {0x34, 0x000034cc},
|
||||
{0x34, 0x0000244f}, {0x34, 0x0000144c},
|
||||
{0x34, 0x00000014},
|
||||
#endif
|
||||
{0x00, 0x00030159},
|
||||
{0x84, 0x00068180},
|
||||
{0x86, 0x0000014e},
|
||||
{0x87, 0x00048e00},
|
||||
{0x8e, 0x00065540},
|
||||
{0x8f, 0x00088000},
|
||||
{0xef, 0x000020a0},
|
||||
#ifdef EXT_PA_8192EU
|
||||
/* External PA or external LNA */
|
||||
{0x3b, 0x000f07b0},
|
||||
#else
|
||||
{0x3b, 0x000f02b0},
|
||||
#endif
|
||||
{0x3b, 0x000ef7b0}, {0x3b, 0x000d4fb0},
|
||||
{0x3b, 0x000cf060}, {0x3b, 0x000b0090},
|
||||
{0x3b, 0x000a0080}, {0x3b, 0x00090080},
|
||||
{0x3b, 0x0008f780},
|
||||
#ifdef EXT_PA_8192EU
|
||||
/* External PA or external LNA */
|
||||
{0x3b, 0x000787b0},
|
||||
#else
|
||||
{0x3b, 0x00078730},
|
||||
#endif
|
||||
{0x3b, 0x00060fb0}, {0x3b, 0x0005ffa0},
|
||||
{0x3b, 0x00040620}, {0x3b, 0x00037090},
|
||||
{0x3b, 0x00020080}, {0x3b, 0x0001f060},
|
||||
{0x3b, 0x0000ffb0}, {0xef, 0x000000a0},
|
||||
{0xfe, 0x00000000}, {0x18, 0x0000fc07},
|
||||
{0xfe, 0x00000000}, {0xfe, 0x00000000},
|
||||
{0xfe, 0x00000000}, {0xfe, 0x00000000},
|
||||
{0x1e, 0x00000001}, {0x1f, 0x00080000},
|
||||
{0x00, 0x00033e70},
|
||||
{0xff, 0xffffffff}
|
||||
};
|
||||
|
||||
static struct rtl8xxxu_rfregval rtl8192eu_radiob_init_table[] = {
|
||||
{0x7f, 0x00000082}, {0x81, 0x0003fc00},
|
||||
{0x00, 0x00030000}, {0x08, 0x00008400},
|
||||
{0x18, 0x00000407}, {0x19, 0x00000012},
|
||||
{0x1b, 0x00000064}, {0x1e, 0x00080009},
|
||||
{0x1f, 0x00000880}, {0x2f, 0x0001a060},
|
||||
{0x3f, 0x00000000}, {0x42, 0x000060c0},
|
||||
{0x57, 0x000d0000}, {0x58, 0x000be180},
|
||||
{0x67, 0x00001552}, {0x7f, 0x00000082},
|
||||
{0x81, 0x0003f000}, {0x83, 0x00000000},
|
||||
{0xdf, 0x00000180}, {0xef, 0x000001a0},
|
||||
{0x51, 0x00069545}, {0x52, 0x0007e42e},
|
||||
{0x53, 0x00000071}, {0x56, 0x00051ff3},
|
||||
{0x35, 0x000000a8}, {0x35, 0x000001e0},
|
||||
{0x35, 0x000002a8}, {0x36, 0x00001ca8},
|
||||
{0x36, 0x00009c24}, {0x36, 0x00011c24},
|
||||
{0x36, 0x00019c24}, {0x18, 0x00000c07},
|
||||
{0x5a, 0x00048000}, {0x19, 0x000739d0},
|
||||
#ifdef EXT_PA_8192EU
|
||||
/* External PA or external LNA */
|
||||
{0x34, 0x0000a093}, {0x34, 0x0000908f},
|
||||
{0x34, 0x0000808c}, {0x34, 0x0000704d},
|
||||
{0x34, 0x0000604a}, {0x34, 0x00005047},
|
||||
{0x34, 0x0000400a}, {0x34, 0x00003007},
|
||||
{0x34, 0x00002004}, {0x34, 0x00001001},
|
||||
{0x34, 0x00000000},
|
||||
#else
|
||||
{0x34, 0x0000add7}, {0x34, 0x00009dd4},
|
||||
{0x34, 0x00008dd1}, {0x34, 0x00007dce},
|
||||
{0x34, 0x00006dcb}, {0x34, 0x00005dc8},
|
||||
{0x34, 0x00004dc5}, {0x34, 0x000034cc},
|
||||
{0x34, 0x0000244f}, {0x34, 0x0000144c},
|
||||
{0x34, 0x00000014},
|
||||
#endif
|
||||
{0x00, 0x00030159}, {0x84, 0x00068180},
|
||||
{0x86, 0x000000ce}, {0x87, 0x00048a00},
|
||||
{0x8e, 0x00065540}, {0x8f, 0x00088000},
|
||||
{0xef, 0x000020a0},
|
||||
#ifdef EXT_PA_8192EU
|
||||
/* External PA or external LNA */
|
||||
{0x3b, 0x000f07b0},
|
||||
#else
|
||||
{0x3b, 0x000f02b0},
|
||||
#endif
|
||||
|
||||
{0x3b, 0x000ef7b0}, {0x3b, 0x000d4fb0},
|
||||
{0x3b, 0x000cf060}, {0x3b, 0x000b0090},
|
||||
{0x3b, 0x000a0080}, {0x3b, 0x00090080},
|
||||
{0x3b, 0x0008f780},
|
||||
#ifdef EXT_PA_8192EU
|
||||
/* External PA or external LNA */
|
||||
{0x3b, 0x000787b0},
|
||||
#else
|
||||
{0x3b, 0x00078730},
|
||||
#endif
|
||||
{0x3b, 0x00060fb0}, {0x3b, 0x0005ffa0},
|
||||
{0x3b, 0x00040620}, {0x3b, 0x00037090},
|
||||
{0x3b, 0x00020080}, {0x3b, 0x0001f060},
|
||||
{0x3b, 0x0000ffb0}, {0xef, 0x000000a0},
|
||||
{0x00, 0x00010159}, {0xfe, 0x00000000},
|
||||
{0xfe, 0x00000000}, {0xfe, 0x00000000},
|
||||
{0xfe, 0x00000000}, {0x1e, 0x00000001},
|
||||
{0x1f, 0x00080000}, {0x00, 0x00033e70},
|
||||
{0xff, 0xffffffff}
|
||||
};
|
||||
|
||||
static struct rtl8xxxu_rfregs rtl8xxxu_rfregs[] = {
|
||||
{ /* RF_A */
|
||||
.hssiparm1 = REG_FPGA0_XA_HSSI_PARM1,
|
||||
@ -6447,6 +6593,14 @@ static int rtl8xxxu_init_device(struct ieee80211_hw *hw)
|
||||
rftable = rtl8192cu_radiob_2t_init_table;
|
||||
ret = rtl8xxxu_init_phy_rf(priv, rftable, RF_B);
|
||||
break;
|
||||
case RTL8192E:
|
||||
rftable = rtl8192eu_radioa_init_table;
|
||||
ret = rtl8xxxu_init_phy_rf(priv, rftable, RF_A);
|
||||
if (ret)
|
||||
break;
|
||||
rftable = rtl8192eu_radiob_init_table;
|
||||
ret = rtl8xxxu_init_phy_rf(priv, rftable, RF_B);
|
||||
break;
|
||||
default:
|
||||
ret = -EINVAL;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user