blob: c710f48d0e28f9382e55af8bd5ed92e1e6a63e42 [file] [log] [blame]
rjw6c1fd8f2022-11-30 14:33:01 +08001/*******************************************************************************
2* Modification Notice:
3* --------------------------
4* This software is modified by MediaTek Inc. and the information contained
5* herein is confidential. The software may not be copied and the information
6* contained herein may not be used or disclosed except with the written
7* permission of MediaTek Inc. (C) 2016
8*
9* BY OPENING THIS FILE, BUYER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
10* THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
11* RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO BUYER ON
12* AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
13* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
14* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
15* NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
16* SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
17* SUPPLIED WITH THE MEDIATEK SOFTWARE, AND BUYER AGREES TO LOOK ONLY TO SUCH
18* THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. MEDIATEK SHALL ALSO
19* NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE RELEASES MADE TO BUYER'S
20* SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM.
21*
22* BUYER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND CUMULATIVE
23* LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
24* AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
25* OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY BUYER TO
26* MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE.
27*
28* THE TRANSACTION CONTEMPLATED HEREUNDER SHALL BE CONSTRUED IN ACCORDANCE
29* WITH THE LAWS OF THE STATE OF CALIFORNIA, USA, EXCLUDING ITS CONFLICT OF
30* LAWS PRINCIPLES. ANY DISPUTES, CONTROVERSIES OR CLAIMS ARISING THEREOF AND
31* RELATED THERETO SHALL BE SETTLED BY ARBITRATION IN SAN FRANCISCO, CA, UNDER
32* THE RULES OF THE INTERNATIONAL CHAMBER OF COMMERCE (ICC).
33*
34*******************************************************************************/
35
36/*******************************************************************************
37*
38* Filename:
39* ---------
40* cl1tstdpd.h
41*
42* Project:
43* --------
44* MTXXXX Project
45*
46* Description:
47* ------------
48* This file contains the log IQ functions.
49*
50* Author:
51* -------
52*
53*
54*==============================================================================
55* HISTORY
56* Below this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
57*------------------------------------------------------------------------------
58 * removed!
59 * removed!
60 * removed!
61*
62 * removed!
63 * removed!
64*
65*
66*
67*
68*
69*
70*
71*------------------------------------------------------------------------------
72* Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
73*==============================================================================
74******************************************************************************/
75
76#ifndef _CL1TST_DPD_H_
77#define _CL1TST_DPD_H_
78
79/*----------------------------------------------------------------------------
80 Include Files
81----------------------------------------------------------------------------*/
82#include "kal_general_types.h"
83#include "kal_public_defs.h"
84#include "sysapi.h"
85
86#define CL1TST_DPD_RETRY_LIMIT 3
87#define CL1TST_DPD_REF_TEMP_INDEX 4
88#define CL1TST_DPD_FACTORY_DIFF 12
89
90/** define DPD state */
91typedef enum
92{
93 CL1TST_DPD_FSM_IDLE = 0,
94 CL1TST_DPD_FSM_TX_ON_TPC = 1,
95 CL1TST_DPD_FSM_TPC = 2,
96 CL1TST_DPD_FSM_TX_OFF = 3,
97 CL1TST_DPD_FSM_GAIN_QUERY = 4,
98 CL1TST_DPD_FSM_TX_OFF_WAIT = 5,
99 CL1TST_DPD_FSM_NUM
100} Cl1TstDpdStateE;
101
102/* 8-level PA dc2dc for DPD calibration */
103typedef enum
104{
105 CL1TST_DPD_PA_IDX0 = 0,
106 CL1TST_DPD_PA_IDX1 = 1,
107 CL1TST_DPD_PA_IDX2 = 2,
108 CL1TST_DPD_PA_IDX3 = 3,
109 CL1TST_DPD_PA_IDX4 = 4,
110 CL1TST_DPD_PA_IDX5 = 5,
111 CL1TST_DPD_PA_IDX6 = 6,
112 CL1TST_DPD_PA_IDX7 = 7,
113 CL1TST_DPD_PA_NULL = 0x7f
114} Cl1TstDpdPaIdxE;
115
116/* PA level-7 index */
117typedef enum
118{
119 CL1TST_DPD_L7_IDX0 = 0,
120 CL1TST_DPD_L7_IDX1 = 1,
121 CL1TST_DPD_L7_NULL = 0x7f
122} Cl1TstDpdL7IdxE;
123
124/* define System time structure */
125typedef struct Cl1DpdSysTimeTag
126{
127 /* Slot number */
128 kal_uint8 Slot;
129
130 /* half slot boundary system time */
131 kal_uint32 Time;
132} Cl1DpdSysTimeT;
133
134/* define target time structure */
135typedef struct Cl1DpdTargetTimeTag
136{
137 /* Slot number */
138 kal_uint64 SupFram;
139
140 /* system time */
141 kal_uint32 SysTime;
142} Cl1DpdTargetTimeT;
143
144typedef struct
145{
146 kal_uint8 BandClass;
147 kal_uint16 ChanNum;
148} Cl1TstDpdFreqParaT;
149
150/** This structure is updated by Algo driver */
151typedef struct Cl1TstDpdAlgoUpdParaTag
152{
153 /** PA table index */
154 kal_uint8 PaTbIdx;
155
156 /** 0: the first level 7
157 1: the second level level 7 */
158 kal_uint8 PaL7Idx;
159
160 /** target power */
161 kal_int16 Peak;
162
163 /** PA gain (include compensation) */
164 kal_int16 PaGain;
165
166} Cl1TstDpdAlgoUpdParaT;
167
168/** This structure is updated by RF driver */
169typedef struct Cl1TstDpdRfdUpdParaTag
170{
171 /** target power */
172 kal_int16 Prf;
173
174 /** PA gain (include compensation) */
175 kal_int16 PaGain;
176
177 /** PA gain compensation */
178 kal_int16 PaGainComp;
179
180 /** Coupler loss (include compensation) */
181 kal_int16 CouplerLoss;
182
183} Cl1TstDpdRfdUpdParaT;
184
185/** This structure is used to store UPC HW information in EVDO and 1xRTT mode. */
186typedef struct Cl1TstDpdUpcInfoTag
187{
188 /** PGA gain */
189 kal_int16 PgaGain;
190
191 /** DET path PGA gain */
192 kal_int16 DetGain;
193
194 /** BB gain */
195 kal_int16 BbGain;
196} Cl1TstDpdUpcInfoT;
197
198/** This structure is used to store Fail Info. */
199typedef struct Cl1TstDpdFailInfoTag
200{
201 kal_uint8 Status;
202
203 /** Fail Rat */
204 kal_uint8 CurRfMode;
205
206 /** Fail band class */
207 kal_uint8 CurBandClass;
208
209 /** Fail channel number */
210 kal_uint16 CurChanNum;
211
212 /** Fail PA index */
213 kal_uint16 CurPaIdx;
214
215 /** Fail PA Gain */
216 kal_int16 CurPaGain;
217} Cl1TstDpdFailInfoT;
218
219typedef struct
220{
221 CRfTestCmd_StartDpd_ReqInfo StartInfo;
222 Cl1TstTxDpdStartPduT StartPdu[CL1D_RF_BAND_CLASS_MAX];
223
224 Cl1TstDpdStatusE DpdStatus;
225
226 Cl1TstDpdStateE DpdState;
227
228 Cl1DpdSysTimeT SysTime;
229
230 SysSFrameTimeT TarTime;
231
232 Cl1TstDpdFreqParaT FreqPara;
233
234 Cl1TstDpdAlgoUpdParaT AlgoUpdPara;
235
236 Cl1TstDpdRfdUpdParaT RfdUpdPara;
237
238 Cl1TstDpdUpcInfoT UpcInfo;
239
240 MMDPD_FAC_PGA_PARAM_T *p_target_pga_table;
241
242 /* The parameters for FXP and PA calibration result pointer */
243 DPD_FXP_PARAM FxpPara;
244
245 /* To restore the calibrated PA gain result temperarily */
246 kal_int16 PaGain[CL1TST_DPD_FREQ_NUM][CL1TST_DPD_PA_NUM];
247
248 Cl1TstDpdFailInfoT FailInfo;
249
250 kal_int16 TrValue;
251 kal_uint8 QueryCnt;
252 kal_uint8 TxOnFlag;
253 kal_uint8 TxOffCnt;
254
255 kal_uint8 query;
256
257 kal_bool rf_tx_fec_wakeup_flag;
258
259 kal_uint8 fxp_retry_count;
260
261 kal_uint16 WaitSmples;
262 kal_uint16 DpdThUpper;
263 kal_uint16 TestMode;
264 kal_uint16 InitMode;
265 kal_uint16 TestCnt3;
266 kal_uint32 HSlotCnt;
267
268} Cl1DpdDataT;
269
270/*----------------------------------------------------------------------------
271 global fucction
272----------------------------------------------------------------------------*/
273extern void Cl1TstDpdFacMain(void);
274
275#endif /* _CL1TST_DPD_H_ */
276