aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/staging/rtlwifi/phydm/phydm_iqk.h
blob: 0ed21e06fc336df4aee0352051ea6c9a5093ba34 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
/* SPDX-License-Identifier: GPL-2.0 */
/******************************************************************************
 *
 * Copyright(c) 2007 - 2016  Realtek Corporation.
 *
 * Contact Information:
 * wlanfae <wlanfae@realtek.com>
 * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
 * Hsinchu 300, Taiwan.
 *
 * Larry Finger <Larry.Finger@lwfinger.net>
 *
 *****************************************************************************/

#ifndef __PHYDMIQK_H__
#define __PHYDMIQK_H__

/*--------------------------Define Parameters-------------------------------*/
#define LOK_delay 1
#define WBIQK_delay 10
#define TX_IQK 0
#define RX_IQK 1
#define TXIQK 0
#define RXIQK1 1
#define RXIQK2 2
#define GSRXK1 0
#define GSRXK2 1
#define kcount_limit_80m 2
#define kcount_limit_others 4
#define rxiqk_gs_limit 4

#define NUM 4
/*----------------------End Define Parameters-------------------------------*/

struct dm_iqk_info {
	bool lok_fail[NUM];
	bool iqk_fail[2][NUM];
	u32 iqc_matrix[2][NUM];
	u8 iqk_times;
	u32 rf_reg18;
	u32 lna_idx;
	u8 rxiqk_step;
	u8 tmp1bcc;
	u8 kcount;

	u32 iqk_channel[2];
	bool iqk_fail_report[2][4][2]; /*channel/path/TRX(TX:0, RX:1) */
	u32 iqk_cfir_real[2][4][2]
			 [8]; /*channel / path / TRX(TX:0, RX:1) / CFIR_real*/
	u32 iqk_cfir_imag[2][4][2]
			 [8]; /*channel / path / TRX(TX:0, RX:1) / CFIR_imag*/
	u8 retry_count[2][4][3]; /* channel / path / (TXK:0, RXK1:1, RXK2:2) */
	u8 gs_retry_count[2][4][2]; /* channel / path / (GSRXK1:0, GSRXK2:1) */
	u8 rxiqk_fail_code[2][4]; /* channel / path
				   * 0:SRXK1 fail, 1:RXK1 fail 2:RXK2 fail
				   */
	u32 lok_idac[2][4]; /*channel / path*/
	u16 rxiqk_agc[2][4]; /*channel / path*/
	u32 bypass_iqk[2][4]; /*channel / 0xc94/0xe94*/
	u32 tmp_gntwl;
	bool is_btg;
	bool isbnd;
};

#endif