/** @brief RTL2832 FC2580 NIM module builder Use BuildRtl2832Fc2580Module() to build RTL2832 FC2580 NIM module, set all module function pointers with the corresponding functions, and initialize module private variables. @param [in] ppNim Pointer to RTL2832 FC2580 NIM module pointer @param [in] pDvbtNimModuleMemory Pointer to an allocated DVB-T NIM module memory @param [in] I2cReadingByteNumMax Maximum I2C reading byte number for basic I2C reading function @param [in] I2cWritingByteNumMax Maximum I2C writing byte number for basic I2C writing function @param [in] I2cRead Basic I2C reading function pointer @param [in] I2cWrite Basic I2C writing function pointer @param [in] WaitMs Basic waiting function pointer @param [in] pRtl2832ExtraModuleMemory Pointer to an allocated RTL2832 extra module memory @param [in] DemodDeviceAddr RTL2832 I2C device address @param [in] DemodCrystalFreqHz RTL2832 crystal frequency in Hz @param [in] DemodAppMode RTL2832 application mode for setting @param [in] DemodTsInterfaceMode RTL2832 TS interface mode for setting @param [in] pFc2580ExtraModuleMemory Pointer to an allocated FC2580 extra module memory @param [in] TunerDeviceAddr FC2580 I2C device address @param [in] TunerAgcMode FC2580 AGC mode @note -# One should call BuildRtl2832Fc2580Module() to build RTL2832 FC2580 NIM module before using it. */ void BuildRtl2832Fc2580Module( DVBT_NIM_MODULE **ppNim, // DVB-T NIM dependence DVBT_NIM_MODULE *pDvbtNimModuleMemory, unsigned char I2cReadingByteNumMax, // Base interface dependence unsigned char I2cWritingByteNumMax, BASE_FP_I2C_READ I2cRead, BASE_FP_I2C_WRITE I2cWrite, BASE_FP_WAIT_MS WaitMs, RTL2832_EXTRA_MODULE *pRtl2832ExtraModuleMemory, // Demod dependence unsigned char DemodDeviceAddr, unsigned long DemodCrystalFreqHz, int DemodAppMode, int DemodTsInterfaceMode, unsigned long DemodUpdateFuncRefPeriodMs, int DemodIsFunc1Enabled, FC2580_EXTRA_MODULE *pFc2580ExtraModuleMemory, // Tuner dependence unsigned char TunerDeviceAddr, unsigned long TunerCrystalFreqHz, int TunerAgcMode ) { DVBT_NIM_MODULE *pNim; // Set NIM module pointer with NIM module memory. *ppNim = pDvbtNimModuleMemory; // Get NIM module. pNim = *ppNim; // Set I2C bridge module pointer with I2C bridge module memory. pNim->pI2cBridge = &pNim->I2cBridgeModuleMemory; // Set NIM extra module pointer. pNim->pExtra = INVALID_POINTER_VALUE; // Set NIM type. pNim->NimType = DVBT_NIM_RTL2832_FC2580; // Build base interface module. BuildBaseInterface( &pNim->pBaseInterface, &pNim->BaseInterfaceModuleMemory, I2cReadingByteNumMax, I2cWritingByteNumMax, I2cRead, I2cWrite, WaitMs ); // Build RTL2832 demod module. BuildRtl2832Module( &pNim->pDemod, &pNim->DvbtDemodModuleMemory, pRtl2832ExtraModuleMemory, &pNim->BaseInterfaceModuleMemory, &pNim->I2cBridgeModuleMemory, DemodDeviceAddr, DemodCrystalFreqHz, DemodAppMode, DemodUpdateFuncRefPeriodMs, DemodIsFunc1Enabled ); // Build FC2580 tuner module. BuildFc2580Module( &pNim->pTuner, &pNim->TunerModuleMemory, pFc2580ExtraModuleMemory, &pNim->BaseInterfaceModuleMemory, &pNim->I2cBridgeModuleMemory, TunerDeviceAddr, TunerCrystalFreqHz, TunerAgcMode ); // Set NIM module variables. pNim->DemodTsInterfaceMode = DemodTsInterfaceMode; // Set NIM module function pointers with default functions. pNim->GetNimType = dvbt_nim_default_GetNimType; pNim->GetParameters = dvbt_nim_default_GetParameters; pNim->IsSignalPresent = dvbt_nim_default_IsSignalPresent; pNim->IsSignalLocked = dvbt_nim_default_IsSignalLocked; pNim->GetSignalStrength = dvbt_nim_default_GetSignalStrength; pNim->GetSignalQuality = dvbt_nim_default_GetSignalQuality; pNim->GetBer = dvbt_nim_default_GetBer; pNim->GetSnrDb = dvbt_nim_default_GetSnrDb; pNim->GetTrOffsetPpm = dvbt_nim_default_GetTrOffsetPpm; pNim->GetCrOffsetHz = dvbt_nim_default_GetCrOffsetHz; pNim->GetTpsInfo = dvbt_nim_default_GetTpsInfo; pNim->UpdateFunction = dvbt_nim_default_UpdateFunction; // Set NIM module function pointers with particular functions. pNim->Initialize = rtl2832_fc2580_Initialize; pNim->SetParameters = rtl2832_fc2580_SetParameters; return; }
/** @brief RTL2836 FC2580 NIM module builder Use BuildRtl2836Fc2580Module() to build RTL2836 FC2580 NIM module, set all module function pointers with the corresponding functions, and initialize module private variables. @param [in] ppNim Pointer to RTL2836 FC2580 NIM module pointer @param [in] pDtmbNimModuleMemory Pointer to an allocated DTMB NIM module memory @param [in] I2cReadingByteNumMax Maximum I2C reading byte number for basic I2C reading function @param [in] I2cWritingByteNumMax Maximum I2C writing byte number for basic I2C writing function @param [in] I2cRead Basic I2C reading function pointer @param [in] I2cWrite Basic I2C writing function pointer @param [in] WaitMs Basic waiting function pointer @param [in] DemodDeviceAddr RTL2836 I2C device address @param [in] DemodCrystalFreqHz RTL2836 crystal frequency in Hz @param [in] DemodTsInterfaceMode RTL2836 TS interface mode @param [in] DemodUpdateFuncRefPeriodMs RTL2836 update function reference period in millisecond @param [in] DemodIsFunc1Enabled RTL2836 Function 1 enabling status for setting @param [in] DemodIsFunc2Enabled RTL2836 Function 2 enabling status for setting @param [in] TunerDeviceAddr FC2580 I2C device address @param [in] TunerCrystalFreqHz FC2580 crystal frequency in Hz @param [in] TunerAgcMode FC2580 AGC mode @note -# One should call BuildRtl2836Fc2580Module() to build RTL2836 FC2580 NIM module before using it. */ void BuildRtl2836Fc2580Module( DTMB_NIM_MODULE **ppNim, // DTMB NIM dependence DTMB_NIM_MODULE *pDtmbNimModuleMemory, unsigned long I2cReadingByteNumMax, // Base interface dependence unsigned long I2cWritingByteNumMax, BASE_FP_I2C_READ I2cRead, BASE_FP_I2C_WRITE I2cWrite, BASE_FP_WAIT_MS WaitMs, unsigned char DemodDeviceAddr, // Demod dependence unsigned long DemodCrystalFreqHz, int DemodTsInterfaceMode, unsigned long DemodUpdateFuncRefPeriodMs, int DemodIsFunc1Enabled, int DemodIsFunc2Enabled, unsigned char TunerDeviceAddr, // Tuner dependence unsigned long TunerCrystalFreqHz, int TunerAgcMode ) { DTMB_NIM_MODULE *pNim; // Set NIM module pointer with NIM module memory. *ppNim = pDtmbNimModuleMemory; // Get NIM module. pNim = *ppNim; // Set I2C bridge module pointer with I2C bridge module memory. pNim->pI2cBridge = &pNim->I2cBridgeModuleMemory; // Set NIM type. pNim->NimType = DTMB_NIM_RTL2836_FC2580; // Build base interface module. BuildBaseInterface( &pNim->pBaseInterface, &pNim->BaseInterfaceModuleMemory, I2cReadingByteNumMax, I2cWritingByteNumMax, I2cRead, I2cWrite, WaitMs ); // Build RTL2836 demod module. BuildRtl2836Module( &pNim->pDemod, &pNim->DtmbDemodModuleMemory, &pNim->BaseInterfaceModuleMemory, &pNim->I2cBridgeModuleMemory, DemodDeviceAddr, DemodCrystalFreqHz, DemodTsInterfaceMode, DemodUpdateFuncRefPeriodMs, DemodIsFunc1Enabled, DemodIsFunc2Enabled ); // Build FC2580 tuner module. BuildFc2580Module( &pNim->pTuner, &pNim->TunerModuleMemory, &pNim->BaseInterfaceModuleMemory, &pNim->I2cBridgeModuleMemory, TunerDeviceAddr, TunerCrystalFreqHz, TunerAgcMode ); // Set NIM module function pointers with default functions. pNim->GetNimType = dtmb_nim_default_GetNimType; pNim->GetParameters = dtmb_nim_default_GetParameters; pNim->IsSignalPresent = dtmb_nim_default_IsSignalPresent; pNim->IsSignalLocked = dtmb_nim_default_IsSignalLocked; pNim->GetSignalStrength = dtmb_nim_default_GetSignalStrength; pNim->GetSignalQuality = dtmb_nim_default_GetSignalQuality; pNim->GetBer = dtmb_nim_default_GetBer; pNim->GetPer = dtmb_nim_default_GetPer; pNim->GetSnrDb = dtmb_nim_default_GetSnrDb; pNim->GetTrOffsetPpm = dtmb_nim_default_GetTrOffsetPpm; pNim->GetCrOffsetHz = dtmb_nim_default_GetCrOffsetHz; pNim->GetSignalInfo = dtmb_nim_default_GetSignalInfo; pNim->UpdateFunction = dtmb_nim_default_UpdateFunction; // Set NIM module function pointers with particular functions. pNim->Initialize = rtl2836_fc2580_Initialize; pNim->SetParameters = rtl2836_fc2580_SetParameters; return; }