rf_txiq.h
上传用户:gelin96
上传日期:2017-01-08
资源大小:20993k
文件大小:7k
- /*****************************************************************************
- * Copyright Statement:
- * --------------------
- * This software is protected by Copyright and the information contained
- * herein is confidential. The software may not be copied and the information
- * contained herein may not be used or disclosed except with the written
- * permission of MediaTek Inc. (C) 2005
- *
- * BY OPENING THIS FILE, BUYER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
- * THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
- * RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO BUYER ON
- * AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
- * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
- * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
- * NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
- * SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
- * SUPPLIED WITH THE MEDIATEK SOFTWARE, AND BUYER AGREES TO LOOK ONLY TO SUCH
- * THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. MEDIATEK SHALL ALSO
- * NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE RELEASES MADE TO BUYER'S
- * SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM.
- *
- * BUYER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND CUMULATIVE
- * LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
- * AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
- * OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY BUYER TO
- * MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE.
- *
- * THE TRANSACTION CONTEMPLATED HEREUNDER SHALL BE CONSTRUED IN ACCORDANCE
- * WITH THE LAWS OF THE STATE OF CALIFORNIA, USA, EXCLUDING ITS CONFLICT OF
- * LAWS PRINCIPLES. ANY DISPUTES, CONTROVERSIES OR CLAIMS ARISING THEREOF AND
- * RELATED THERETO SHALL BE SETTLED BY ARBITRATION IN SAN FRANCISCO, CA, UNDER
- * THE RULES OF THE INTERNATIONAL CHAMBER OF COMMERCE (ICC).
- *
- *****************************************************************************/
- /*****************************************************************************
- *
- * Filename:
- * ---------
- * rf_txiq.h
- *
- * Project:
- * --------
- * Maui META APP
- *
- * Description:
- * ------------
- * RF TX IQ header
- *
- * Author:
- * -------
- * Andy Ueng (mtk00490)
- *
- *============================================================================
- * HISTORY
- * Below this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
- *------------------------------------------------------------------------------
- * $Revision$
- * $Modtime$
- * $Log$
- *
- *------------------------------------------------------------------------------
- * Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
- *============================================================================
- ****************************************************************************/
- #ifndef _RF_TXIQ_H_
- #define _RF_TXIQ_H_
- // common
- #ifndef META_DLL_H
- #include "meta.h"
- #endif
- #ifndef _METAAPP_COMMON_H_
- #include "metaapp_common.h"
- #endif
- #ifndef _MAN_HANDLE_H_
- #include "man_handle.h"
- #endif
- // RF
- #ifndef _RF_COMMON_H_
- #include "rf_common.h"
- #endif
- /*---------------------------------------------------------------------------*/
- /*---------------------------------------------------------------------------*/
- typedef struct
- {
- E_BANDSEL e_band;
- E_BBTXCFG_VER_T e_bb_tx_cfg_ver;
- short s_arfcn;
- char c_tsc;
- short s_pcl;
- int i_frames;
- short s_afc_dac;
- APCTxPattern e_burst_type;
- }S_TXIQRUN;
- typedef struct
- {
- bool b_bbtx_common_mode_voltage;
- bool b_bbtx_gain;
- bool b_bbtx_calrcsel;
- bool b_bbtx_trimI;
- bool b_bbtx_trimQ;
- bool b_bbtx_offsetI;
- bool b_bbtx_offsetQ;
- bool b_bbtx_isCalibrated;
- bool b_apc_bat_low_voltage;
- bool b_apc_bat_high_voltage;
- bool b_apc_bat_low_temperature;
- bool b_apc_bat_high_temperature;
- bool b_bbtx_common_mode_voltage_h;
- bool b_bbtx_gain_h;
- bool b_bbtx_calrcsel_h;
- bool b_bbtx_trimI_h;
- bool b_bbtx_trimQ_h;
- bool b_bbtx_offsetI_h;
- bool b_bbtx_offsetQ_h;
- bool b_bbtx_phsel;
- bool b_bbtx_phsel_h;
- }S_BBTXPARA_CHANGE_FLAG_T;
- /*---------------------------------------------------------------------------*/
- class CRFTXIQ
- {
- private:
- E_METAAPP_RESULT_T m_eConfirmState;
- unsigned int m_uiFinalRfId;
- CMETAHANDLE m_META_HANDLE_Obj;
- bool m_bTxIqRunTrigger;
- bool m_bDcCoarseSupport;
- S_TXIQRUN m_sTxIqRun;
- E_BBTXCFG_VER_T m_eBbTxCfgVer;
- E_NVRAM_BBTXCFG_VER_T m_eNvBbTxCfgVer;
- RfBBTXCfg4 m_sBbTxCfg;
- BBTXParameters_T m_sL1CalTxIq;
- S_UI_L1CAL_TXIQ m_sUiL1CalTxIq;
- short m_sRFID_TXIQ;
- bool m_bDownloadTrigger;
- unsigned int m_uiTXIQBufSize;
- char *m_cTXIQBuf;
- S_BBTXPARA_CHANGE_FLAG_T m_BbTxParaChangeFlag;
- protected:
- public:
- void Confirm(E_METAAPP_RESULT_T confirm_state);
- CRFTXIQ(void);
- ~CRFTXIQ();
- void ReleaseResource(void);
- void Init(void);
- void SetBbTxParaChangeFlag(void);
- void ResetBbTxParaChangeFlag(void);
- // NVRAM
- void REQ_Read_From_NVRAM(void);
- void REQ_Write_To_NVRAM(void);
- void CNF_ReadFromNVRAM(void);
- void CNF_WriteToNVRAM(void);
-
- /*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
- // Public member
- void (*ConfirmCallback)( void );
- // Public interface
-
- void Compose_BBTXParameters(void);
- void DeCompose_BBTXParameters(void);
- void REQ_Read_From_NVRAM_Start(unsigned int rfmod_id, E_BBTXCFG_VER_T bbtxcfg_ver);
- void REQ_Write_To_NVRAM_Start(unsigned int rfmod_id, E_BBTXCFG_VER_T bbtxcfg_ver);
- bool TxIqSectionExist(char *filename);
- bool REQ_Read_From_File(char *filename, unsigned int rfmod_id, E_BBTXCFG_VER_T bbtxcfg_ver);
- bool REQ_Write_To_File(char *filename, unsigned int rfmod_id, E_BBTXCFG_VER_T bbtxcfg_ver);
-
- // Global information
- E_METAAPP_RESULT_T Get_ConfirmState(void);
- void Set_BBTxParametersFromAutoK(RfBBTXCfg2* p_rf_bbtx_cfg);
- signed char Get_BBTx_OffsetI(void);
- signed char Get_BBTx_OffsetQ(void);
- void Set_BBTx_OffsetI(char offset_i);
- void Set_BBTx_OffsetQ(char offset_q);
- void Set_BBTx_isCalibrated(unsigned char isCalibrated);
- BBTXParameters_T* Get_BBTXParameters(void);
- void Set_BBTXParameters(BBTXParameters_T l1cal_txiq_par);
- S_UI_L1CAL_TXIQ* Get_UiBBTXParameters(void);
- void Set_UiBBTXParameters(E_BBTXCFG_VER_T eBbTxCfgVer, unsigned int rf_id, S_UI_L1CAL_TXIQ l1cal_txiq_par);
- void Set_BBTXChangeFlag(S_BBTXPARA_CHANGE_FLAG_T flag);
- };
- /*---------------------------------------------------------------------------*/
- #endif