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:
Jes Sorensen 2016-04-07 14:19:19 -04:00 committed by Kalle Valo
parent 80805aa5f3
commit 19102f8419

View File

@ -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;
}