rf_txiq.h
上传用户:gelin96
上传日期:2017-01-08
资源大小:20993k
文件大小:7k
源码类别:

MTK

开发平台:

C++ Builder

  1. /*****************************************************************************
  2. *  Copyright Statement:
  3. *  --------------------
  4. *  This software is protected by Copyright 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) 2005
  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.  * Filename:
  38.  * ---------
  39.  *   rf_txiq.h
  40.  *
  41.  * Project:
  42.  * --------
  43.  *   Maui META APP
  44.  *
  45.  * Description:
  46.  * ------------
  47.  *   RF TX IQ header
  48.  *
  49.  * Author:
  50.  * -------
  51.  *  Andy Ueng (mtk00490)
  52.  *
  53.  *============================================================================
  54.  *             HISTORY
  55.  * Below this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
  56.  *------------------------------------------------------------------------------
  57.  * $Revision$
  58.  * $Modtime$
  59.  * $Log$
  60.  * 
  61.  *------------------------------------------------------------------------------
  62.  * Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
  63.  *============================================================================
  64.  ****************************************************************************/
  65. #ifndef  _RF_TXIQ_H_
  66. #define  _RF_TXIQ_H_
  67. // common
  68. #ifndef META_DLL_H
  69. #include "meta.h"
  70. #endif
  71. #ifndef  _METAAPP_COMMON_H_
  72. #include "metaapp_common.h"
  73. #endif
  74. #ifndef  _MAN_HANDLE_H_
  75. #include "man_handle.h"
  76. #endif
  77. // RF
  78. #ifndef  _RF_COMMON_H_
  79. #include "rf_common.h"
  80. #endif
  81. /*---------------------------------------------------------------------------*/
  82. /*---------------------------------------------------------------------------*/
  83. typedef struct
  84. {
  85.     E_BANDSEL e_band;
  86.     E_BBTXCFG_VER_T e_bb_tx_cfg_ver;
  87.     short s_arfcn;
  88.     char  c_tsc;
  89.     short s_pcl;
  90.     int i_frames;
  91.     short s_afc_dac;
  92.     APCTxPattern e_burst_type;
  93. }S_TXIQRUN;
  94. typedef struct
  95. {
  96.     bool b_bbtx_common_mode_voltage;
  97.     bool b_bbtx_gain;
  98.     bool b_bbtx_calrcsel;
  99.     bool b_bbtx_trimI;
  100.     bool b_bbtx_trimQ;
  101.     bool b_bbtx_offsetI;
  102.     bool b_bbtx_offsetQ;
  103.     bool b_bbtx_isCalibrated;
  104.     bool b_apc_bat_low_voltage;
  105.     bool b_apc_bat_high_voltage;
  106.     bool b_apc_bat_low_temperature;
  107.     bool b_apc_bat_high_temperature;
  108.     bool b_bbtx_common_mode_voltage_h;
  109.     bool b_bbtx_gain_h;
  110.     bool b_bbtx_calrcsel_h;
  111.     bool b_bbtx_trimI_h;
  112.     bool b_bbtx_trimQ_h;
  113.     bool b_bbtx_offsetI_h;
  114.     bool b_bbtx_offsetQ_h;
  115.     bool b_bbtx_phsel;
  116.     bool b_bbtx_phsel_h;
  117. }S_BBTXPARA_CHANGE_FLAG_T;
  118. /*---------------------------------------------------------------------------*/
  119. class  CRFTXIQ
  120. {
  121. private:
  122.     E_METAAPP_RESULT_T   m_eConfirmState;
  123.     unsigned int  m_uiFinalRfId;
  124.     CMETAHANDLE m_META_HANDLE_Obj;
  125.     bool m_bTxIqRunTrigger;
  126.     bool m_bDcCoarseSupport;
  127.     S_TXIQRUN m_sTxIqRun;
  128.     E_BBTXCFG_VER_T m_eBbTxCfgVer;
  129.     E_NVRAM_BBTXCFG_VER_T  m_eNvBbTxCfgVer;
  130.     RfBBTXCfg4 m_sBbTxCfg;
  131.     BBTXParameters_T  m_sL1CalTxIq;
  132.     S_UI_L1CAL_TXIQ m_sUiL1CalTxIq;
  133.     short        m_sRFID_TXIQ;
  134.     bool  m_bDownloadTrigger;
  135.     unsigned int m_uiTXIQBufSize;
  136.     char        *m_cTXIQBuf;
  137.     S_BBTXPARA_CHANGE_FLAG_T m_BbTxParaChangeFlag;
  138. protected:
  139. public:
  140.    void  Confirm(E_METAAPP_RESULT_T confirm_state);
  141.    CRFTXIQ(void);
  142.    ~CRFTXIQ();
  143.    void  ReleaseResource(void);
  144.    void  Init(void);
  145.    void  SetBbTxParaChangeFlag(void);
  146.    void  ResetBbTxParaChangeFlag(void);
  147.    // NVRAM
  148.    void  REQ_Read_From_NVRAM(void);
  149.    void  REQ_Write_To_NVRAM(void);
  150.    void  CNF_ReadFromNVRAM(void);
  151.    void  CNF_WriteToNVRAM(void);
  152.    
  153. /*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
  154.   // Public member
  155.    void  (*ConfirmCallback)( void );
  156.  // Public interface
  157.    
  158.    void  Compose_BBTXParameters(void);
  159.    void  DeCompose_BBTXParameters(void);
  160.    void  REQ_Read_From_NVRAM_Start(unsigned int rfmod_id, E_BBTXCFG_VER_T bbtxcfg_ver);
  161.    void  REQ_Write_To_NVRAM_Start(unsigned int rfmod_id, E_BBTXCFG_VER_T bbtxcfg_ver);
  162.    bool  TxIqSectionExist(char *filename);
  163.    bool  REQ_Read_From_File(char *filename, unsigned int rfmod_id, E_BBTXCFG_VER_T bbtxcfg_ver);
  164.    bool  REQ_Write_To_File(char *filename, unsigned int rfmod_id, E_BBTXCFG_VER_T bbtxcfg_ver);
  165.    
  166.    // Global information
  167.    E_METAAPP_RESULT_T  Get_ConfirmState(void);
  168.    void  Set_BBTxParametersFromAutoK(RfBBTXCfg2*  p_rf_bbtx_cfg);
  169.    signed char Get_BBTx_OffsetI(void);
  170.    signed char Get_BBTx_OffsetQ(void);
  171.    void  Set_BBTx_OffsetI(char offset_i);
  172.    void  Set_BBTx_OffsetQ(char offset_q);
  173.    void  Set_BBTx_isCalibrated(unsigned char isCalibrated);
  174.    BBTXParameters_T*  Get_BBTXParameters(void);
  175.    void  Set_BBTXParameters(BBTXParameters_T  l1cal_txiq_par);
  176.    S_UI_L1CAL_TXIQ* Get_UiBBTXParameters(void);
  177.    void Set_UiBBTXParameters(E_BBTXCFG_VER_T eBbTxCfgVer, unsigned int rf_id, S_UI_L1CAL_TXIQ l1cal_txiq_par);
  178.    void Set_BBTXChangeFlag(S_BBTXPARA_CHANGE_FLAG_T flag);
  179. };
  180. /*---------------------------------------------------------------------------*/
  181. #endif