diff options
Diffstat (limited to 'drivers/media')
-rw-r--r-- | drivers/media/dvb/frontends/drxk_hard.c | 3479 | ||||
-rw-r--r-- | drivers/media/dvb/frontends/tda18271c2dd.c | 4 |
2 files changed, 2170 insertions, 1313 deletions
diff --git a/drivers/media/dvb/frontends/drxk_hard.c b/drivers/media/dvb/frontends/drxk_hard.c index 5ac5e7653cb..f2c5a926160 100644 --- a/drivers/media/dvb/frontends/drxk_hard.c +++ b/drivers/media/dvb/frontends/drxk_hard.c @@ -77,10 +77,6 @@ bool IsA1WithRomCode(struct drxk_state *state) #define NOA1ROM 0 -#ifndef CHK_ERROR -#define CHK_ERROR(s) if ((status = s) < 0) break -#endif - #define DRXDAP_FASI_SHORT_FORMAT(addr) (((addr) & 0xFC30FF80) == 0) #define DRXDAP_FASI_LONG_FORMAT(addr) (((addr) & 0xFC30FF80) != 0) @@ -519,12 +515,16 @@ int PowerUpDevice(struct drxk_state *state) return -1; do { /* Make sure all clk domains are active */ - CHK_ERROR(Write16_0(state, SIO_CC_PWD_MODE__A, - SIO_CC_PWD_MODE_LEVEL_NONE)); - CHK_ERROR(Write16_0(state, SIO_CC_UPDATE__A, - SIO_CC_UPDATE_KEY)); + status = Write16_0(state, SIO_CC_PWD_MODE__A, SIO_CC_PWD_MODE_LEVEL_NONE); + if (status < 0) + break; + status = Write16_0(state, SIO_CC_UPDATE__A, SIO_CC_UPDATE_KEY); + if (status < 0) + break; /* Enable pll lock tests */ - CHK_ERROR(Write16_0(state, SIO_CC_PLL_LOCK__A, 1)); + status = Write16_0(state, SIO_CC_PLL_LOCK__A, 1); + if (status < 0) + break; state->m_currentPowerMode = DRX_POWER_UP; } while (0); return status; @@ -795,15 +795,25 @@ static int DRXX_Open(struct drxk_state *state) do { /* stop lock indicator process */ - CHK_ERROR(Write16_0(state, SCU_RAM_GPIO__A, - SCU_RAM_GPIO_HW_LOCK_IND_DISABLE)); + status = Write16_0(state, SCU_RAM_GPIO__A, SCU_RAM_GPIO_HW_LOCK_IND_DISABLE); + if (status < 0) + break; /* Check device id */ - CHK_ERROR(Read16(state, SIO_TOP_COMM_KEY__A, &key, 0)); - CHK_ERROR(Write16_0(state, SIO_TOP_COMM_KEY__A, - SIO_TOP_COMM_KEY_KEY)); - CHK_ERROR(Read32(state, SIO_TOP_JTAGID_LO__A, &jtag, 0)); - CHK_ERROR(Read16(state, SIO_PDR_UIO_IN_HI__A, &bid, 0)); - CHK_ERROR(Write16_0(state, SIO_TOP_COMM_KEY__A, key)); + status = Read16(state, SIO_TOP_COMM_KEY__A, &key, 0); + if (status < 0) + break; + status = Write16_0(state, SIO_TOP_COMM_KEY__A, SIO_TOP_COMM_KEY_KEY); + if (status < 0) + break; + status = Read32(state, SIO_TOP_JTAGID_LO__A, &jtag, 0); + if (status < 0) + break; + status = Read16(state, SIO_PDR_UIO_IN_HI__A, &bid, 0); + if (status < 0) + break; + status = Write16_0(state, SIO_TOP_COMM_KEY__A, key); + if (status < 0) + break; } while (0); return status; } @@ -817,13 +827,19 @@ static int GetDeviceCapabilities(struct drxk_state *state) do { /* driver 0.9.0 */ /* stop lock indicator process */ - CHK_ERROR(Write16_0(state, SCU_RAM_GPIO__A, - SCU_RAM_GPIO_HW_LOCK_IND_DISABLE)); + status = Write16_0(state, SCU_RAM_GPIO__A, SCU_RAM_GPIO_HW_LOCK_IND_DISABLE); + if (status < 0) + break; - CHK_ERROR(Write16_0(state, SIO_TOP_COMM_KEY__A, 0xFABA)); - CHK_ERROR(Read16 - (state, SIO_PDR_OHW_CFG__A, &sioPdrOhwCfg, 0)); - CHK_ERROR(Write16_0(state, SIO_TOP_COMM_KEY__A, 0x0000)); + status = Write16_0(state, SIO_TOP_COMM_KEY__A, 0xFABA); + if (status < 0) + break; + status = Read16(state, SIO_PDR_OHW_CFG__A, &sioPdrOhwCfg, 0); + if (status < 0) + break; + status = Write16_0(state, SIO_TOP_COMM_KEY__A, 0x0000); + if (status < 0) + break; switch ((sioPdrOhwCfg & SIO_PDR_OHW_CFG_FREF_SEL__M)) { case 0: @@ -848,8 +864,9 @@ static int GetDeviceCapabilities(struct drxk_state *state) Determine device capabilities Based on pinning v14 */ - CHK_ERROR(Read32(state, SIO_TOP_JTAGID_LO__A, - &sioTopJtagidLo, 0)); + status = Read32(state, SIO_TOP_JTAGID_LO__A, &sioTopJtagidLo, 0); + if (status < 0) + break; /* driver 0.9.0 */ switch ((sioTopJtagidLo >> 29) & 0xF) { case 0: @@ -1024,19 +1041,27 @@ static int HI_CfgCommand(struct drxk_state *state) mutex_lock(&state->mutex); do { - CHK_ERROR(Write16_0(state, SIO_HI_RA_RAM_PAR_6__A, - state->m_HICfgTimeout)); - CHK_ERROR(Write16_0(state, SIO_HI_RA_RAM_PAR_5__A, - state->m_HICfgCtrl)); - CHK_ERROR(Write16_0(state, SIO_HI_RA_RAM_PAR_4__A, - state->m_HICfgWakeUpKey)); - CHK_ERROR(Write16_0(state, SIO_HI_RA_RAM_PAR_3__A, - state->m_HICfgBridgeDelay)); - CHK_ERROR(Write16_0(state, SIO_HI_RA_RAM_PAR_2__A, - state->m_HICfgTimingDiv)); - CHK_ERROR(Write16_0(state, SIO_HI_RA_RAM_PAR_1__A, - SIO_HI_RA_RAM_PAR_1_PAR1_SEC_KEY)); - CHK_ERROR(HI_Command(state, SIO_HI_RA_RAM_CMD_CONFIG, 0)); + status = Write16_0(state, SIO_HI_RA_RAM_PAR_6__A, state->m_HICfgTimeout); + if (status < 0) + break; + status = Write16_0(state, SIO_HI_RA_RAM_PAR_5__A, state->m_HICfgCtrl); + if (status < 0) + break; + status = Write16_0(state, SIO_HI_RA_RAM_PAR_4__A, state->m_HICfgWakeUpKey); + if (status < 0) + break; + status = Write16_0(state, SIO_HI_RA_RAM_PAR_3__A, state->m_HICfgBridgeDelay); + if (status < 0) + break; + status = Write16_0(state, SIO_HI_RA_RAM_PAR_2__A, state->m_HICfgTimingDiv); + if (status < 0) + break; + status = Write16_0(state, SIO_HI_RA_RAM_PAR_1__A, SIO_HI_RA_RAM_PAR_1_PAR1_SEC_KEY); + if (status < 0) + break; + status = HI_Command(state, SIO_HI_RA_RAM_CMD_CONFIG, 0); + if (status < 0) + break; state->m_HICfgCtrl &= ~SIO_HI_RA_RAM_PAR_5_CFG_SLEEP_ZZZ; } while (0); @@ -1061,38 +1086,53 @@ static int MPEGTSConfigurePins(struct drxk_state *state, bool mpegEnable) do { /* stop lock indicator process */ - CHK_ERROR(Write16_0(state, SCU_RAM_GPIO__A, - SCU_RAM_GPIO_HW_LOCK_IND_DISABLE)); + status = Write16_0(state, SCU_RAM_GPIO__A, SCU_RAM_GPIO_HW_LOCK_IND_DISABLE); + if (status < 0) + break; /* MPEG TS pad configuration */ - CHK_ERROR(Write16_0(state, SIO_TOP_COMM_KEY__A, 0xFABA)); + status = Write16_0(state, SIO_TOP_COMM_KEY__A, 0xFABA); + if (status < 0) + break; if (mpegEnable == false) { /* Set MPEG TS pads to inputmode */ - CHK_ERROR(Write16_0(state, - SIO_PDR_MSTRT_CFG__A, 0x0000)); - CHK_ERROR(Write16_0(state, - SIO_PDR_MERR_CFG__A, 0x0000)); - CHK_ERROR(Write16_0(state, - SIO_PDR_MCLK_CFG__A, 0x0000)); - CHK_ERROR(Write16_0(state, - SIO_PDR_MVAL_CFG__A, 0x0000)); - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD0_CFG__A, 0x0000)); - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD1_CFG__A, 0x0000)); - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD2_CFG__A, 0x0000)); - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD3_CFG__A, 0x0000)); - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD4_CFG__A, 0x0000)); - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD5_CFG__A, 0x0000)); - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD6_CFG__A, 0x0000)); - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD7_CFG__A, 0x0000)); + status = Write16_0(state, SIO_PDR_MSTRT_CFG__A, 0x0000); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MERR_CFG__A, 0x0000); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MCLK_CFG__A, 0x0000); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MVAL_CFG__A, 0x0000); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MD0_CFG__A, 0x0000); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MD1_CFG__A, 0x0000); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MD2_CFG__A, 0x0000); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MD3_CFG__A, 0x0000); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MD4_CFG__A, 0x0000); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MD5_CFG__A, 0x0000); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MD6_CFG__A, 0x0000); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MD7_CFG__A, 0x0000); + if (status < 0) + break; } else { /* Enable MPEG output */ sioPdrMdxCfg = @@ -1102,69 +1142,80 @@ static int MPEGTSConfigurePins(struct drxk_state *state, bool mpegEnable) SIO_PDR_MCLK_CFG_DRIVE__B) | 0x0003); - CHK_ERROR(Write16_0(state, SIO_PDR_MSTRT_CFG__A, - sioPdrMdxCfg)); - CHK_ERROR(Write16_0(state, SIO_PDR_MERR_CFG__A, 0x0000)); /* Disable */ - CHK_ERROR(Write16_0(state, SIO_PDR_MVAL_CFG__A, 0x0000)); /* Disable */ + status = Write16_0(state, SIO_PDR_MSTRT_CFG__A, sioPdrMdxCfg); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MERR_CFG__A, 0x0000); /* Disable */ + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MVAL_CFG__A, 0x0000); /* Disable */ + if (status < 0) + break; if (state->m_enableParallel == true) { /* paralel -> enable MD1 to MD7 */ - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD1_CFG__A, - sioPdrMdxCfg)); - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD2_CFG__A, - sioPdrMdxCfg)); - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD3_CFG__A, - sioPdrMdxCfg)); - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD4_CFG__A, - sioPdrMdxCfg)); - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD5_CFG__A, - sioPdrMdxCfg)); - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD6_CFG__A, - sioPdrMdxCfg)); - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD7_CFG__A, - sioPdrMdxCfg)); + status = Write16_0(state, SIO_PDR_MD1_CFG__A, sioPdrMdxCfg); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MD2_CFG__A, sioPdrMdxCfg); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MD3_CFG__A, sioPdrMdxCfg); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MD4_CFG__A, sioPdrMdxCfg); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MD5_CFG__A, sioPdrMdxCfg); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MD6_CFG__A, sioPdrMdxCfg); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MD7_CFG__A, sioPdrMdxCfg); + if (status < 0) + break; } else { sioPdrMdxCfg = ((state->m_TSDataStrength << SIO_PDR_MD0_CFG_DRIVE__B) | 0x0003); /* serial -> disable MD1 to MD7 */ - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD1_CFG__A, - 0x0000)); - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD2_CFG__A, - 0x0000)); - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD3_CFG__A, - 0x0000)); - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD4_CFG__A, - 0x0000)); - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD5_CFG__A, - 0x0000)); - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD6_CFG__A, - 0x0000)); - CHK_ERROR(Write16_0 - (state, SIO_PDR_MD7_CFG__A, - 0x0000)); + status = Write16_0(state, SIO_PDR_MD1_CFG__A, 0x0000); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MD2_CFG__A, 0x0000); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MD3_CFG__A, 0x0000); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MD4_CFG__A, 0x0000); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MD5_CFG__A, 0x0000); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MD6_CFG__A, 0x0000); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MD7_CFG__A, 0x0000); + if (status < 0) + break; } - CHK_ERROR(Write16_0(state, SIO_PDR_MCLK_CFG__A, - sioPdrMclkCfg)); - CHK_ERROR(Write16_0(state, SIO_PDR_MD0_CFG__A, - sioPdrMdxCfg)); + status = Write16_0(state, SIO_PDR_MCLK_CFG__A, sioPdrMclkCfg); + if (status < 0) + break; + status = Write16_0(state, SIO_PDR_MD0_CFG__A, sioPdrMdxCfg); + if (status < 0) + break; } /* Enable MB output over MPEG pads and ctl input */ - CHK_ERROR(Write16_0(state, SIO_PDR_MON_CFG__A, 0x0000)); + status = Write16_0(state, SIO_PDR_MON_CFG__A, 0x0000); + if (status < 0) + break; /* Write nomagic word to enable pdr reg write */ - CHK_ERROR(Write16_0(state, SIO_TOP_COMM_KEY__A, 0x0000)); + status = Write16_0(state, SIO_TOP_COMM_KEY__A, 0x0000); + if (status < 0) + break; } while (0); return status; } @@ -1183,20 +1234,25 @@ static int BLChainCmd(struct drxk_state *state, mutex_lock(&state->mutex); do { - CHK_ERROR(Write16_0(state, SIO_BL_MODE__A, - SIO_BL_MODE_CHAIN)); - CHK_ERROR(Write16_0(state, SIO_BL_CHAIN_ADDR__A, - romOffset)); - CHK_ERROR(Write16_0(state, SIO_BL_CHAIN_LEN__A, - nrOfElements)); - CHK_ERROR(Write16_0(state, SIO_BL_ENABLE__A, - SIO_BL_ENABLE_ON)); + status = Write16_0(state, SIO_BL_MODE__A, SIO_BL_MODE_CHAIN); + if (status < 0) + break; + status = Write16_0(state, SIO_BL_CHAIN_ADDR__A, romOffset); + if (status < 0) + break; + status = Write16_0(state, SIO_BL_CHAIN_LEN__A, nrOfElements); + if (status < 0) + break; + status = Write16_0(state, SIO_BL_ENABLE__A, SIO_BL_ENABLE_ON); + if (status < 0) + break; end = jiffies + msecs_to_jiffies(timeOut); do { msleep(1); - CHK_ERROR(Read16(state, SIO_BL_STATUS__A, - &blStatus, 0)); + status = Read16(state, SIO_BL_STATUS__A, &blStatus, 0); + if (status < 0) + break; } while ((blStatus == 0x1) && ((time_is_after_jiffies(end)))); if (blStatus == 0x1) { @@ -1282,10 +1338,11 @@ static int DVBTEnableOFDMTokenRing(struct drxk_state *state, bool enable) Write16_0(state, SIO_OFDM_SH_OFDM_RING_ENABLE__A, desiredCtrl); end = jiffies + msecs_to_jiffies(DRXK_OFDM_TR_SHUTDOWN_TIMEOUT); - do - CHK_ERROR(Read16_0 - (state, SIO_OFDM_SH_OFDM_RING_STATUS__A, &data)); - while ((data != desiredStatus) && ((time_is_after_jiffies(end)))); + do { + status = Read16_0(state, SIO_OFDM_SH_OFDM_RING_STATUS__A, &data); + if (status < 0) + break; + } while ((data != desiredStatus) && ((time_is_after_jiffies(end)))); if (data != desiredStatus) { printk(KERN_ERR "SIO not ready\n"); return -1; @@ -1301,18 +1358,22 @@ static int MPEGTSStop(struct drxk_state *state) do { /* Gracefull shutdown (byte boundaries) */ - CHK_ERROR(Read16_0 - (state, FEC_OC_SNC_MODE__A, &fecOcSncMode)); + status = Read16_0(state, FEC_OC_SNC_MODE__A, &fecOcSncMode); + if (status < 0) + break; fecOcSncMode |= FEC_OC_SNC_MODE_SHUTDOWN__M; - CHK_ERROR(Write16_0 - (state, FEC_OC_SNC_MODE__A, fecOcSncMode)); + status = Write16_0(state, FEC_OC_SNC_MODE__A, fecOcSncMode); + if (status < 0) + break; /* Suppress MCLK during absence of data */ - CHK_ERROR(Read16_0 - (state, FEC_OC_IPR_MODE__A, &fecOcIprMode)); + status = Read16_0(state, FEC_OC_IPR_MODE__A, &fecOcIprMode); + if (status < 0) + break; fecOcIprMode |= FEC_OC_IPR_MODE_MCLK_DIS_DAT_ABS__M; - CHK_ERROR(Write16_0 - (state, FEC_OC_IPR_MODE__A, fecOcIprMode)); + status = Write16_0(state, FEC_OC_IPR_MODE__A, fecOcIprMode); + if (status < 0) + break; } while (0); return status; } @@ -1352,8 +1413,9 @@ static int scu_command(struct drxk_state *state, end = jiffies + msecs_to_jiffies(DRXK_MAX_WAITTIME); do { msleep(1); - CHK_ERROR(Read16_0 - (state, SCU_RAM_COMMAND__A, &curCmd)); + status = Read16_0(state, SCU_RAM_COMMAND__A, &curCmd); + if (status < 0) + break; } while (!(curCmd == DRX_SCU_READY) && (time_is_after_jiffies(end))); if (curCmd != DRX_SCU_READY) { @@ -1367,9 +1429,9 @@ static int scu_command(struct drxk_state *state, int ii; for (ii = resultLen - 1; ii >= 0; ii -= 1) { - CHK_ERROR(Read16_0(state, - SCU_RAM_PARAM_0__A - ii, - &result[ii])); + status = Read16_0(state, SCU_RAM_PARAM_0__A - ii, &result[ii]); + if (status < 0) + break; } /* Check if an error was reported by SCU */ @@ -1408,7 +1470,9 @@ static int SetIqmAf(struct drxk_state *state, bool active) do { /* Configure IQM */ - CHK_ERROR(Read16_0(state, IQM_AF_STDBY__A, &data)); + status = Read16_0(state, IQM_AF_STDBY__A, &data); + if (status < 0) + break; if (!active) { data |= (IQM_AF_STDBY_STDBY_ADC_STANDBY | IQM_AF_STDBY_STDBY_AMP_STANDBY @@ -1424,7 +1488,9 @@ static int SetIqmAf(struct drxk_state *state, bool active) & (~IQM_AF_STDBY_STDBY_TAGC_RF_STANDBY) ); } - CHK_ERROR(Write16_0(state, IQM_AF_STDBY__A, data)); + status = Write16_0(state, IQM_AF_STDBY__A, data); + if (status < 0) + break; } while (0); return status; } @@ -1467,8 +1533,12 @@ static int CtrlPowerMode(struct drxk_state *state, enum DRXPowerMode *mode) /* For next steps make sure to start from DRX_POWER_UP mode */ if (state->m_currentPowerMode != DRX_POWER_UP) { do { - CHK_ERROR(PowerUpDevice(state)); - CHK_ERROR(DVBTEnableOFDMTokenRing(state, true)); + status = PowerUpDevice(state); + if (status < 0) + break; + status = DVBTEnableOFDMTokenRing(state, true); + if (status < 0) + break; } while (0); } @@ -1487,27 +1557,41 @@ static int CtrlPowerMode(struct drxk_state *state, enum DRXPowerMode *mode) do { switch (state->m_OperationMode) { case OM_DVBT: - CHK_ERROR(MPEGTSStop(state)); - CHK_ERROR(PowerDownDVBT(state, false)); + status = MPEGTSStop(state); + if (status < 0) + break; + status = PowerDownDVBT(state, false); + if (status < 0) + break; break; case OM_QAM_ITU_A: case OM_QAM_ITU_C: - CHK_ERROR(MPEGTSStop(state)); - CHK_ERROR(PowerDownQAM(state)); + status = MPEGTSStop(state); + if (status < 0) + break; + status = PowerDownQAM(state); + if (status < 0) + break; break; default: break; } - CHK_ERROR(DVBTEnableOFDMTokenRing(state, false)); - CHK_ERROR(Write16_0(state, SIO_CC_PWD_MODE__A, - sioCcPwdMode)); - CHK_ERROR(Write16_0(state, SIO_CC_UPDATE__A, - SIO_CC_UPDATE_KEY)); + status = DVBTEnableOFDMTokenRing(state, false); + if (status < 0) + break; + status = Write16_0(state, SIO_CC_PWD_MODE__A, sioCcPwdMode); + if (status < 0) + break; + status = Write16_0(state, SIO_CC_UPDATE__A, SIO_CC_UPDATE_KEY); + if (status < 0) + break; if (*mode != DRXK_POWER_DOWN_OFDM) { state->m_HICfgCtrl |= SIO_HI_RA_RAM_PAR_5_CFG_SLEEP_ZZZ; - CHK_ERROR(HI_CfgCommand(state)); + status = HI_CfgCommand(state); + if (status < 0) + break; } } while (0); } @@ -1523,36 +1607,41 @@ static int PowerDownDVBT(struct drxk_state *state, bool setPowerMode) int status; do { - CHK_ERROR(Read16_0(state, SCU_COMM_EXEC__A, &data)); + status = Read16_0(state, SCU_COMM_EXEC__A, &data); + if (status < 0) + break; if (data == SCU_COMM_EXEC_ACTIVE) { /* Send OFDM stop command */ - CHK_ERROR(scu_command(state, - SCU_RAM_COMMAND_STANDARD_OFDM - | - SCU_RAM_COMMAND_CMD_DEMOD_STOP, - 0, NULL, 1, &cmdResult)); + status = scu_command(state, SCU_RAM_COMMAND_STANDARD_OFDM | SCU_RAM_COMMAND_CMD_DEMOD_STOP, 0, NULL, 1, &cmdResult); + if (status < 0) + break; /* Send OFDM reset command */ - CHK_ERROR(scu_command(state, - SCU_RAM_COMMAND_STANDARD_OFDM - | - SCU_RAM_COMMAND_CMD_DEMOD_RESET, - 0, NULL, 1, &cmdResult)); + status = scu_command(state, SCU_RAM_COMMAND_STANDARD_OFDM | SCU_RAM_COMMAND_CMD_DEMOD_RESET, 0, NULL, 1, &cmdResult); + if (status < 0) + break; } /* Reset datapath for OFDM, processors first */ - CHK_ERROR(Write16_0(state, OFDM_SC_COMM_EXEC__A, - OFDM_SC_COMM_EXEC_STOP)); - CHK_ERROR(Write16_0(state, OFDM_LC_COMM_EXEC__A, - OFDM_LC_COMM_EXEC_STOP)); - CHK_ERROR(Write16_0(state, IQM_COMM_EXEC__A, - IQM_COMM_EXEC_B_STOP)); + status = Write16_0(state, OFDM_SC_COMM_EXEC__A, OFDM_SC_COMM_EXEC_STOP); + if (status < 0) + break; + status = Write16_0(state, OFDM_LC_COMM_EXEC__A, OFDM_LC_COMM_EXEC_STOP); + if (status < 0) + break; + status = Write16_0(state, IQM_COMM_EXEC__A, IQM_COMM_EXEC_B_STOP); + if (status < 0) + break; /* powerdown AFE */ - CHK_ERROR(SetIqmAf(state, false)); + status = SetIqmAf(state, false); + if (status < 0) + break; /* powerdown to OFDM mode */ if (setPowerMode) { - CHK_ERROR(CtrlPowerMode(state, &powerMode)); + status = CtrlPowerMode(state, &powerMode); + if (status < 0) + break; } } while (0); return status; @@ -1570,8 +1659,9 @@ static int SetOperationMode(struct drxk_state *state, */ do { /* disable HW lock indicator */ - CHK_ERROR(Write16_0(state, SCU_RAM_GPIO__A, - SCU_RAM_GPIO_HW_LOCK_IND_DISABLE)); + status = Write16_0(state, SCU_RAM_GPIO__A, SCU_RAM_GPIO_HW_LOCK_IND_DISABLE); + if (status < 0) + break; if (state->m_OperationMode != oMode) { switch (state->m_OperationMode) { @@ -1579,8 +1669,12 @@ static int SetOperationMode(struct drxk_state *state, case OM_NONE: break; case OM_DVBT: - CHK_ERROR(MPEGTSStop(state)); - CHK_ERROR(PowerDownDVBT(state, true)); + status = MPEGTSStop(state); + if (status < 0) + break; + status = PowerDownDVBT(state, true); + if (status < 0) + break; state->m_OperationMode = OM_NONE; break; case OM_QAM_ITU_B: @@ -1588,14 +1682,20 @@ static int SetOperationMode(struct drxk_state *state, break; case OM_QAM_ITU_A: /* fallthrough */ case OM_QAM_ITU_C: - CHK_ERROR(MPEGTSStop(state)); - CHK_ERROR(PowerDownQAM(state)); + status = MPEGTSStop(state); + if (status < 0) + break; + status = PowerDownQAM(state); + if (status < 0) + break; state->m_OperationMode = OM_NONE; break; default: status = -1; } - CHK_ERROR(status); + status = status; + if (status < 0) + break; /* Power up new standard @@ -1603,7 +1703,9 @@ static int SetOperationMode(struct drxk_state *state, switch (oMode) { case OM_DVBT: state->m_OperationMode = oMode; - CHK_ERROR(SetDVBTStandard(state, oMode)); + status = SetDVBTStandard(state, oMode); + if (status < 0) + break; break; case OM_QAM_ITU_B: status = -1; @@ -1611,13 +1713,17 @@ static int SetOperationMode(struct drxk_state *state, case OM_QAM_ITU_A: /* fallthrough */ case OM_QAM_ITU_C: state->m_OperationMode = oMode; - CHK_ERROR(SetQAMStandard(state, oMode)); + status = SetQAMStandard(state, oMode); + if (status < 0) + break; break; default: status = -1; } } - CHK_ERROR(status); + status = status; + if (status < 0) + break; } while (0); return 0; } @@ -1649,14 +1755,22 @@ static int Start(struct drxk_state *state, s32 offsetFreq, case OM_QAM_ITU_A: case OM_QAM_ITU_C: IFreqkHz = (IntermediateFrequency / 1000); - CHK_ERROR(SetQAM(state, IFreqkHz, OffsetkHz)); + status = SetQAM(state, IFreqkHz, OffsetkHz); + if (status < 0) + break; state->m_DrxkState = DRXK_DTV_STARTED; break; case OM_DVBT: IFreqkHz = (IntermediateFrequency / 1000); - CHK_ERROR(MPEGTSStop(state)); - CHK_ERROR(SetDVBT(state, IFreqkHz, OffsetkHz)); - CHK_ERROR(DVBTStart(state)); + status = MPEGTSStop(state); + if (status < 0) + break; + status = SetDVBT(state, IFreqkHz, OffsetkHz); + if (status < 0) + break; + status = DVBTStart(state); + if (status < 0) + break; state->m_DrxkState = DRXK_DTV_STARTED; break; default: @@ -1706,12 +1820,16 @@ static int MPEGTSStart(struct drxk_state *state) do { /* Allow OC to sync again */ - CHK_ERROR(Read16_0 - (state, FEC_OC_SNC_MODE__A, &fecOcSncMode)); + status = Read16_0(state, FEC_OC_SNC_MODE__A, &fecOcSncMode); + if (status < 0) + break; fecOcSncMode &= ~FEC_OC_SNC_MODE_SHUTDOWN__M; - CHK_ERROR(Write16_0 - (state, FEC_OC_SNC_MODE__A, fecOcSncMode)); - CHK_ERROR(Write16_0(state, FEC_OC_SNC_UNLOCK__A, 1)); + status = Write16_0(state, FEC_OC_SNC_MODE__A, fecOcSncMode); + if (status < 0) + break; + status = Write16_0(state, FEC_OC_SNC_UNLOCK__A, 1); + if (status < 0) + break; } while (0); return status; } @@ -1722,23 +1840,41 @@ static int MPEGTSDtoInit(struct drxk_state *state) do { /* Rate integration settings */ - CHK_ERROR(Write16_0 - (state, FEC_OC_RCN_CTL_STEP_LO__A, 0x0000)); - CHK_ERROR(Write16_0 - (state, FEC_OC_RCN_CTL_STEP_HI__A, 0x000C)); - CHK_ERROR(Write16_0(state, FEC_OC_RCN_GAIN__A, 0x000A)); - CHK_ERROR(Write16_0(state, FEC_OC_AVR_PARM_A__A, 0x0008)); - CHK_ERROR(Write16_0(state, FEC_OC_AVR_PARM_B__A, 0x0006)); - CHK_ERROR(Write16_0 - (state, FEC_OC_TMD_HI_MARGIN__A, 0x0680)); - CHK_ERROR(Write16_0 - (state, FEC_OC_TMD_LO_MARGIN__A, 0x0080)); - CHK_ERROR(Write16_0(state, FEC_OC_TMD_COUNT__A, 0x03F4)); + status = Write16_0(state, FEC_OC_RCN_CTL_STEP_LO__A, 0x0000); + if (status < 0) + break; + status = Write16_0(state, FEC_OC_RCN_CTL_STEP_HI__A, 0x000C); + if (status < 0) + break; + status = Write16_0(state, FEC_OC_RCN_GAIN__A, 0x000A); + if (status < 0) + break; + status = Write16_0(state, FEC_OC_AVR_PARM_A__A, 0x0008); + if (status < 0) + break; + status = Write16_0(state, FEC_OC_AVR_PARM_B__A, 0x0006); + if (status < 0) + break; + status = Write16_0(state, FEC_OC_TMD_HI_MARGIN__A, 0x0680); + if (status < 0) + break; + status = Write16_0(state, FEC_OC_TMD_LO_MARGIN__A, 0x0080); + if (status < 0) + break; + status = Write16_0(state, FEC_OC_TMD_COUNT__A, 0x03F4); + if (status < 0) + break; /* Additional configuration */ - CHK_ERROR(Write16_0(state, FEC_OC_OCR_INVERT__A, 0)); - CHK_ERROR(Write16_0(state, FEC_OC_SNC_LWM__A, 2)); - CHK_ERROR(Write16_0(state, FEC_OC_SNC_HWM__A, 12)); + status = Write16_0(state, FEC_OC_OCR_INVERT__A, 0); + if (status < 0) + break; + status = Write16_0(state, FEC_OC_SNC_LWM__A, 2); + if (status < 0) + break; + status = Write16_0(state, FEC_OC_SNC_HWM__A, 12); + if (status < 0) + break; } while (0); return status; } @@ -1762,9 +1898,12 @@ static int MPEGTSDtoSetup(struct drxk_state *state, do { /* Check insertion of the Reed-Solomon parity bytes */ - CHK_ERROR(Read16_0(state, FEC_OC_MODE__A, &fecOcRegMode)); - CHK_ERROR(Read16_0(state, FEC_OC_IPR_MODE__A, - &fecOcRegIprMode)); + status = Read16_0(state, FEC_OC_MODE__A, &fecOcRegMode); + if (status < 0) + break; + status = Read16_0(state, FEC_OC_IPR_MODE__A, &fecOcRegIprMode); + if (status < 0) + break; fecOcRegMode &= (~FEC_OC_MODE_PARITY__M); fecOcRegIprMode &= (~FEC_OC_IPR_MODE_MVAL_DIS_PAR__M); if (state->m_insertRSByte == true) { @@ -1800,7 +1939,9 @@ static int MPEGTSDtoSetup(struct drxk_state *state, default: status = -1; } /* switch (standard) */ - CHK_ERROR(status); + status = status; + if (status < 0) + break; /* Configure DTO's */ if (staticCLK) { @@ -1841,25 +1982,35 @@ static int MPEGTSDtoSetup(struct drxk_state *state, } /* Write appropriate registers with requested configuration */ - CHK_ERROR(Write16_0(state, FEC_OC_DTO_BURST_LEN__A, - fecOcDtoBurstLen)); - CHK_ERROR(Write16_0(state, FEC_OC_DTO_PERIOD__A, - fecOcDtoPeriod)); - CHK_ERROR(Write16_0(state, FEC_OC_DTO_MODE__A, - fecOcDtoMode)); - CHK_ERROR(Write16_0(state, FEC_OC_FCT_MODE__A, - fecOcFctMode)); - CHK_ERROR(Write16_0(state, FEC_OC_MODE__A, fecOcRegMode)); - CHK_ERROR(Write16_0(state, FEC_OC_IPR_MODE__A, - fecOcRegIprMode)); + status = Write16_0(state, FEC_OC_DTO_BURST_LEN__A, fecOcDtoBurstLen); + if (status < 0) + break; + status = Write16_0(state, FEC_OC_DTO_PERIOD__A, fecOcDtoPeriod); + if (status < 0) + break; + status = Write16_0(state, FEC_OC_DTO_MODE__A, fecOcDtoMode); + if (status < 0) + break; + status = Write16_0(state, FEC_OC_FCT_MODE__A, fecOcFctMode); + if (status < 0) + break; + status = Write16_0(state, FEC_OC_MODE__A, fecOcRegMode); + if (status < 0) + break; + status = Write16_0(state, FEC_OC_IPR_MODE__A, fecOcRegIprMode); + if (status < 0) + break; /* Rate integration settings */ - CHK_ERROR(Write32(state, FEC_OC_RCN_CTL_RATE_LO__A, - fecOcRcnCtlRate, 0)); - CHK_ERROR(Write16_0(state, FEC_OC_TMD_INT_UPD_RATE__A, - fecOcTmdIntUpdRate)); - CHK_ERROR(Write16_0(state, FEC_OC_TMD_MODE__A, - fecOcTmdMode)); + status = Write32(state, FEC_OC_RCN_CTL_RATE_LO__A, fecOcRcnCtlRate, 0); + if (status < 0) + break; + status = Write16_0(state, FEC_OC_TMD_INT_UPD_RATE__A, fecOcTmdIntUpdRate); + if (status < 0) + break; + status = Write16_0(state, FEC_OC_TMD_MODE__A, fecOcTmdMode); + if (status < 0) + break; } while (0); return status; } @@ -1914,12 +2065,17 @@ static int SetAgcRf(struct drxk_state *state, case DRXK_AGC_CTRL_AUTO: /* Enable RF AGC DAC */ - CHK_ERROR(Read16_0(state, IQM_AF_STDBY__A, &data)); + status = Read16_0(state, IQM_AF_STDBY__A, &data); + if (status < 0) + break; data &= ~IQM_AF_STDBY_STDBY_TAGC_RF_STANDBY; - CHK_ERROR(Write16_0(state, IQM_AF_STDBY__A, data)); + status = Write16_0(state, IQM_AF_STDBY__A, data); + if (status < 0) + break; - CHK_ERROR(Read16(state, SCU_RAM_AGC_CONFIG__A, - &data, 0)); + status = Read16(state, SCU_RAM_AGC_CONFIG__A, &data, 0); + if (status < 0) + break; /* Enable SCU RF AGC loop */ data &= ~SCU_RAM_AGC_CONFIG_DISABLE_RF_AGC__M; @@ -1929,20 +2085,23 @@ static int SetAgcRf(struct drxk_state *state, data |= SCU_RAM_AGC_CONFIG_INV_RF_POL__M; else data &= ~SCU_RAM_AGC_CONFIG_INV_RF_POL__M; - CHK_ERROR(Write16_0(state, - SCU_RAM_AGC_CONFIG__A, data)); + status = Write16_0(state, SCU_RAM_AGC_CONFIG__A, data); + if (status < 0) + break; /* Set speed (using complementary reduction value) */ - CHK_ERROR(Read16(state, SCU_RAM_AGC_KI_RED__A, - &data, 0)); + status = Read16(state, SCU_RAM_AGC_KI_RED__A, &data, 0); + if (status < 0) + break; data &= ~SCU_RAM_AGC_KI_RED_RAGC_RED__M; data |= (~(pAgcCfg->speed << SCU_RAM_AGC_KI_RED_RAGC_RED__B) & SCU_RAM_AGC_KI_RED_RAGC_RED__M); - CHK_ERROR(Write16_0(state, - SCU_RAM_AGC_KI_RED__A, data)); + status = Write16_0(state, SCU_RAM_AGC_KI_RED__A, data); + if (status < 0) + break; if (IsDVBT(state)) pIfAgcSettings = &state->m_dvbtIfAgcCfg; @@ -1955,61 +2114,74 @@ static int SetAgcRf(struct drxk_state *state, /* Set TOP, only if IF-AGC is in AUTO mode */ if (pIfAgcSettings->ctrlMode == DRXK_AGC_CTRL_AUTO) - CHK_ERROR(Write16_0(state, - SCU_RAM_AGC_IF_IACCU_HI_TGT_MAX__A, - pAgcCfg->top)); + status = Write16_0(state, SCU_RAM_AGC_IF_IACCU_HI_TGT_MAX__A, pAgcCfg->top); + if (status < 0) + break; /* Cut-Off current */ - CHK_ERROR(Write16_0(state, - SCU_RAM_AGC_RF_IACCU_HI_CO__A, - pAgcCfg->cutOffCurrent)); + status = Write16_0(state, SCU_RAM_AGC_RF_IACCU_HI_CO__A, pAgcCfg->cutOffCurrent); + if (status < 0) + break; /* Max. output level */ - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_RF_MAX__A, - pAgcCfg->maxOutputLevel)); + status = Write16_0(state, SCU_RAM_AGC_RF_MAX__A, pAgcCfg->maxOutputLevel); + if (status < 0) + break; break; case DRXK_AGC_CTRL_USER: /* Enable RF AGC DAC */ - CHK_ERROR(Read16_0(state, IQM_AF_STDBY__A, &data)); + status = Read16_0(state, IQM_AF_STDBY__A, &data); + if (status < 0) + break; data &= ~IQM_AF_STDBY_STDBY_TAGC_RF_STANDBY; - CHK_ERROR(Write16_0(state, IQM_AF_STDBY__A, data)); + status = Write16_0(state, IQM_AF_STDBY__A, data); + if (status < 0) + break; /* Disable SCU RF AGC loop */ - CHK_ERROR(Read16_0(state, - SCU_RAM_AGC_CONFIG__A, &data)); + status = Read16_0(state, SCU_RAM_AGC_CONFIG__A, &data); + if (status < 0) + break; data |= SCU_RAM_AGC_CONFIG_DISABLE_RF_AGC__M; if (state->m_RfAgcPol) data |= SCU_RAM_AGC_CONFIG_INV_RF_POL__M; else data &= ~SCU_RAM_AGC_CONFIG_INV_RF_POL__M; - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_CONFIG__A, - data)); + status = Write16_0(state, SCU_RAM_AGC_CONFIG__A, data); + if (status < 0) + break; /* SCU c.o.c. to 0, enabling full control range */ - CHK_ERROR(Write16_0 - (state, SCU_RAM_AGC_RF_IACCU_HI_CO__A, - 0)); + status = Write16_0(state, SCU_RAM_AGC_RF_IACCU_HI_CO__A, 0); + if (status < 0) + break; /* Write value to output pin */ - CHK_ERROR(Write16_0 - (state, SCU_RAM_AGC_RF_IACCU_HI__A, - pAgcCfg->outputLevel)); + status = Write16_0(state, SCU_RAM_AGC_RF_IACCU_HI__A, pAgcCfg->outputLevel); + if (status < 0) + break; break; case DRXK_AGC_CTRL_OFF: /* Disable RF AGC DAC */ - CHK_ERROR(Read16_0(state, IQM_AF_STDBY__A, &data)); + status = Read16_0(state, IQM_AF_STDBY__A, &data); + if (status < 0) + break; data |= IQM_AF_STDBY_STDBY_TAGC_RF_STANDBY; - CHK_ERROR(Write16_0(state, IQM_AF_STDBY__A, data)); + status = Write16_0(state, IQM_AF_STDBY__A, data); + if (status < 0) + break; /* Disable SCU RF AGC loop */ - CHK_ERROR(Read16_0(state, - SCU_RAM_AGC_CONFIG__A, &data)); + status = Read16_0(state, SCU_RAM_AGC_CONFIG__A, &data); + if (status < 0) + break; data |= SCU_RAM_AGC_CONFIG_DISABLE_RF_AGC__M; - CHK_ERROR(Write16_0(state, - SCU_RAM_AGC_CONFIG__A, data)); + status = Write16_0(state, SCU_RAM_AGC_CONFIG__A, data); + if (status < 0) + break; break; default: @@ -2034,12 +2206,17 @@ static int SetAgcIf(struct drxk_state *state, case DRXK_AGC_CTRL_AUTO: /* Enable IF AGC DAC */ - CHK_ERROR(Read16_0(state, IQM_AF_STDBY__A, &data)); + status = Read16_0(state, IQM_AF_STDBY__A, &data); + if (status < 0) + break; data &= ~IQM_AF_STDBY_STDBY_TAGC_IF_STANDBY; - CHK_ERROR(Write16_0(state, IQM_AF_STDBY__A, data)); + status = Write16_0(state, IQM_AF_STDBY__A, data); + if (status < 0) + break; - CHK_ERROR(Read16_0(state, SCU_RAM_AGC_CONFIG__A, - &data)); + status = Read16_0(state, SCU_RAM_AGC_CONFIG__A, &data); + if (status < 0) + break; /* Enable SCU IF AGC loop */ data &= ~SCU_RAM_AGC_CONFIG_DISABLE_IF_AGC__M; @@ -2049,19 +2226,22 @@ static int SetAgcIf(struct drxk_state *state, data |= SCU_RAM_AGC_CONFIG_INV_IF_POL__M; else data &= ~SCU_RAM_AGC_CONFIG_INV_IF_POL__M; - CHK_ERROR(Write16_0(state, - SCU_RAM_AGC_CONFIG__A, data)); + status = Write16_0(state, SCU_RAM_AGC_CONFIG__A, data); + if (status < 0) + break; /* Set speed (using complementary reduction value) */ - CHK_ERROR(Read16_0(state, SCU_RAM_AGC_KI_RED__A, - &data)); + status = Read16_0(state, SCU_RAM_AGC_KI_RED__A, &data); + if (status < 0) + break; data &= ~SCU_RAM_AGC_KI_RED_IAGC_RED__M; data |= (~(pAgcCfg->speed << SCU_RAM_AGC_KI_RED_IAGC_RED__B) & SCU_RAM_AGC_KI_RED_IAGC_RED__M); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_KI_RED__A, - data)); + status = Write16_0(state, SCU_RAM_AGC_KI_RED__A, data); + if (status < 0) + break; if (IsQAM(state)) pRfAgcSettings = &state->m_qamRfAgcCfg; @@ -2070,20 +2250,25 @@ static int SetAgcIf(struct drxk_state *state, if (pRfAgcSettings == NULL) return -1; /* Restore TOP */ - CHK_ERROR(Write16_0(state, - SCU_RAM_AGC_IF_IACCU_HI_TGT_MAX__A, - pRfAgcSettings->top)); + status = Write16_0(state, SCU_RAM_AGC_IF_IACCU_HI_TGT_MAX__A, pRfAgcSettings->top); + if (status < 0) + break; break; case DRXK_AGC_CTRL_USER: /* Enable IF AGC DAC */ - CHK_ERROR(Read16_0(state, IQM_AF_STDBY__A, &data)); + status = Read16_0(state, IQM_AF_STDBY__A, &data); + if (status < 0) + break; data &= ~IQM_AF_STDBY_STDBY_TAGC_IF_STANDBY; - CHK_ERROR(Write16_0(state, IQM_AF_STDBY__A, data)); + status = Write16_0(state, IQM_AF_STDBY__A, data); + if (status < 0) + break; - CHK_ERROR(Read16_0(state, - SCU_RAM_AGC_CONFIG__A, &data)); + status = Read16_0(state, SCU_RAM_AGC_CONFIG__A, &data); + if (status < 0) + break; /* Disable SCU IF AGC loop */ data |= SCU_RAM_AGC_CONFIG_DISABLE_IF_AGC__M; @@ -2093,35 +2278,43 @@ static int SetAgcIf(struct drxk_state *state, data |= SCU_RAM_AGC_CONFIG_INV_IF_POL__M; else data &= ~SCU_RAM_AGC_CONFIG_INV_IF_POL__M; - CHK_ERROR(Write16_0(state, - SCU_RAM_AGC_CONFIG__A, data)); + status = Write16_0(state, SCU_RAM_AGC_CONFIG__A, data); + if (status < 0) + break; /* Write value to output pin */ - CHK_ERROR(Write16_0(state, - SCU_RAM_AGC_IF_IACCU_HI_TGT_MAX__A, - pAgcCfg->outputLevel)); + status = Write16_0(state, SCU_RAM_AGC_IF_IACCU_HI_TGT_MAX__A, pAgcCfg->outputLevel); + if (status < 0) + break; break; case DRXK_AGC_CTRL_OFF: /* Disable If AGC DAC */ - CHK_ERROR(Read16_0(state, IQM_AF_STDBY__A, &data)); + status = Read16_0(state, IQM_AF_STDBY__A, &data); + if (status < 0) + break; data |= IQM_AF_STDBY_STDBY_TAGC_IF_STANDBY; - CHK_ERROR(Write16_0(state, IQM_AF_STDBY__A, data)); + status = Write16_0(state, IQM_AF_STDBY__A, data); + if (status < 0) + break; /* Disable SCU IF AGC loop */ - CHK_ERROR(Read16_0(state, - SCU_RAM_AGC_CONFIG__A, &data)); + status = Read16_0(state, SCU_RAM_AGC_CONFIG__A, &data); + if (status < 0) + break; data |= SCU_RAM_AGC_CONFIG_DISABLE_IF_AGC__M; - CHK_ERROR(Write16_0(state, - SCU_RAM_AGC_CONFIG__A, data)); + status = Write16_0(state, SCU_RAM_AGC_CONFIG__A, data); + if (status < 0) + break; break; } /* switch (agcSettingsIf->ctrlMode) */ /* always set the top to support configurations without if-loop */ - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_INGAIN_TGT_MIN__A, - pAgcCfg->top)); + status = Write16_0(state, SCU_RAM_AGC_INGAIN_TGT_MIN__A, pAgcCfg->top); + if (status < 0) + break; } while (0); @@ -2161,8 +2354,9 @@ static int GetQAMSignalToNoise(struct drxk_state *state, u32 qamSlMer = 0; /* QAM MER */ /* get the register value needed for MER */ - CHK_ERROR(Read16_0 - (state, QAM_SL_ERR_POWER__A, &qamSlErrPower)); + status = Read16_0(state, QAM_SL_ERR_POWER__A, &qamSlErrPower); + if (status < 0) + break; switch (state->param.u.qam.modulation) { case QAM_16: @@ -2212,30 +2406,36 @@ static int GetDVBTSignalToNoise(struct drxk_state *state, u16 transmissionParams = 0; do { - CHK_ERROR(Read16_0(state, OFDM_EQ_TOP_TD_TPS_PWR_OFS__A, - &EqRegTdTpsPwrOfs)); - CHK_ERROR(Read16_0(state, OFDM_EQ_TOP_TD_REQ_SMB_CNT__A, - &EqRegTdReqSmbCnt)); - CHK_ERROR(Read16_0(state, OFDM_EQ_TOP_TD_SQR_ERR_EXP__A, - &EqRegTdSqrErrExp)); - CHK_ERROR(Read16_0(state, OFDM_EQ_TOP_TD_SQR_ERR_I__A, - ®Data)); + status = Read16_0(state, OFDM_EQ_TOP_TD_TPS_PWR_OFS__A, &EqRegTdTpsPwrOfs); + if (status < 0) + break; + status = Read16_0(state, OFDM_EQ_TOP_TD_REQ_SMB_CNT__A, &EqRegTdReqSmbCnt); + if (status < 0) + break; + status = Read16_0(state, OFDM_EQ_TOP_TD_SQR_ERR_EXP__A, &EqRegTdSqrErrExp); + if (status < 0) + break; + status = Read16_0(state, OFDM_EQ_TOP_TD_SQR_ERR_I__A, ®Data); + if (status < 0) + break; /* Extend SQR_ERR_I operational range */ EqRegTdSqrErrI = (u32) regData; if ((EqRegTdSqrErrExp > 11) && (EqRegTdSqrErrI < 0x00000FFFUL)) { EqRegTdSqrErrI += 0x00010000UL; } - CHK_ERROR(Read16_0(state, OFDM_EQ_TOP_TD_SQR_ERR_Q__A, - ®Data)); + status = Read16_0(state, OFDM_EQ_TOP_TD_SQR_ERR_Q__A, ®Data); + if (status < 0) + break; /* Extend SQR_ERR_Q operational range */ EqRegTdSqrErrQ = (u32) regData; if ((EqRegTdSqrErrExp > 11) && (EqRegTdSqrErrQ < 0x00000FFFUL)) EqRegTdSqrErrQ += 0x00010000UL; - CHK_ERROR(Read16_0(state, OFDM_SC_RA_RAM_OP_PARAM__A, - &transmissionParams)); + status = Read16_0(state, OFDM_SC_RA_RAM_OP_PARAM__A, &transmissionParams); + if (status < 0) + break; /* Check input data for MER */ @@ -2336,13 +2536,17 @@ static int GetDVBTQuality(struct drxk_state *state, s32 *pQuality) u32 SignalToNoiseRel; u32 BERQuality; - CHK_ERROR(GetDVBTSignalToNoise(state, &SignalToNoise)); - CHK_ERROR(Read16_0(state, OFDM_EQ_TOP_TD_TPS_CONST__A, - &Constellation)); + status = GetDVBTSignalToNoise(state, &SignalToNoise); + if (status < 0) + break; + status = Read16_0(state, OFDM_EQ_TOP_TD_TPS_CONST__A, &Constellation); + if (status < 0) + break; Constellation &= OFDM_EQ_TOP_TD_TPS_CONST__M; - CHK_ERROR(Read16_0(state, OFDM_EQ_TOP_TD_TPS_CODE_HP__A, - &CodeRate)); + status = Read16_0(state, OFDM_EQ_TOP_TD_TPS_CODE_HP__A, &CodeRate); + if (status < 0) + break; CodeRate &= OFDM_EQ_TOP_TD_TPS_CODE_HP__M; if (Constellation > OFDM_EQ_TOP_TD_TPS_CONST_64QAM || @@ -2373,7 +2577,9 @@ static int GetDVBCQuality(struct drxk_state *state, s32 *pQuality) u32 BERQuality = 100; u32 SignalToNoiseRel = 0; - CHK_ERROR(GetQAMSignalToNoise(state, &SignalToNoise)); + status = GetQAMSignalToNoise(state, &SignalToNoise); + if (status < 0) + break; switch (state->param.u.qam.modulation) { case QAM_16: @@ -2444,17 +2650,22 @@ static int ConfigureI2CBridge(struct drxk_state *state, bool bEnableBridge) return -1; do { - CHK_ERROR(Write16_0(state, SIO_HI_RA_RAM_PAR_1__A, - SIO_HI_RA_RAM_PAR_1_PAR1_SEC_KEY)); + status = Write16_0(state, SIO_HI_RA_RAM_PAR_1__A, SIO_HI_RA_RAM_PAR_1_PAR1_SEC_KEY); + if (status < 0) + break; if (bEnableBridge) { - CHK_ERROR(Write16_0(state, SIO_HI_RA_RAM_PAR_2__A, - SIO_HI_RA_RAM_PAR_2_BRD_CFG_CLOSED)); + status = Write16_0(state, SIO_HI_RA_RAM_PAR_2__A, SIO_HI_RA_RAM_PAR_2_BRD_CFG_CLOSED); + if (status < 0) + break; } else { - CHK_ERROR(Write16_0(state, SIO_HI_RA_RAM_PAR_2__A, - SIO_HI_RA_RAM_PAR_2_BRD_CFG_OPEN)); + status = Write16_0(state, SIO_HI_RA_RAM_PAR_2__A, SIO_HI_RA_RAM_PAR_2_BRD_CFG_OPEN); + if (status < 0) + break; } - CHK_ERROR(HI_Command(state, SIO_HI_RA_RAM_CMD_BRDCTRL, 0)); + status = HI_Command(state, SIO_HI_RA_RAM_CMD_BRDCTRL, 0); + if (status < 0) + break; } while (0); return status; } @@ -2483,20 +2694,30 @@ static int BLDirectCmd(struct drxk_state *state, u32 targetAddr, mutex_lock(&state->mutex); do { - CHK_ERROR(Write16_0 - (state, SIO_BL_MODE__A, SIO_BL_MODE_DIRECT)); - CHK_ERROR(Write16_0(state, SIO_BL_TGT_HDR__A, blockbank)); - CHK_ERROR(Write16_0(state, SIO_BL_TGT_ADDR__A, offset)); - CHK_ERROR(Write16_0(state, SIO_BL_SRC_ADDR__A, romOffset)); - CHK_ERROR(Write16_0 - (state, SIO_BL_SRC_LEN__A, nrOfElements)); - CHK_ERROR(Write16_0 - (state, SIO_BL_ENABLE__A, SIO_BL_ENABLE_ON)); + status = Write16_0(state, SIO_BL_MODE__A, SIO_BL_MODE_DIRECT); + if (status < 0) + break; + status = Write16_0(state, SIO_BL_TGT_HDR__A, blockbank); + if (status < 0) + break; + status = Write16_0(state, SIO_BL_TGT_ADDR__A, offset); + if (status < 0) + break; + status = Write16_0(state, SIO_BL_SRC_ADDR__A, romOffset); + if (status < 0) + break; + status = Write16_0(state, SIO_BL_SRC_LEN__A, nrOfElements); + if (status < 0) + break; + status = Write16_0(state, SIO_BL_ENABLE__A, SIO_BL_ENABLE_ON); + if (status < 0) + break; end = jiffies + msecs_to_jiffies(timeOut); do { - CHK_ERROR(Read16_0 - (state, SIO_BL_STATUS__A, &blStatus)); + status = Read16_0(state, SIO_BL_STATUS__A, &blStatus); + if (status < 0) + break; } while ((blStatus == 0x1) && time_is_after_jiffies(end)); if (blStatus == 0x1) { printk(KERN_ERR "SIO not ready\n"); @@ -2516,18 +2737,27 @@ static int ADCSyncMeasurement(struct drxk_state *state, u16 *count) do { /* Start measurement */ - CHK_ERROR(Write16_0(state, IQM_AF_COMM_EXEC__A, - IQM_AF_COMM_EXEC_ACTIVE)); - CHK_ERROR(Write16_0(state, IQM_AF_START_LOCK__A, 1)); + status = Write16_0(state, IQM_AF_COMM_EXEC__A, IQM_AF_COMM_EXEC_ACTIVE); + if (status < 0) + break; + status = Write16_0(state, IQM_AF_START_LOCK__A, 1); + if (status < 0) + break; *count = 0; - CHK_ERROR(Read16_0(state, IQM_AF_PHASE0__A, &data)); + status = Read16_0(state, IQM_AF_PHASE0__A, &data); + if (status < 0) + break; if (data == 127) *count = *count + 1; - CHK_ERROR(Read16_0(state, IQM_AF_PHASE1__A, &data)); + status = Read16_0(state, IQM_AF_PHASE1__A, &data); + if (status < 0) + break; if (data == 127) *count = *count + 1; - CHK_ERROR(Read16_0(state, IQM_AF_PHASE2__A, &data)); + status = Read16_0(state, IQM_AF_PHASE2__A, &data); + if (status < 0) + break; if (data == 127) *count = *count + 1; } while (0); @@ -2540,14 +2770,17 @@ static int ADCSynchronization(struct drxk_state *state) int status; do { - CHK_ERROR(ADCSyncMeasurement(state, &count)); + status = ADCSyncMeasurement(state, &count); + if (status < 0) + break; if (count == 1) { /* Try sampling on a diffrent edge */ u16 clkNeg = 0; - CHK_ERROR(Read16_0 - (state, IQM_AF_CLKNEG__A, &clkNeg)); + status = Read16_0(state, IQM_AF_CLKNEG__A, &clkNeg); + if (status < 0) + break; if ((clkNeg | IQM_AF_CLKNEG_CLKNEGDATA__M) == IQM_AF_CLKNEG_CLKNEGDATA_CLK_ADC_DATA_POS) { clkNeg &= (~(IQM_AF_CLKNEG_CLKNEGDATA__M)); @@ -2558,9 +2791,12 @@ static int ADCSynchronization(struct drxk_state *state) clkNeg |= IQM_AF_CLKNEG_CLKNEGDATA_CLK_ADC_DATA_POS; } - CHK_ERROR(Write16_0 - (state, IQM_AF_CLKNEG__A, clkNeg)); - CHK_ERROR(ADCSyncMeasurement(state, &count)); + status = Write16_0(state, IQM_AF_CLKNEG__A, clkNeg); + if (status < 0) + break; + status = ADCSyncMeasurement(state, &count); + if (status < 0) + break; } if (count < 2) @@ -2669,7 +2905,9 @@ static int InitAGC(struct drxk_state *state, bool isDTV) kiInnergainMin = (u16) -1030; } else status = -1; - CHK_ERROR((status)); + status = (status); + if (status < 0) + break; if (IsQAM(state)) { ifIaccuHiTgtMax = 0x2380; ifIaccuHiTgt = 0x2380; @@ -2687,77 +2925,129 @@ static int InitAGC(struct drxk_state *state, bool isDTV) fastClpCtrlDelay = state->m_dvbtIfAgcCfg.FastClipCtrlDelay; } - CHK_ERROR(Write16_0 - (state, SCU_RAM_AGC_FAST_CLP_CTRL_DELAY__A, - fastClpCtrlDelay)); - - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_CLP_CTRL_MODE__A, - clpCtrlMode)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_INGAIN_TGT__A, - ingainTgt)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_INGAIN_TGT_MIN__A, - ingainTgtMin)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_INGAIN_TGT_MAX__A, - ingainTgtMax)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_AGC_IF_IACCU_HI_TGT_MIN__A, - ifIaccuHiTgtMin)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_AGC_IF_IACCU_HI_TGT_MAX__A, - ifIaccuHiTgtMax)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_IF_IACCU_HI__A, 0)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_IF_IACCU_LO__A, 0)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_RF_IACCU_HI__A, 0)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_RF_IACCU_LO__A, 0)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_CLP_SUM_MAX__A, - clpSumMax)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_SNS_SUM_MAX__A, - snsSumMax)); - - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_KI_INNERGAIN_MIN__A, - kiInnergainMin)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_IF_IACCU_HI_TGT__A, - ifIaccuHiTgt)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_CLP_CYCLEN__A, - clpCyclen)); - - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_RF_SNS_DEV_MAX__A, - 1023)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_RF_SNS_DEV_MIN__A, - (u16) -1023)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_AGC_FAST_SNS_CTRL_DELAY__A, 50)); - - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_KI_MAXMINGAIN_TH__A, - 20)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_CLP_SUM_MIN__A, - clpSumMin)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_SNS_SUM_MIN__A, - snsSumMin)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_CLP_DIR_TO__A, - clpDirTo)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_SNS_DIR_TO__A, - snsDirTo)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_AGC_KI_MINGAIN__A, 0x7fff)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_AGC_KI_MAXGAIN__A, 0x0)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_KI_MIN__A, 0x0117)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_KI_MAX__A, 0x0657)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_CLP_SUM__A, 0)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_CLP_CYCCNT__A, 0)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_CLP_DIR_WD__A, 0)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_CLP_DIR_STP__A, 1)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_SNS_SUM__A, 0)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_SNS_CYCCNT__A, 0)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_SNS_DIR_WD__A, 0)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_SNS_DIR_STP__A, 1)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_AGC_SNS_CYCLEN__A, 500)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_KI_CYCLEN__A, 500)); + status = Write16_0(state, SCU_RAM_AGC_FAST_CLP_CTRL_DELAY__A, fastClpCtrlDelay); + if (status < 0) + break; + + status = Write16_0(state, SCU_RAM_AGC_CLP_CTRL_MODE__A, clpCtrlMode); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_INGAIN_TGT__A, ingainTgt); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_INGAIN_TGT_MIN__A, ingainTgtMin); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_INGAIN_TGT_MAX__A, ingainTgtMax); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_IF_IACCU_HI_TGT_MIN__A, ifIaccuHiTgtMin); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_IF_IACCU_HI_TGT_MAX__A, ifIaccuHiTgtMax); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_IF_IACCU_HI__A, 0); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_IF_IACCU_LO__A, 0); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_RF_IACCU_HI__A, 0); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_RF_IACCU_LO__A, 0); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_CLP_SUM_MAX__A, clpSumMax); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_SNS_SUM_MAX__A, snsSumMax); + if (status < 0) + break; + + status = Write16_0(state, SCU_RAM_AGC_KI_INNERGAIN_MIN__A, kiInnergainMin); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_IF_IACCU_HI_TGT__A, ifIaccuHiTgt); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_CLP_CYCLEN__A, clpCyclen); + if (status < 0) + break; + + status = Write16_0(state, SCU_RAM_AGC_RF_SNS_DEV_MAX__A, 1023); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_RF_SNS_DEV_MIN__A, (u16) -1023); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_FAST_SNS_CTRL_DELAY__A, 50); + if (status < 0) + break; + + status = Write16_0(state, SCU_RAM_AGC_KI_MAXMINGAIN_TH__A, 20); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_CLP_SUM_MIN__A, clpSumMin); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_SNS_SUM_MIN__A, snsSumMin); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_CLP_DIR_TO__A, clpDirTo); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_SNS_DIR_TO__A, snsDirTo); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_KI_MINGAIN__A, 0x7fff); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_KI_MAXGAIN__A, 0x0); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_KI_MIN__A, 0x0117); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_KI_MAX__A, 0x0657); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_CLP_SUM__A, 0); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_CLP_CYCCNT__A, 0); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_CLP_DIR_WD__A, 0); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_CLP_DIR_STP__A, 1); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_SNS_SUM__A, 0); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_SNS_CYCCNT__A, 0); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_SNS_DIR_WD__A, 0); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_SNS_DIR_STP__A, 1); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_SNS_CYCLEN__A, 500); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_KI_CYCLEN__A, 500); + if (status < 0) + break; /* Initialize inner-loop KI gain factors */ - CHK_ERROR(Read16_0(state, SCU_RAM_AGC_KI__A, &data)); + status = Read16_0(state, SCU_RAM_AGC_KI__A, &data); + if (status < 0) + break; if (IsQAM(state)) { data = 0x0657; data &= ~SCU_RAM_AGC_KI_RF__M; @@ -2765,7 +3055,9 @@ static int InitAGC(struct drxk_state *state, bool isDTV) data &= ~SCU_RAM_AGC_KI_IF__M; data |= (DRXK_KI_IAGC_QAM << SCU_RAM_AGC_KI_IF__B); } - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_KI__A, data)); + status = Write16_0(state, SCU_RAM_AGC_KI__A, data); + if (status < 0) + break; } while (0); return status; } @@ -2776,13 +3068,13 @@ static int DVBTQAMGetAccPktErr(struct drxk_state *state, u16 *packetErr) do { if (packetErr == NULL) { - CHK_ERROR(Write16_0(state, - SCU_RAM_FEC_ACCUM_PKT_FAILURES__A, - 0)); + status = Write16_0(state, SCU_RAM_FEC_ACCUM_PKT_FAILURES__A, 0); + if (status < 0) + break; } else { - CHK_ERROR(Read16_0(state, - SCU_RAM_FEC_ACCUM_PKT_FAILURES__A, - packetErr)); + status = Read16_0(state, SCU_RAM_FEC_ACCUM_PKT_FAILURES__A, packetErr); + if (status < 0) + break; } } while (0); return status; @@ -2905,7 +3197,9 @@ static int PowerUpDVBT(struct drxk_state *state) int status; do { - CHK_ERROR(CtrlPowerMode(state, &powerMode)); + status = CtrlPowerMode(state, &powerMode); + if (status < 0) + break; } while (0); return status; } @@ -2947,8 +3241,9 @@ static int DVBTCtrlSetEchoThreshold(struct drxk_state *state, int status; do { - CHK_ERROR(Read16_0 - (state, OFDM_SC_RA_RAM_ECHO_THRES__A, &data)); + status = Read16_0(state, OFDM_SC_RA_RAM_ECHO_THRES__A, &data); + if (status < 0) + break; switch (echoThres->fftMode) { case DRX_FFTMODE_2K: @@ -2970,8 +3265,9 @@ static int DVBTCtrlSetEchoThreshold(struct drxk_state *state, break; } - CHK_ERROR(Write16_0 - (state, OFDM_SC_RA_RAM_ECHO_THRES__A, data)); + status = Write16_0(state, OFDM_SC_RA_RAM_ECHO_THRES__A, data); + if (status < 0) + break; } while (0); return status; @@ -3015,12 +3311,21 @@ static int DVBTActivatePresets(struct drxk_state *state) do { bool setincenable = false; bool setfrenable = true; - CHK_ERROR(DVBTCtrlSetIncEnable(state, &setincenable)); - CHK_ERROR(DVBTCtrlSetFrEnable(state, &setfrenable)); - CHK_ERROR(DVBTCtrlSetEchoThreshold(state, &echoThres2k)); - CHK_ERROR(DVBTCtrlSetEchoThreshold(state, &echoThres8k)); - CHK_ERROR(Write16_0(state, SCU_RAM_AGC_INGAIN_TGT_MAX__A, - state->m_dvbtIfAgcCfg.IngainTgtMax)); + status = DVBTCtrlSetIncEnable(state, &setincenable); + if (status < 0) + break; + status = DVBTCtrlSetFrEnable(state, &setfrenable); + if (status < 0) + break; + status = DVBTCtrlSetEchoThreshold(state, &echoThres2k); + if (status < 0) + break; + status = DVBTCtrlSetEchoThreshold(state, &echoThres8k); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_AGC_INGAIN_TGT_MAX__A, state->m_dvbtIfAgcCfg.IngainTgtMax); + if (status < 0) + break; } while (0); return status; @@ -3049,128 +3354,182 @@ static int SetDVBTStandard(struct drxk_state *state, /* added antenna switch */ SwitchAntennaToDVBT(state); /* send OFDM reset command */ - CHK_ERROR(scu_command - (state, - SCU_RAM_COMMAND_STANDARD_OFDM | - SCU_RAM_COMMAND_CMD_DEMOD_RESET, 0, NULL, 1, - &cmdResult)); + status = scu_command(state, SCU_RAM_COMMAND_STANDARD_OFDM | SCU_RAM_COMMAND_CMD_DEMOD_RESET, 0, NULL, 1, &cmdResult); + if (status < 0) + break; /* send OFDM setenv command */ - CHK_ERROR(scu_command - (state, - SCU_RAM_COMMAND_STANDARD_OFDM | - SCU_RAM_COMMAND_CMD_DEMOD_SET_ENV, 0, NULL, 1, - &cmdResult)); + status = scu_command(state, SCU_RAM_COMMAND_STANDARD_OFDM | SCU_RAM_COMMAND_CMD_DEMOD_SET_ENV, 0, NULL, 1, &cmdResult); + if (status < 0) + break; /* reset datapath for OFDM, processors first */ - CHK_ERROR(Write16_0 - (state, OFDM_SC_COMM_EXEC__A, - OFDM_SC_COMM_EXEC_STOP)); - CHK_ERROR(Write16_0 - (state, OFDM_LC_COMM_EXEC__A, - OFDM_LC_COMM_EXEC_STOP)); - CHK_ERROR(Write16_0 - (state, IQM_COMM_EXEC__A, IQM_COMM_EXEC_B_STOP)); + status = Write16_0(state, OFDM_SC_COMM_EXEC__A, OFDM_SC_COMM_EXEC_STOP); + if (status < 0) + break; + status = Write16_0(state, OFDM_LC_COMM_EXEC__A, OFDM_LC_COMM_EXEC_STOP); + if (status < 0) + break; + status = Write16_0(state, IQM_COMM_EXEC__A, IQM_COMM_EXEC_B_STOP); + if (status < 0) + break; /* IQM setup */ /* synchronize on ofdstate->m_festart */ - CHK_ERROR(Write16_0(state, IQM_AF_UPD_SEL__A, 1)); + status = Write16_0(state, IQM_AF_UPD_SEL__A, 1); + if (status < 0) + break; /* window size for clipping ADC detection */ - CHK_ERROR(Write16_0(state, IQM_AF_CLP_LEN__A, 0)); + status = Write16_0(state, IQM_AF_CLP_LEN__A, 0); + if (status < 0) + break; /* window size for for sense pre-SAW detection */ - CHK_ERROR(Write16_0(state, IQM_AF_SNS_LEN__A, 0)); + status = Write16_0(state, IQM_AF_SNS_LEN__A, 0); + if (status < 0) + break; /* sense threshold for sense pre-SAW detection */ - CHK_ERROR(Write16_0 - (state, IQM_AF_AMUX__A, IQM_AF_AMUX_SIGNAL2ADC)); - CHK_ERROR(SetIqmAf(state, true)); + status = Write16_0(state, IQM_AF_AMUX__A, IQM_AF_AMUX_SIGNAL2ADC); + if (status < 0) + break; + status = SetIqmAf(state, true); + if (status < 0) + break; - CHK_ERROR(Write16_0(state, IQM_AF_AGC_RF__A, 0)); + status = Write16_0(state, IQM_AF_AGC_RF__A, 0); + if (status < 0) + break; /* Impulse noise cruncher setup */ - CHK_ERROR(Write16_0(state, IQM_AF_INC_LCT__A, 0)); /* crunch in IQM_CF */ - CHK_ERROR(Write16_0(state, IQM_CF_DET_LCT__A, 0)); /* detect in IQM_CF */ - CHK_ERROR(Write16_0(state, IQM_CF_WND_LEN__A, 3)); /* peak detector window length */ + status = Write16_0(state, IQM_AF_INC_LCT__A, 0); /* crunch in IQM_CF */ + if (status < 0) + break; + status = Write16_0(state, IQM_CF_DET_LCT__A, 0); /* detect in IQM_CF */ + if (status < 0) + break; + status = Write16_0(state, IQM_CF_WND_LEN__A, 3); /* peak detector window length */ + if (status < 0) + break; - CHK_ERROR(Write16_0(state, IQM_RC_STRETCH__A, 16)); - CHK_ERROR(Write16_0(state, IQM_CF_OUT_ENA__A, 0x4)); /* enable output 2 */ - CHK_ERROR(Write16_0(state, IQM_CF_DS_ENA__A, 0x4)); /* decimate output 2 */ - CHK_ERROR(Write16_0(state, IQM_CF_SCALE__A, 1600)); - CHK_ERROR(Write16_0(state, IQM_CF_SCALE_SH__A, 0)); + status = Write16_0(state, IQM_RC_STRETCH__A, 16); + if (status < 0) + break; + status = Write16_0(state, IQM_CF_OUT_ENA__A, 0x4); /* enable output 2 */ + if (status < 0) + break; + status = Write16_0(state, IQM_CF_DS_ENA__A, 0x4); /* decimate output 2 */ + if (status < 0) + break; + status = Write16_0(state, IQM_CF_SCALE__A, 1600); + if (status < 0) + break; + status = Write16_0(state, IQM_CF_SCALE_SH__A, 0); + if (status < 0) + break; /* virtual clipping threshold for clipping ADC detection */ - CHK_ERROR(Write16_0(state, IQM_AF_CLP_TH__A, 448)); - CHK_ERROR(Write16_0(state, IQM_CF_DATATH__A, 495)); /* crunching threshold */ + status = Write16_0(state, IQM_AF_CLP_TH__A, 448); + if (status < 0) + break; + status = Write16_0(state, IQM_CF_DATATH__A, 495); /* crunching threshold */ + if (status < 0) + break; - CHK_ERROR(BLChainCmd(state, - DRXK_BL_ROM_OFFSET_TAPS_DVBT, - DRXK_BLCC_NR_ELEMENTS_TAPS, - DRXK_BLC_TIMEOUT)); + status = BLChainCmd(state, DRXK_BL_ROM_OFFSET_TAPS_DVBT, DRXK_BLCC_NR_ELEMENTS_TAPS, DRXK_BLC_TIMEOUT); + if (status < 0) + break; - CHK_ERROR(Write16_0(state, IQM_CF_PKDTH__A, 2)); /* peak detector threshold */ - CHK_ERROR(Write16_0(state, IQM_CF_POW_MEAS_LEN__A, 2)); + status = Write16_0(state, IQM_CF_PKDTH__A, 2); /* peak detector threshold */ + if (status < 0) + break; + status = Write16_0(state, IQM_CF_POW_MEAS_LEN__A, 2); + if (status < 0) + break; /* enable power measurement interrupt */ - CHK_ERROR(Write16_0(state, IQM_CF_COMM_INT_MSK__A, 1)); - CHK_ERROR(Write16_0 - (state, IQM_COMM_EXEC__A, - IQM_COMM_EXEC_B_ACTIVE)); + status = Write16_0(state, IQM_CF_COMM_INT_MSK__A, 1); + if (status < 0) + break; + status = Write16_0(state, IQM_COMM_EXEC__A, IQM_COMM_EXEC_B_ACTIVE); + if (status < 0) + break; /* IQM will not be reset from here, sync ADC and update/init AGC */ - CHK_ERROR(ADCSynchronization(state)); - CHK_ERROR(SetPreSaw(state, &state->m_dvbtPreSawCfg)); + status = ADCSynchronization(state); + if (status < 0) + break; + status = SetPreSaw(state, &state->m_dvbtPreSawCfg); + if (status < 0) + break; /* Halt SCU to enable safe non-atomic accesses */ - CHK_ERROR(Write16_0 - (state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_HOLD)); + status = Write16_0(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_HOLD); + if (status < 0) + break; - CHK_ERROR(SetAgcRf(state, &state->m_dvbtRfAgcCfg, true)); - CHK_ERROR(SetAgcIf(state, &state->m_dvbtIfAgcCfg, true)); + status = SetAgcRf(state, &state->m_dvbtRfAgcCfg, true); + if (status < 0) + break; + status = SetAgcIf(state, &state->m_dvbtIfAgcCfg, true); + if (status < 0) + break; /* Set Noise Estimation notch width and enable DC fix */ - CHK_ERROR(Read16_0 - (state, OFDM_SC_RA_RAM_CONFIG__A, &data)); + status = Read16_0(state, OFDM_SC_RA_RAM_CONFIG__A, &data); + if (status < 0) + break; data |= OFDM_SC_RA_RAM_CONFIG_NE_FIX_ENABLE__M; - CHK_ERROR(Write16_0 - (state, OFDM_SC_RA_RAM_CONFIG__A, data)); + status = Write16_0(state, OFDM_SC_RA_RAM_CONFIG__A, data); + if (status < 0) + break; /* Activate SCU to enable SCU commands */ - CHK_ERROR(Write16_0 - (state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE)); + status = Write16_0(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE); + if (status < 0) + break; if (!state->m_DRXK_A3_ROM_CODE) { /* AGCInit() is not done for DVBT, so set agcFastClipCtrlDelay */ - CHK_ERROR(Write16_0 - (state, - SCU_RAM_AGC_FAST_CLP_CTRL_DELAY__A, - state-> - m_dvbtIfAgcCfg.FastClipCtrlDelay)); + status = Write16_0(state, SCU_RAM_AGC_FAST_CLP_CTRL_DELAY__A, state->m_dvbtIfAgcCfg.FastClipCtrlDelay); + if (status < 0) + break; } /* OFDM_SC setup */ #ifdef COMPILE_FOR_NONRT - CHK_ERROR(Write16_0 - (state, OFDM_SC_RA_RAM_BE_OPT_DELAY__A, 1)); - CHK_ERROR(Write16_0 - (state, OFDM_SC_RA_RAM_BE_OPT_INIT_DELAY__A, 2)); + status = Write16_0(state, OFDM_SC_RA_RAM_BE_OPT_DELAY__A, 1); + if (status < 0) + break; + status = Write16_0(state, OFDM_SC_RA_RAM_BE_OPT_INIT_DELAY__A, 2); + if (status < 0) + break; #endif /* FEC setup */ - CHK_ERROR(Write16_0(state, FEC_DI_INPUT_CTL__A, 1)); /* OFDM input */ + status = Write16_0(state, FEC_DI_INPUT_CTL__A, 1); /* OFDM input */ + if (status < 0) + break; #ifdef COMPILE_FOR_NONRT - CHK_ERROR(Write16_0 - (state, FEC_RS_MEASUREMENT_PERIOD__A, 0x400)); + status = Write16_0(state, FEC_RS_MEASUREMENT_PERIOD__A, 0x400); + if (status < 0) + break; #else - CHK_ERROR(Write16_0 - (state, FEC_RS_MEASUREMENT_PERIOD__A, 0x1000)); + status = Write16_0(state, FEC_RS_MEASUREMENT_PERIOD__A, 0x1000); + if (status < 0) + break; #endif - CHK_ERROR(Write16_0 - (state, FEC_RS_MEASUREMENT_PRESCALE__A, 0x0001)); + status = Write16_0(state, FEC_RS_MEASUREMENT_PRESCALE__A, 0x0001); + if (status < 0) + break; /* Setup MPEG bus */ - CHK_ERROR(MPEGTSDtoSetup(state, OM_DVBT)); + status = MPEGTSDtoSetup(state, OM_DVBT); + if (status < 0) + break; /* Set DVBT Presets */ - CHK_ERROR(DVBTActivatePresets(state)); + status = DVBTActivatePresets(state); + if (status < 0) + break; } while (0); @@ -3196,14 +3555,16 @@ static int DVBTStart(struct drxk_state *state) /* DRXK: OFDM_SC_RA_RAM_PROC_LOCKTRACK is no longer in mapfile! */ do { param1 = OFDM_SC_RA_RAM_LOCKTRACK_MIN; - CHK_ERROR(DVBTScCommand - (state, OFDM_SC_RA_RAM_CMD_PROC_START, 0, - OFDM_SC_RA_RAM_SW_EVENT_RUN_NMASK__M, param1, 0, - 0, 0)); + status = DVBTScCommand(state, OFDM_SC_RA_RAM_CMD_PROC_START, 0, OFDM_SC_RA_RAM_SW_EVENT_RUN_NMASK__M, param1, 0, 0, 0); + if (status < 0) + break; /* Start FEC OC */ - CHK_ERROR(MPEGTSStart(state)); - CHK_ERROR(Write16_0 - (state, FEC_COMM_EXEC__A, FEC_COMM_EXEC_ACTIVE)); + status = MPEGTSStart(state); + if (status < 0) + break; + status = Write16_0(state, FEC_COMM_EXEC__A, FEC_COMM_EXEC_ACTIVE); + if (status < 0) + break; } while (0); return status; } @@ -3230,29 +3591,28 @@ static int SetDVBT(struct drxk_state *state, u16 IntermediateFreqkHz, /* printk(KERN_DEBUG "%s IF =%d, TFO = %d\n", __func__, IntermediateFreqkHz, tunerFreqOffset); */ do { - CHK_ERROR(scu_command - (state, - SCU_RAM_COMMAND_STANDARD_OFDM | - SCU_RAM_COMMAND_CMD_DEMOD_STOP, 0, NULL, 1, - &cmdResult)); + status = scu_command(state, SCU_RAM_COMMAND_STANDARD_OFDM | SCU_RAM_COMMAND_CMD_DEMOD_STOP, 0, NULL, 1, &cmdResult); + if (status < 0) + break; /* Halt SCU to enable safe non-atomic accesses */ - CHK_ERROR(Write16_0 - (state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_HOLD)); + status = Write16_0(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_HOLD); + if (status < 0) + break; /* Stop processors */ - CHK_ERROR(Write16_0 - (state, OFDM_SC_COMM_EXEC__A, - OFDM_SC_COMM_EXEC_STOP)); - CHK_ERROR(Write16_0 - (state, OFDM_LC_COMM_EXEC__A, - OFDM_LC_COMM_EXEC_STOP)); + status = Write16_0(state, OFDM_SC_COMM_EXEC__A, OFDM_SC_COMM_EXEC_STOP); + if (status < 0) + break; + status = Write16_0(state, OFDM_LC_COMM_EXEC__A, OFDM_LC_COMM_EXEC_STOP); + if (status < 0) + break; /* Mandatory fix, always stop CP, required to set spl offset back to hardware default (is set to 0 by ucode during pilot detection */ - CHK_ERROR(Write16_0 - (state, OFDM_CP_COMM_EXEC__A, - OFDM_CP_COMM_EXEC_STOP)); + status = Write16_0(state, OFDM_CP_COMM_EXEC__A, OFDM_CP_COMM_EXEC_STOP); + if (status < 0) + break; /*== Write channel settings to device =====================================*/ @@ -3363,9 +3723,9 @@ static int SetDVBT(struct drxk_state *state, u16 IntermediateFreqkHz, #else /* Set Priorty high */ transmissionParams |= OFDM_SC_RA_RAM_OP_PARAM_PRIO_HI; - CHK_ERROR(Write16_0 - (state, OFDM_EC_SB_PRIOR__A, - OFDM_EC_SB_PRIOR_HI)); + status = Write16_0(state, OFDM_EC_SB_PRIOR__A, OFDM_EC_SB_PRIOR_HI); + if (status < 0) + break; #endif /* coderate */ @@ -3407,75 +3767,60 @@ static int SetDVBT(struct drxk_state *state, u16 IntermediateFreqkHz, case BANDWIDTH_AUTO: case BANDWIDTH_8_MHZ: bandwidth = DRXK_BANDWIDTH_8MHZ_IN_HZ; - CHK_ERROR(Write16_0 - (state, - OFDM_SC_RA_RAM_SRMM_FIX_FACT_8K__A, - 3052)); + status = Write16_0(state, OFDM_SC_RA_RAM_SRMM_FIX_FACT_8K__A, 3052); + if (status < 0) + break; /* cochannel protection for PAL 8 MHz */ - CHK_ERROR(Write16_0 - (state, - OFDM_SC_RA_RAM_NI_INIT_8K_PER_LEFT__A, - 7)); - CHK_ERROR(Write16_0 - (state, - OFDM_SC_RA_RAM_NI_INIT_8K_PER_RIGHT__A, - 7)); - CHK_ERROR(Write16_0 - (state, - OFDM_SC_RA_RAM_NI_INIT_2K_PER_LEFT__A, - 7)); - CHK_ERROR(Write16_0 - (state, - OFDM_SC_RA_RAM_NI_INIT_2K_PER_RIGHT__A, - 1)); + status = Write16_0(state, OFDM_SC_RA_RAM_NI_INIT_8K_PER_LEFT__A, 7); + if (status < 0) + break; + status = Write16_0(state, OFDM_SC_RA_RAM_NI_INIT_8K_PER_RIGHT__A, 7); + if (status < 0) + break; + status = Write16_0(state, OFDM_SC_RA_RAM_NI_INIT_2K_PER_LEFT__A, 7); + if (status < 0) + break; + status = Write16_0(state, OFDM_SC_RA_RAM_NI_INIT_2K_PER_RIGHT__A, 1); + if (status < 0) + break; break; case BANDWIDTH_7_MHZ: bandwidth = DRXK_BANDWIDTH_7MHZ_IN_HZ; - CHK_ERROR(Write16_0 - (state, - OFDM_SC_RA_RAM_SRMM_FIX_FACT_8K__A, - 3491)); + status = Write16_0(state, OFDM_SC_RA_RAM_SRMM_FIX_FACT_8K__A, 3491); + if (status < 0) + break; /* cochannel protection for PAL 7 MHz */ - CHK_ERROR(Write16_0 - (state, - OFDM_SC_RA_RAM_NI_INIT_8K_PER_LEFT__A, - 8)); - CHK_ERROR(Write16_0 - (state, - OFDM_SC_RA_RAM_NI_INIT_8K_PER_RIGHT__A, - 8)); - CHK_ERROR(Write16_0 - (state, - OFDM_SC_RA_RAM_NI_INIT_2K_PER_LEFT__A, - 4)); - CHK_ERROR(Write16_0 - (state, - OFDM_SC_RA_RAM_NI_INIT_2K_PER_RIGHT__A, - 1)); + status = Write16_0(state, OFDM_SC_RA_RAM_NI_INIT_8K_PER_LEFT__A, 8); + if (status < 0) + break; + status = Write16_0(state, OFDM_SC_RA_RAM_NI_INIT_8K_PER_RIGHT__A, 8); + if (status < 0) + break; + status = Write16_0(state, OFDM_SC_RA_RAM_NI_INIT_2K_PER_LEFT__A, 4); + if (status < 0) + break; + status = Write16_0(state, OFDM_SC_RA_RAM_NI_INIT_2K_PER_RIGHT__A, 1); + if (status < 0) + break; break; case BANDWIDTH_6_MHZ: bandwidth = DRXK_BANDWIDTH_6MHZ_IN_HZ; - CHK_ERROR(Write16_0 - (state, - OFDM_SC_RA_RAM_SRMM_FIX_FACT_8K__A, - 4073)); + status = Write16_0(state, OFDM_SC_RA_RAM_SRMM_FIX_FACT_8K__A, 4073); + if (status < 0) + break; /* cochannel protection for NTSC 6 MHz */ - CHK_ERROR(Write16_0 - (state, - OFDM_SC_RA_RAM_NI_INIT_8K_PER_LEFT__A, - 19)); - CHK_ERROR(Write16_0 - (state, - OFDM_SC_RA_RAM_NI_INIT_8K_PER_RIGHT__A, - 19)); - CHK_ERROR(Write16_0 - (state, - OFDM_SC_RA_RAM_NI_INIT_2K_PER_LEFT__A, - 14)); - CHK_ERROR(Write16_0 - (state, - OFDM_SC_RA_RAM_NI_INIT_2K_PER_RIGHT__A, - 1)); + status = Write16_0(state, OFDM_SC_RA_RAM_NI_INIT_8K_PER_LEFT__A, 19); + if (status < 0) + break; + status = Write16_0(state, OFDM_SC_RA_RAM_NI_INIT_8K_PER_RIGHT__A, 19); + if (status < 0) + break; + status = Write16_0(state, OFDM_SC_RA_RAM_NI_INIT_2K_PER_LEFT__A, 14); + if (status < 0) + break; + status = Write16_0(state, OFDM_SC_RA_RAM_NI_INIT_2K_PER_RIGHT__A, 1); + if (status < 0) + break; break; } @@ -3503,32 +3848,40 @@ static int SetDVBT(struct drxk_state *state, u16 IntermediateFreqkHz, iqmRcRateOfs &= ((((u32) IQM_RC_RATE_OFS_HI__M) << IQM_RC_RATE_OFS_LO__W) | IQM_RC_RATE_OFS_LO__M); - CHK_ERROR(Write32 - (state, IQM_RC_RATE_OFS_LO__A, iqmRcRateOfs, 0)); + status = Write32(state, IQM_RC_RATE_OFS_LO__A, iqmRcRateOfs, 0); + if (status < 0) + break; /* Bandwidth setting done */ - /* CHK_ERROR(DVBTSetFrequencyShift(demod, channel, tunerOffset)); */ - CHK_ERROR(SetFrequencyShifter - (state, IntermediateFreqkHz, tunerFreqOffset, - true)); +#if 0 + status = DVBTSetFrequencyShift(demod, channel, tunerOffset); + if (status < 0) + break; +#endif + status = SetFrequencyShifter(state, IntermediateFreqkHz, tunerFreqOffset, true); + if (status < 0) + break; /*== Start SC, write channel settings to SC ===============================*/ /* Activate SCU to enable SCU commands */ - CHK_ERROR(Write16_0 - (state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE)); + status = Write16_0(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE); + if (status < 0) + break; /* Enable SC after setting all other parameters */ - CHK_ERROR(Write16_0(state, OFDM_SC_COMM_STATE__A, 0)); - CHK_ERROR(Write16_0(state, OFDM_SC_COMM_EXEC__A, 1)); + status = Write16_0(state, OFDM_SC_COMM_STATE__A, 0); + if (status < 0) + break; + status = Write16_0(state, OFDM_SC_COMM_EXEC__A, 1); + if (status < 0) + break; - CHK_ERROR(scu_command - (state, - SCU_RAM_COMMAND_STANDARD_OFDM | - SCU_RAM_COMMAND_CMD_DEMOD_START, 0, NULL, 1, - &cmdResult)); + status = scu_command(state, SCU_RAM_COMMAND_STANDARD_OFDM | SCU_RAM_COMMAND_CMD_DEMOD_START, 0, NULL, 1, &cmdResult); + if (status < 0) + break; /* Write SC parameter registers, set all AUTO flags in operation mode */ param1 = (OFDM_SC_RA_RAM_OP_AUTO_MODE__M | @@ -3540,8 +3893,9 @@ static int SetDVBT(struct drxk_state *state, u16 IntermediateFreqkHz, DVBTScCommand(state, OFDM_SC_RA_RAM_CMD_SET_PREF_PARAM, 0, transmissionParams, param1, 0, 0, 0); if (!state->m_DRXK_A3_ROM_CODE) - CHK_ERROR(DVBTCtrlSetSqiSpeed - (state, &state->m_sqiSpeed)); + status = DVBTCtrlSetSqiSpeed(state, &state->m_sqiSpeed); + if (status < 0) + break; } while (0); @@ -3600,7 +3954,9 @@ static int PowerUpQAM(struct drxk_state *state) int status = 0; do { - CHK_ERROR(CtrlPowerMode(state, &powerMode)); + status = CtrlPowerMode(state, &powerMode); + if (status < 0) + break; } while (0); @@ -3616,24 +3972,26 @@ static int PowerDownQAM(struct drxk_state *state) int status = 0; do { - CHK_ERROR(Read16_0(state, SCU_COMM_EXEC__A, &data)); + status = Read16_0(state, SCU_COMM_EXEC__A, &data); + if (status < 0) + break; if (data == SCU_COMM_EXEC_ACTIVE) { /* STOP demodulator QAM and HW blocks */ /* stop all comstate->m_exec */ - CHK_ERROR(Write16_0 - (state, QAM_COMM_EXEC__A, - QAM_COMM_EXEC_STOP)); - CHK_ERROR(scu_command - (state, - SCU_RAM_COMMAND_STANDARD_QAM | - SCU_RAM_COMMAND_CMD_DEMOD_STOP, 0, NULL, - 1, &cmdResult)); + status = Write16_0(state, QAM_COMM_EXEC__A, QAM_COMM_EXEC_STOP); + if (status < 0) + break; + status = scu_command(state, SCU_RAM_COMMAND_STANDARD_QAM | SCU_RAM_COMMAND_CMD_DEMOD_STOP, 0, NULL, 1, &cmdResult); + if (status < 0) + break; } /* powerdown AFE */ - CHK_ERROR(SetIqmAf(state, false)); + status = SetIqmAf(state, false); + if (status < 0) + break; } while (0); return status; @@ -3691,7 +4049,9 @@ static int SetQAMMeasurement(struct drxk_state *state, default: status = -EINVAL; } - CHK_ERROR(status); + status = status; + if (status < 0) + break; fecBitsDesired /= 1000; /* symbolRate [Hz] -> symbolRate [kHz] */ fecBitsDesired *= 500; /* meas. period [ms] */ @@ -3706,20 +4066,23 @@ static int SetQAMMeasurement(struct drxk_state *state, /* Divide by zero (though impossible) */ status = -1; } - CHK_ERROR(status); + status = status; + if (status < 0) + break; fecRsPeriod = ((u16) fecRsPeriodTotal + (fecRsPrescale >> 1)) / fecRsPrescale; /* write corresponding registers */ - CHK_ERROR(Write16_0 - (state, FEC_RS_MEASUREMENT_PERIOD__A, - fecRsPeriod)); - CHK_ERROR(Write16_0 - (state, FEC_RS_MEASUREMENT_PRESCALE__A, - fecRsPrescale)); - CHK_ERROR(Write16_0 - (state, FEC_OC_SNC_FAIL_PERIOD__A, fecRsPeriod)); + status = Write16_0(state, FEC_RS_MEASUREMENT_PERIOD__A, fecRsPeriod); + if (status < 0) + break; + status = Write16_0(state, FEC_RS_MEASUREMENT_PRESCALE__A, fecRsPrescale); + if (status < 0) + break; + status = Write16_0(state, FEC_OC_SNC_FAIL_PERIOD__A, fecRsPeriod); + if (status < 0) + break; } while (0); @@ -3736,112 +4099,178 @@ static int SetQAM16(struct drxk_state *state) do { /* QAM Equalizer Setup */ /* Equalizer */ - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD0__A, 13517)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD1__A, 13517)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD2__A, 13517)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD3__A, 13517)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD4__A, 13517)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD5__A, 13517)); + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD0__A, 13517); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD1__A, 13517); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD2__A, 13517); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD3__A, 13517); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD4__A, 13517); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD5__A, 13517); + if (status < 0) + break; /* Decision Feedback Equalizer */ - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN0__A, 2)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN1__A, 2)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN2__A, 2)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN3__A, 2)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN4__A, 2)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN5__A, 0)); + status = Write16_0(state, QAM_DQ_QUAL_FUN0__A, 2); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN1__A, 2); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN2__A, 2); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN3__A, 2); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN4__A, 2); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN5__A, 0); + if (status < 0) + break; - CHK_ERROR(Write16_0(state, QAM_SY_SYNC_HWM__A, 5)); - CHK_ERROR(Write16_0(state, QAM_SY_SYNC_AWM__A, 4)); - CHK_ERROR(Write16_0(state, QAM_SY_SYNC_LWM__A, 3)); + status = Write16_0(state, QAM_SY_SYNC_HWM__A, 5); + if (status < 0) + break; + status = Write16_0(state, QAM_SY_SYNC_AWM__A, 4); + if (status < 0) + break; + status = Write16_0(state, QAM_SY_SYNC_LWM__A, 3); + if (status < 0) + break; /* QAM Slicer Settings */ - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_SL_SIG_POWER__A, - DRXK_QAM_SL_SIG_POWER_QAM16)); + status = Write16_0(state, SCU_RAM_QAM_SL_SIG_POWER__A, DRXK_QAM_SL_SIG_POWER_QAM16); + if (status < 0) + break; /* QAM Loop Controller Coeficients */ - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CA_FINE__A, 15)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CA_COARSE__A, 40)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_EP_FINE__A, 12)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_EP_COARSE__A, 24)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_EI_FINE__A, 12)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_EI_COARSE__A, 16)); - - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CP_FINE__A, 5)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CP_MEDIUM__A, 20)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CP_COARSE__A, 80)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CI_FINE__A, 5)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CI_MEDIUM__A, 20)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CI_COARSE__A, 50)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CF_FINE__A, 16)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CF_MEDIUM__A, 16)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CF_COARSE__A, 32)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CF1_FINE__A, 5)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 10)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CF1_COARSE__A, 10)); + status = Write16_0(state, SCU_RAM_QAM_LC_CA_FINE__A, 15); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CA_COARSE__A, 40); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EP_FINE__A, 12); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EP_COARSE__A, 24); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EI_FINE__A, 12); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EI_COARSE__A, 16); + if (status < 0) + break; + + status = Write16_0(state, SCU_RAM_QAM_LC_CP_FINE__A, 5); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CP_MEDIUM__A, 20); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CP_COARSE__A, 80); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CI_FINE__A, 5); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CI_MEDIUM__A, 20); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CI_COARSE__A, 50); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF_FINE__A, 16); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF_MEDIUM__A, 16); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF_COARSE__A, 32); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF1_FINE__A, 5); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 10); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF1_COARSE__A, 10); + if (status < 0) + break; /* QAM State Machine (FSM) Thresholds */ - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_RTH__A, 140)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_FTH__A, 50)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_CTH__A, 95)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_PTH__A, 120)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_QTH__A, 230)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_MTH__A, 105)); + status = Write16_0(state, SCU_RAM_QAM_FSM_RTH__A, 140); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_FTH__A, 50); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_CTH__A, 95); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_PTH__A, 120); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_QTH__A, 230); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_MTH__A, 105); + if (status < 0) + break; - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_RATE_LIM__A, 40)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_COUNT_LIM__A, 4)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_FREQ_LIM__A, 24)); + status = Write16_0(state, SCU_RAM_QAM_FSM_RATE_LIM__A, 40); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_COUNT_LIM__A, 4); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_FREQ_LIM__A, 24); + if (status < 0) + break; /* QAM FSM Tracking Parameters */ - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, - (u16) 16)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, - (u16) 220)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, - (u16) 25)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, - (u16) 6)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, - (u16) -24)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, - (u16) -65)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, - (u16) -127)); + status = Write16_0(state, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, (u16) 16); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, (u16) 220); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, (u16) 25); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, (u16) 6); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, (u16) -24); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, (u16) -65); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, (u16) -127); + if (status < 0) + break; } while (0); return status; @@ -3861,116 +4290,182 @@ static int SetQAM32(struct drxk_state *state) do { /* QAM Equalizer Setup */ /* Equalizer */ - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD0__A, 6707)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD1__A, 6707)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD2__A, 6707)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD3__A, 6707)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD4__A, 6707)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD5__A, 6707)); + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD0__A, 6707); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD1__A, 6707); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD2__A, 6707); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD3__A, 6707); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD4__A, 6707); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD5__A, 6707); + if (status < 0) + break; /* Decision Feedback Equalizer */ - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN0__A, 3)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN1__A, 3)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN2__A, 3)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN3__A, 3)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN4__A, 3)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN5__A, 0)); + status = Write16_0(state, QAM_DQ_QUAL_FUN0__A, 3); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN1__A, 3); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN2__A, 3); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN3__A, 3); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN4__A, 3); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN5__A, 0); + if (status < 0) + break; - CHK_ERROR(Write16_0(state, QAM_SY_SYNC_HWM__A, 6)); - CHK_ERROR(Write16_0(state, QAM_SY_SYNC_AWM__A, 5)); - CHK_ERROR(Write16_0(state, QAM_SY_SYNC_LWM__A, 3)); + status = Write16_0(state, QAM_SY_SYNC_HWM__A, 6); + if (status < 0) + break; + status = Write16_0(state, QAM_SY_SYNC_AWM__A, 5); + if (status < 0) + break; + status = Write16_0(state, QAM_SY_SYNC_LWM__A, 3); + if (status < 0) + break; /* QAM Slicer Settings */ - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_SL_SIG_POWER__A, - DRXK_QAM_SL_SIG_POWER_QAM32)); + status = Write16_0(state, SCU_RAM_QAM_SL_SIG_POWER__A, DRXK_QAM_SL_SIG_POWER_QAM32); + if (status < 0) + break; /* QAM Loop Controller Coeficients */ - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CA_FINE__A, 15)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CA_COARSE__A, 40)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_EP_FINE__A, 12)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_EP_COARSE__A, 24)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_EI_FINE__A, 12)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_EI_COARSE__A, 16)); - - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CP_FINE__A, 5)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CP_MEDIUM__A, 20)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CP_COARSE__A, 80)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CI_FINE__A, 5)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CI_MEDIUM__A, 20)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CI_COARSE__A, 50)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CF_FINE__A, 16)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CF_MEDIUM__A, 16)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CF_COARSE__A, 16)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CF1_FINE__A, 5)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 10)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CF1_COARSE__A, 0)); + status = Write16_0(state, SCU_RAM_QAM_LC_CA_FINE__A, 15); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CA_COARSE__A, 40); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EP_FINE__A, 12); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EP_COARSE__A, 24); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EI_FINE__A, 12); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EI_COARSE__A, 16); + if (status < 0) + break; + + status = Write16_0(state, SCU_RAM_QAM_LC_CP_FINE__A, 5); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CP_MEDIUM__A, 20); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CP_COARSE__A, 80); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CI_FINE__A, 5); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CI_MEDIUM__A, 20); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CI_COARSE__A, 50); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF_FINE__A, 16); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF_MEDIUM__A, 16); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF_COARSE__A, 16); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF1_FINE__A, 5); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 10); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF1_COARSE__A, 0); + if (status < 0) + break; /* QAM State Machine (FSM) Thresholds */ - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_RTH__A, 90)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_FTH__A, 50)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_CTH__A, 80)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_PTH__A, 100)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_QTH__A, 170)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_MTH__A, 100)); + status = Write16_0(state, SCU_RAM_QAM_FSM_RTH__A, 90); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_FTH__A, 50); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_CTH__A, 80); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_PTH__A, 100); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_QTH__A, 170); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_MTH__A, 100); + if (status < 0) + break; - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_RATE_LIM__A, 40)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_COUNT_LIM__A, 4)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_FREQ_LIM__A, 10)); + status = Write16_0(state, SCU_RAM_QAM_FSM_RATE_LIM__A, 40); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_COUNT_LIM__A, 4); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_FREQ_LIM__A, 10); + if (status < 0) + break; /* QAM FSM Tracking Parameters */ - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, - (u16) 12)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, - (u16) 140)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, - (u16) -8)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, - (u16) -16)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, - (u16) -26)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, - (u16) -56)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, - (u16) -86)); + status = Write16_0(state, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, (u16) 12); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, (u16) 140); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, (u16) -8); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, (u16) -16); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, (u16) -26); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, (u16) -56); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, (u16) -86); + if (status < 0) + break; } while (0); return status; @@ -3990,115 +4485,181 @@ static int SetQAM64(struct drxk_state *state) do { /* QAM Equalizer Setup */ /* Equalizer */ - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD0__A, 13336)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD1__A, 12618)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD2__A, 11988)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD3__A, 13809)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD4__A, 13809)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD5__A, 15609)); + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD0__A, 13336); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD1__A, 12618); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD2__A, 11988); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD3__A, 13809); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD4__A, 13809); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD5__A, 15609); + if (status < 0) + break; /* Decision Feedback Equalizer */ - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN0__A, 4)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN1__A, 4)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN2__A, 4)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN3__A, 4)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN4__A, 3)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN5__A, 0)); + status = Write16_0(state, QAM_DQ_QUAL_FUN0__A, 4); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN1__A, 4); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN2__A, 4); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN3__A, 4); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN4__A, 3); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN5__A, 0); + if (status < 0) + break; - CHK_ERROR(Write16_0(state, QAM_SY_SYNC_HWM__A, 5)); - CHK_ERROR(Write16_0(state, QAM_SY_SYNC_AWM__A, 4)); - CHK_ERROR(Write16_0(state, QAM_SY_SYNC_LWM__A, 3)); + status = Write16_0(state, QAM_SY_SYNC_HWM__A, 5); + if (status < 0) + break; + status = Write16_0(state, QAM_SY_SYNC_AWM__A, 4); + if (status < 0) + break; + status = Write16_0(state, QAM_SY_SYNC_LWM__A, 3); + if (status < 0) + break; /* QAM Slicer Settings */ - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_SL_SIG_POWER__A, - DRXK_QAM_SL_SIG_POWER_QAM64)); + status = Write16_0(state, SCU_RAM_QAM_SL_SIG_POWER__A, DRXK_QAM_SL_SIG_POWER_QAM64); + if (status < 0) + break; /* QAM Loop Controller Coeficients */ - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CA_FINE__A, 15)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CA_COARSE__A, 40)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_EP_FINE__A, 12)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_EP_COARSE__A, 24)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_EI_FINE__A, 12)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_EI_COARSE__A, 16)); - - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CP_FINE__A, 5)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CP_MEDIUM__A, 30)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CP_COARSE__A, 100)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CI_FINE__A, 5)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CI_MEDIUM__A, 30)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CI_COARSE__A, 50)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CF_FINE__A, 16)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CF_MEDIUM__A, 25)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CF_COARSE__A, 48)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CF1_FINE__A, 5)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 10)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CF1_COARSE__A, 10)); + status = Write16_0(state, SCU_RAM_QAM_LC_CA_FINE__A, 15); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CA_COARSE__A, 40); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EP_FINE__A, 12); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EP_COARSE__A, 24); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EI_FINE__A, 12); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EI_COARSE__A, 16); + if (status < 0) + break; + + status = Write16_0(state, SCU_RAM_QAM_LC_CP_FINE__A, 5); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CP_MEDIUM__A, 30); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CP_COARSE__A, 100); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CI_FINE__A, 5); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CI_MEDIUM__A, 30); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CI_COARSE__A, 50); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF_FINE__A, 16); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF_MEDIUM__A, 25); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF_COARSE__A, 48); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF1_FINE__A, 5); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 10); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF1_COARSE__A, 10); + if (status < 0) + break; /* QAM State Machine (FSM) Thresholds */ - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_RTH__A, 100)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_FTH__A, 60)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_CTH__A, 80)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_PTH__A, 110)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_QTH__A, 200)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_MTH__A, 95)); + status = Write16_0(state, SCU_RAM_QAM_FSM_RTH__A, 100); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_FTH__A, 60); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_CTH__A, 80); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_PTH__A, 110); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_QTH__A, 200); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_MTH__A, 95); + if (status < 0) + break; - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_RATE_LIM__A, 40)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_COUNT_LIM__A, 4)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_FREQ_LIM__A, 15)); + status = Write16_0(state, SCU_RAM_QAM_FSM_RATE_LIM__A, 40); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_COUNT_LIM__A, 4); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_FREQ_LIM__A, 15); + if (status < 0) + break; /* QAM FSM Tracking Parameters */ - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, - (u16) 12)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, - (u16) 141)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, - (u16) 7)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, - (u16) 0)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, - (u16) -15)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, - (u16) -45)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, - (u16) -80)); + status = Write16_0(state, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, (u16) 12); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, (u16) 141); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, (u16) 7); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, (u16) 0); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, (u16) -15); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, (u16) -45); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, (u16) -80); + if (status < 0) + break; } while (0); return status; @@ -4118,117 +4679,183 @@ static int SetQAM128(struct drxk_state *state) do { /* QAM Equalizer Setup */ /* Equalizer */ - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD0__A, 6564)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD1__A, 6598)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD2__A, 6394)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD3__A, 6409)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD4__A, 6656)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD5__A, 7238)); + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD0__A, 6564); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD1__A, 6598); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD2__A, 6394); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD3__A, 6409); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD4__A, 6656); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD5__A, 7238); + if (status < 0) + break; /* Decision Feedback Equalizer */ - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN0__A, 6)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN1__A, 6)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN2__A, 6)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN3__A, 6)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN4__A, 5)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN5__A, 0)); + status = Write16_0(state, QAM_DQ_QUAL_FUN0__A, 6); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN1__A, 6); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN2__A, 6); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN3__A, 6); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN4__A, 5); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN5__A, 0); + if (status < 0) + break; - CHK_ERROR(Write16_0(state, QAM_SY_SYNC_HWM__A, 6)); - CHK_ERROR(Write16_0(state, QAM_SY_SYNC_AWM__A, 5)); - CHK_ERROR(Write16_0(state, QAM_SY_SYNC_LWM__A, 3)); + status = Write16_0(state, QAM_SY_SYNC_HWM__A, 6); + if (status < 0) + break; + status = Write16_0(state, QAM_SY_SYNC_AWM__A, 5); + if (status < 0) + break; + status = Write16_0(state, QAM_SY_SYNC_LWM__A, 3); + if (status < 0) + break; /* QAM Slicer Settings */ - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_SL_SIG_POWER__A, - DRXK_QAM_SL_SIG_POWER_QAM128)); + status = Write16_0(state, SCU_RAM_QAM_SL_SIG_POWER__A, DRXK_QAM_SL_SIG_POWER_QAM128); + if (status < 0) + break; /* QAM Loop Controller Coeficients */ - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CA_FINE__A, 15)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CA_COARSE__A, 40)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_EP_FINE__A, 12)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_EP_COARSE__A, 24)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_EI_FINE__A, 12)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_EI_COARSE__A, 16)); - - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CP_FINE__A, 5)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CP_MEDIUM__A, 40)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CP_COARSE__A, 120)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CI_FINE__A, 5)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CI_MEDIUM__A, 40)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CI_COARSE__A, 60)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CF_FINE__A, 16)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CF_MEDIUM__A, 25)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CF_COARSE__A, 64)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CF1_FINE__A, 5)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 10)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CF1_COARSE__A, 0)); + status = Write16_0(state, SCU_RAM_QAM_LC_CA_FINE__A, 15); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CA_COARSE__A, 40); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EP_FINE__A, 12); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EP_COARSE__A, 24); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EI_FINE__A, 12); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EI_COARSE__A, 16); + if (status < 0) + break; + + status = Write16_0(state, SCU_RAM_QAM_LC_CP_FINE__A, 5); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CP_MEDIUM__A, 40); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CP_COARSE__A, 120); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CI_FINE__A, 5); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CI_MEDIUM__A, 40); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CI_COARSE__A, 60); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF_FINE__A, 16); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF_MEDIUM__A, 25); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF_COARSE__A, 64); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF1_FINE__A, 5); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 10); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF1_COARSE__A, 0); + if (status < 0) + break; /* QAM State Machine (FSM) Thresholds */ - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_RTH__A, 50)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_FTH__A, 60)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_CTH__A, 80)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_PTH__A, 100)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_QTH__A, 140)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_MTH__A, 100)); + status = Write16_0(state, SCU_RAM_QAM_FSM_RTH__A, 50); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_FTH__A, 60); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_CTH__A, 80); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_PTH__A, 100); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_QTH__A, 140); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_MTH__A, 100); + if (status < 0) + break; - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_RATE_LIM__A, 40)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_COUNT_LIM__A, 5)); + status = Write16_0(state, SCU_RAM_QAM_FSM_RATE_LIM__A, 40); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_COUNT_LIM__A, 5); + if (status < 0) + break; - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_FREQ_LIM__A, 12)); + status = Write16_0(state, SCU_RAM_QAM_FSM_FREQ_LIM__A, 12); + if (status < 0) + break; /* QAM FSM Tracking Parameters */ - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, - (u16) 8)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, - (u16) 65)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, - (u16) 5)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, - (u16) 3)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, - (u16) -1)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, - (u16) -12)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, - (u16) -23)); + status = Write16_0(state, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, (u16) 8); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, (u16) 65); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, (u16) 5); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, (u16) 3); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, (u16) -1); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, (u16) -12); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, (u16) -23); + if (status < 0) + break; } while (0); return status; @@ -4248,116 +4875,182 @@ static int SetQAM256(struct drxk_state *state) do { /* QAM Equalizer Setup */ /* Equalizer */ - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD0__A, 11502)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD1__A, 12084)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD2__A, 12543)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD3__A, 12931)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD4__A, 13629)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_EQ_CMA_RAD5__A, 15385)); + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD0__A, 11502); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD1__A, 12084); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD2__A, 12543); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD3__A, 12931); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD4__A, 13629); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_EQ_CMA_RAD5__A, 15385); + if (status < 0) + break; /* Decision Feedback Equalizer */ - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN0__A, 8)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN1__A, 8)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN2__A, 8)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN3__A, 8)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN4__A, 6)); - CHK_ERROR(Write16_0(state, QAM_DQ_QUAL_FUN5__A, 0)); + status = Write16_0(state, QAM_DQ_QUAL_FUN0__A, 8); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN1__A, 8); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN2__A, 8); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN3__A, 8); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN4__A, 6); + if (status < 0) + break; + status = Write16_0(state, QAM_DQ_QUAL_FUN5__A, 0); + if (status < 0) + break; - CHK_ERROR(Write16_0(state, QAM_SY_SYNC_HWM__A, 5)); - CHK_ERROR(Write16_0(state, QAM_SY_SYNC_AWM__A, 4)); - CHK_ERROR(Write16_0(state, QAM_SY_SYNC_LWM__A, 3)); + status = Write16_0(state, QAM_SY_SYNC_HWM__A, 5); + if (status < 0) + break; + status = Write16_0(state, QAM_SY_SYNC_AWM__A, 4); + if (status < 0) + break; + status = Write16_0(state, QAM_SY_SYNC_LWM__A, 3); + if (status < 0) + break; /* QAM Slicer Settings */ - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_SL_SIG_POWER__A, - DRXK_QAM_SL_SIG_POWER_QAM256)); + status = Write16_0(state, SCU_RAM_QAM_SL_SIG_POWER__A, DRXK_QAM_SL_SIG_POWER_QAM256); + if (status < 0) + break; /* QAM Loop Controller Coeficients */ - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CA_FINE__A, 15)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CA_COARSE__A, 40)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_EP_FINE__A, 12)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_EP_COARSE__A, 24)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_EI_FINE__A, 12)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_EI_COARSE__A, 16)); - - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CP_FINE__A, 5)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CP_MEDIUM__A, 50)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CP_COARSE__A, 250)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CI_FINE__A, 5)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CI_MEDIUM__A, 50)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CI_COARSE__A, 125)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CF_FINE__A, 16)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CF_MEDIUM__A, 25)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CF_COARSE__A, 48)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_LC_CF1_FINE__A, 5)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 10)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_LC_CF1_COARSE__A, 10)); + status = Write16_0(state, SCU_RAM_QAM_LC_CA_FINE__A, 15); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CA_COARSE__A, 40); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EP_FINE__A, 12); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EP_MEDIUM__A, 24); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EP_COARSE__A, 24); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EI_FINE__A, 12); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EI_MEDIUM__A, 16); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_EI_COARSE__A, 16); + if (status < 0) + break; + + status = Write16_0(state, SCU_RAM_QAM_LC_CP_FINE__A, 5); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CP_MEDIUM__A, 50); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CP_COARSE__A, 250); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CI_FINE__A, 5); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CI_MEDIUM__A, 50); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CI_COARSE__A, 125); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF_FINE__A, 16); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF_MEDIUM__A, 25); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF_COARSE__A, 48); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF1_FINE__A, 5); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF1_MEDIUM__A, 10); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_LC_CF1_COARSE__A, 10); + if (status < 0) + break; /* QAM State Machine (FSM) Thresholds */ - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_RTH__A, 50)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_FTH__A, 60)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_CTH__A, 80)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_PTH__A, 100)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_QTH__A, 150)); - CHK_ERROR(Write16_0(state, SCU_RAM_QAM_FSM_MTH__A, 110)); + status = Write16_0(state, SCU_RAM_QAM_FSM_RTH__A, 50); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_FTH__A, 60); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_CTH__A, 80); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_PTH__A, 100); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_QTH__A, 150); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_MTH__A, 110); + if (status < 0) + break; - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_RATE_LIM__A, 40)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_COUNT_LIM__A, 4)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_FREQ_LIM__A, 12)); + status = Write16_0(state, SCU_RAM_QAM_FSM_RATE_LIM__A, 40); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_COUNT_LIM__A, 4); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_FREQ_LIM__A, 12); + if (status < 0) + break; /* QAM FSM Tracking Parameters */ - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, - (u16) 8)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, - (u16) 74)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, - (u16) 18)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, - (u16) 13)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, - (u16) 7)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, - (u16) 0)); - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, - (u16) -8)); + status = Write16_0(state, SCU_RAM_QAM_FSM_MEDIAN_AV_MULT__A, (u16) 8); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_RADIUS_AV_LIMIT__A, (u16) 74); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET1__A, (u16) 18); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET2__A, (u16) 13); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET3__A, (u16) 7); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET4__A, (u16) 0); + if (status < 0) + break; + status = Write16_0(state, SCU_RAM_QAM_FSM_LCAVG_OFFSET5__A, (u16) -8); + if (status < 0) + break; } while (0); return status; @@ -4378,14 +5071,13 @@ static int QAMResetQAM(struct drxk_state *state) do { /* Stop QAM comstate->m_exec */ - CHK_ERROR(Write16_0 - (state, QAM_COMM_EXEC__A, QAM_COMM_EXEC_STOP)); - - CHK_ERROR(scu_command - (state, - SCU_RAM_COMMAND_STANDARD_QAM | - SCU_RAM_COMMAND_CMD_DEMOD_RESET, 0, NULL, 1, - &cmdResult)); + status = Write16_0(state, QAM_COMM_EXEC__A, QAM_COMM_EXEC_STOP); + if (status < 0) + break; + + status = scu_command(state, SCU_RAM_COMMAND_STANDARD_QAM | SCU_RAM_COMMAND_CMD_DEMOD_RESET, 0, NULL, 1, &cmdResult); + if (status < 0) + break; } while (0); /* All done, all OK */ @@ -4420,7 +5112,9 @@ static int QAMSetSymbolrate(struct drxk_state *state) ratesel = 2; else if (state->param.u.qam.symbol_rate <= 4755000) ratesel = 1; - CHK_ERROR(Write16_0(state, IQM_FD_RATESEL__A, ratesel)); + status = Write16_0(state, IQM_FD_RATESEL__A, ratesel); + if (status < 0) + break; /* IqmRcRate = ((Fadc / (symbolrate * (4<<ratesel))) - 1) * (1<<23) @@ -4433,8 +5127,9 @@ static int QAMSetSymbolrate(struct drxk_state *state) iqmRcRate = (adcFrequency / symbFreq) * (1 << 21) + (Frac28a((adcFrequency % symbFreq), symbFreq) >> 7) - (1 << 23); - CHK_ERROR(Write32 - (state, IQM_RC_RATE_OFS_LO__A, iqmRcRate, 0)); + status = Write32(state, IQM_RC_RATE_OFS_LO__A, iqmRcRate, 0); + if (status < 0) + break; state->m_iqmRcRate = iqmRcRate; /* LcSymbFreq = round (.125 * symbolrate / adcFreq * (1<<15)) @@ -4449,9 +5144,9 @@ static int QAMSetSymbolrate(struct drxk_state *state) 16); if (lcSymbRate > 511) lcSymbRate = 511; - CHK_ERROR(Write16_0 - (state, QAM_LC_SYMBOL_FREQ__A, - (u16) lcSymbRate)); + status = Write16_0(state, QAM_LC_SYMBOL_FREQ__A, (u16) lcSymbRate); + if (status < 0) + break; } while (0); return status; @@ -4521,20 +5216,24 @@ static int SetQAM(struct drxk_state *state, u16 IntermediateFreqkHz, resets QAM block resets SCU variables */ - CHK_ERROR(Write16_0 - (state, FEC_DI_COMM_EXEC__A, - FEC_DI_COMM_EXEC_STOP)); - CHK_ERROR(Write16_0 - (state, FEC_RS_COMM_EXEC__A, - FEC_RS_COMM_EXEC_STOP)); - CHK_ERROR(QAMResetQAM(state)); + status = Write16_0(state, FEC_DI_COMM_EXEC__A, FEC_DI_COMM_EXEC_STOP); + if (status < 0) + break; + status = Write16_0(state, FEC_RS_COMM_EXEC__A, FEC_RS_COMM_EXEC_STOP); + if (status < 0) + break; + status = QAMResetQAM(state); + if (status < 0) + break; /* STEP 2: configure demodulator -set env -set params; resets IQM,QAM,FEC HW; initializes some SCU variables */ - CHK_ERROR(QAMSetSymbolrate(state)); + status = QAMSetSymbolrate(state); + if (status < 0) + break; /* Env parameters */ setEnvParameters[2] = QAM_TOP_ANNEX_A; /* Annex */ @@ -4567,114 +5266,174 @@ static int SetQAM(struct drxk_state *state, u16 IntermediateFreqkHz, status = -EINVAL; break; } - CHK_ERROR(status); + status = status; + if (status < 0) + break; setParamParameters[0] = state->m_Constellation; /* constellation */ setParamParameters[1] = DRXK_QAM_I12_J17; /* interleave mode */ - CHK_ERROR(scu_command - (state, - SCU_RAM_COMMAND_STANDARD_QAM | - SCU_RAM_COMMAND_CMD_DEMOD_SET_PARAM, 4, - setParamParameters, 1, &cmdResult)); + status = scu_command(state, SCU_RAM_COMMAND_STANDARD_QAM | SCU_RAM_COMMAND_CMD_DEMOD_SET_PARAM, 4, setParamParameters, 1, &cmdResult); + if (status < 0) + break; /* STEP 3: enable the system in a mode where the ADC provides valid signal setup constellation independent registers */ - /* CHK_ERROR (SetFrequency (channel, tunerFreqOffset)); */ - CHK_ERROR(SetFrequencyShifter - (state, IntermediateFreqkHz, tunerFreqOffset, - true)); +#if 0 + status = SetFrequency (channel, tunerFreqOffset)); + if (status < 0) + break; +#endif + status = SetFrequencyShifter(state, IntermediateFreqkHz, tunerFreqOffset, true); + if (status < 0) + break; /* Setup BER measurement */ - CHK_ERROR(SetQAMMeasurement(state, - state->m_Constellation, - state->param.u. - qam.symbol_rate)); + status = SetQAMMeasurement(state, state->m_Constellation, state->param.u. qam.symbol_rate); + if (status < 0) + break; /* Reset default values */ - CHK_ERROR(Write16_0 - (state, IQM_CF_SCALE_SH__A, - IQM_CF_SCALE_SH__PRE)); - CHK_ERROR(Write16_0 - (state, QAM_SY_TIMEOUT__A, QAM_SY_TIMEOUT__PRE)); + status = Write16_0(state, IQM_CF_SCALE_SH__A, IQM_CF_SCALE_SH__PRE); + if (status < 0) + break; + status = Write16_0(state, QAM_SY_TIMEOUT__A, QAM_SY_TIMEOUT__PRE); + if (status < 0) + break; /* Reset default LC values */ - CHK_ERROR(Write16_0(state, QAM_LC_RATE_LIMIT__A, 3)); - CHK_ERROR(Write16_0(state, QAM_LC_LPF_FACTORP__A, 4)); - CHK_ERROR(Write16_0(state, QAM_LC_LPF_FACTORI__A, 4)); - CHK_ERROR(Write16_0(state, QAM_LC_MODE__A, 7)); - - CHK_ERROR(Write16_0(state, QAM_LC_QUAL_TAB0__A, 1)); - CHK_ERROR(Write16_0(state, QAM_LC_QUAL_TAB1__A, 1)); - CHK_ERROR(Write16_0(state, QAM_LC_QUAL_TAB2__A, 1)); - CHK_ERROR(Write16_0(state, QAM_LC_QUAL_TAB3__A, 1)); - CHK_ERROR(Write16_0(state, QAM_LC_QUAL_TAB4__A, 2)); - CHK_ERROR(Write16_0(state, QAM_LC_QUAL_TAB5__A, 2)); - CHK_ERROR(Write16_0(state, QAM_LC_QUAL_TAB6__A, 2)); - CHK_ERROR(Write16_0(state, QAM_LC_QUAL_TAB8__A, 2)); - CHK_ERROR(Write16_0(state, QAM_LC_QUAL_TAB9__A, 2)); - CHK_ERROR(Write16_0(state, QAM_LC_QUAL_TAB10__A, 2)); - CHK_ERROR(Write16_0(state, QAM_LC_QUAL_TAB12__A, 2)); - CHK_ERROR(Write16_0(state, QAM_LC_QUAL_TAB15__A, 3)); - CHK_ERROR(Write16_0(state, QAM_LC_QUAL_TAB16__A, 3)); - CHK_ERROR(Write16_0(state, QAM_LC_QUAL_TAB20__A, 4)); - CHK_ERROR(Write16_0(state, QAM_LC_QUAL_TAB25__A, 4)); + status = Write16_0(state, QAM_LC_RATE_LIMIT__A, 3); + if (status < 0) + break; + status = Write16_0(state, QAM_LC_LPF_FACTORP__A, 4); + if (status < 0) + break; + status = Write16_0(state, QAM_LC_LPF_FACTORI__A, 4); + if (status < 0) + break; + status = Write16_0(state, QAM_LC_MODE__A, 7); + if (status < 0) + break; + + status = Write16_0(state, QAM_LC_QUAL_TAB0__A, 1); + if (status < 0) + break; + status = Write16_0(state, QAM_LC_QUAL_TAB1__A, 1); + if (status < 0) + break; + status = Write16_0(state, QAM_LC_QUAL_TAB2__A, 1); + if (status < 0) + break; + status = Write16_0(state, QAM_LC_QUAL_TAB3__A, 1); + if (status < 0) + break; + status = Write16_0(state, QAM_LC_QUAL_TAB4__A, 2); + if (status < 0) + break; + status = Write16_0(state, QAM_LC_QUAL_TAB5__A, 2); + if (status < 0) + break; + status = Write16_0(state, QAM_LC_QUAL_TAB6__A, 2); + if (status < 0) + break; + status = Write16_0(state, QAM_LC_QUAL_TAB8__A, 2); + if (status < 0) + break; + status = Write16_0(state, QAM_LC_QUAL_TAB9__A, 2); + if (status < 0) + break; + status = Write16_0(state, QAM_LC_QUAL_TAB10__A, 2); + if (status < 0) + break; + status = Write16_0(state, QAM_LC_QUAL_TAB12__A, 2); + if (status < 0) + break; + status = Write16_0(state, QAM_LC_QUAL_TAB15__A, 3); + if (status < 0) + break; + status = Write16_0(state, QAM_LC_QUAL_TAB16__A, 3); + if (status < 0) + break; + status = Write16_0(state, QAM_LC_QUAL_TAB20__A, 4); + if (status < 0) + break; + status = Write16_0(state, QAM_LC_QUAL_TAB25__A, 4); + if (status < 0) + break; /* Mirroring, QAM-block starting point not inverted */ - CHK_ERROR(Write16_0 - (state, QAM_SY_SP_INV__A, - QAM_SY_SP_INV_SPECTRUM_INV_DIS)); + status = Write16_0(state, QAM_SY_SP_INV__A, QAM_SY_SP_INV_SPECTRUM_INV_DIS); + if (status < 0) + break; /* Halt SCU to enable safe non-atomic accesses */ - CHK_ERROR(Write16_0 - (state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_HOLD)); + status = Write16_0(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_HOLD); + if (status < 0) + break; /* STEP 4: constellation specific setup */ switch (state->param.u.qam.modulation) { case QAM_16: - CHK_ERROR(SetQAM16(state)); + status = SetQAM16(state); + if (status < 0) + break; break; case QAM_32: - CHK_ERROR(SetQAM32(state)); + status = SetQAM32(state); + if (status < 0) + break; break; case QAM_AUTO: case QAM_64: - CHK_ERROR(SetQAM64(state)); + status = SetQAM64(state); + if (status < 0) + break; break; case QAM_128: - CHK_ERROR(SetQAM128(state)); + status = SetQAM128(state); + if (status < 0) + break; break; case QAM_256: - CHK_ERROR(SetQAM256(state)); + status = SetQAM256(state); + if (status < 0) + break; break; default: return -1; break; } /* switch */ /* Activate SCU to enable SCU commands */ - CHK_ERROR(Write16_0 - (state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE)); + status = Write16_0(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE); + if (status < 0) + break; /* Re-configure MPEG output, requires knowledge of channel bitrate */ /* extAttr->currentChannel.constellation = channel->constellation; */ /* extAttr->currentChannel.symbolrate = channel->symbolrate; */ - CHK_ERROR(MPEGTSDtoSetup(state, state->m_OperationMode)); + status = MPEGTSDtoSetup(state, state->m_OperationMode); + if (status < 0) + break; /* Start processes */ - CHK_ERROR(MPEGTSStart(state)); - CHK_ERROR(Write16_0 - (state, FEC_COMM_EXEC__A, FEC_COMM_EXEC_ACTIVE)); - CHK_ERROR(Write16_0 - (state, QAM_COMM_EXEC__A, QAM_COMM_EXEC_ACTIVE)); - CHK_ERROR(Write16_0 - (state, IQM_COMM_EXEC__A, - IQM_COMM_EXEC_B_ACTIVE)); + status = MPEGTSStart(state); + if (status < 0) + break; + status = Write16_0(state, FEC_COMM_EXEC__A, FEC_COMM_EXEC_ACTIVE); + if (status < 0) + break; + status = Write16_0(state, QAM_COMM_EXEC__A, QAM_COMM_EXEC_ACTIVE); + if (status < 0) + break; + status = Write16_0(state, IQM_COMM_EXEC__A, IQM_COMM_EXEC_B_ACTIVE); + if (status < 0) + break; /* STEP 5: start QAM demodulator (starts FEC, QAM and IQM HW) */ - CHK_ERROR(scu_command(state, SCU_RAM_COMMAND_STANDARD_QAM | - SCU_RAM_COMMAND_CMD_DEMOD_START, 0, - NULL, 1, &cmdResult)); + status = scu_command(state, SCU_RAM_COMMAND_STANDARD_QAM | SCU_RAM_COMMAND_CMD_DEMOD_START, 0, NULL, 1, &cmdResult); + if (status < 0) + break; /* update global DRXK data container */ /*? extAttr->qamInterleaveMode = DRXK_QAM_I12_J17; */ @@ -4704,96 +5463,153 @@ static int SetQAMStandard(struct drxk_state *state, SwitchAntennaToQAM(state); /* Ensure correct power-up mode */ - CHK_ERROR(PowerUpQAM(state)); + status = PowerUpQAM(state); + if (status < 0) + break; /* Reset QAM block */ - CHK_ERROR(QAMResetQAM(state)); + status = QAMResetQAM(state); + if (status < 0) + break; /* Setup IQM */ - CHK_ERROR(Write16_0 - (state, IQM_COMM_EXEC__A, IQM_COMM_EXEC_B_STOP)); - CHK_ERROR(Write16_0 - (state, IQM_AF_AMUX__A, IQM_AF_AMUX_SIGNAL2ADC)); + status = Write16_0(state, IQM_COMM_EXEC__A, IQM_COMM_EXEC_B_STOP); + if (status < 0) + break; + status = Write16_0(state, IQM_AF_AMUX__A, IQM_AF_AMUX_SIGNAL2ADC); + if (status < 0) + break; /* Upload IQM Channel Filter settings by boot loader from ROM table */ switch (oMode) { case OM_QAM_ITU_A: - CHK_ERROR(BLChainCmd(state, - DRXK_BL_ROM_OFFSET_TAPS_ITU_A, - DRXK_BLCC_NR_ELEMENTS_TAPS, - DRXK_BLC_TIMEOUT)); + status = BLChainCmd(state, DRXK_BL_ROM_OFFSET_TAPS_ITU_A, DRXK_BLCC_NR_ELEMENTS_TAPS, DRXK_BLC_TIMEOUT); + if (status < 0) + break; break; case OM_QAM_ITU_C: - CHK_ERROR(BLDirectCmd(state, IQM_CF_TAP_RE0__A, - DRXK_BL_ROM_OFFSET_TAPS_ITU_C, - DRXK_BLDC_NR_ELEMENTS_TAPS, - DRXK_BLC_TIMEOUT)); - CHK_ERROR(BLDirectCmd(state, IQM_CF_TAP_IM0__A, - DRXK_BL_ROM_OFFSET_TAPS_ITU_C, - DRXK_BLDC_NR_ELEMENTS_TAPS, - DRXK_BLC_TIMEOUT)); + status = BLDirectCmd(state, IQM_CF_TAP_RE0__A, DRXK_BL_ROM_OFFSET_TAPS_ITU_C, DRXK_BLDC_NR_ELEMENTS_TAPS, DRXK_BLC_TIMEOUT); + if (status < 0) + break; + status = BLDirectCmd(state, IQM_CF_TAP_IM0__A, DRXK_BL_ROM_OFFSET_TAPS_ITU_C, DRXK_BLDC_NR_ELEMENTS_TAPS, DRXK_BLC_TIMEOUT); + if (status < 0) + break; break; default: status = -EINVAL; } - CHK_ERROR(status); - - CHK_ERROR(Write16_0(state, IQM_CF_OUT_ENA__A, - (1 << IQM_CF_OUT_ENA_QAM__B))); - CHK_ERROR(Write16_0(state, IQM_CF_SYMMETRIC__A, 0)); - CHK_ERROR(Write16_0(state, IQM_CF_MIDTAP__A, - ((1 << IQM_CF_MIDTAP_RE__B) | - (1 << IQM_CF_MIDTAP_IM__B)))); - - CHK_ERROR(Write16_0(state, IQM_RC_STRETCH__A, 21)); - CHK_ERROR(Write16_0(state, IQM_AF_CLP_LEN__A, 0)); - CHK_ERROR(Write16_0(state, IQM_AF_CLP_TH__A, 448)); - CHK_ERROR(Write16_0(state, IQM_AF_SNS_LEN__A, 0)); - CHK_ERROR(Write16_0(state, IQM_CF_POW_MEAS_LEN__A, 0)); - - CHK_ERROR(Write16_0(state, IQM_FS_ADJ_SEL__A, 1)); - CHK_ERROR(Write16_0(state, IQM_RC_ADJ_SEL__A, 1)); - CHK_ERROR(Write16_0(state, IQM_CF_ADJ_SEL__A, 1)); - CHK_ERROR(Write16_0(state, IQM_AF_UPD_SEL__A, 0)); + status = status; + if (status < 0) + break; + + status = Write16_0(state, IQM_CF_OUT_ENA__A, (1 << IQM_CF_OUT_ENA_QAM__B)); + if (status < 0) + break; + status = Write16_0(state, IQM_CF_SYMMETRIC__A, 0); + if (status < 0) + break; + status = Write16_0(state, IQM_CF_MIDTAP__A, ((1 << IQM_CF_MIDTAP_RE__B) | (1 << IQM_CF_MIDTAP_IM__B))); + if (status < 0) + break; + + status = Write16_0(state, IQM_RC_STRETCH__A, 21); + if (status < 0) + break; + status = Write16_0(state, IQM_AF_CLP_LEN__A, 0); + if (status < 0) + break; + status = Write16_0(state, IQM_AF_CLP_TH__A, 448); + if (status < 0) + break; + status = Write16_0(state, IQM_AF_SNS_LEN__A, 0); + if (status < 0) + break; + status = Write16_0(state, IQM_CF_POW_MEAS_LEN__A, 0); + if (status < 0) + break; + + status = Write16_0(state, IQM_FS_ADJ_SEL__A, 1); + if (status < 0) + break; + status = Write16_0(state, IQM_RC_ADJ_SEL__A, 1); + if (status < 0) + break; + status = Write16_0(state, IQM_CF_ADJ_SEL__A, 1); + if (status < 0) + break; + status = Write16_0(state, IQM_AF_UPD_SEL__A, 0); + if (status < 0) + break; /* IQM Impulse Noise Processing Unit */ - CHK_ERROR(Write16_0(state, IQM_CF_CLP_VAL__A, 500)); - CHK_ERROR(Write16_0(state, IQM_CF_DATATH__A, 1000)); - CHK_ERROR(Write16_0(state, IQM_CF_BYPASSDET__A, 1)); - CHK_ERROR(Write16_0(state, IQM_CF_DET_LCT__A, 0)); - CHK_ERROR(Write16_0(state, IQM_CF_WND_LEN__A, 1)); - CHK_ERROR(Write16_0(state, IQM_CF_PKDTH__A, 1)); - CHK_ERROR(Write16_0(state, IQM_AF_INC_BYPASS__A, 1)); + status = Write16_0(state, IQM_CF_CLP_VAL__A, 500); + if (status < 0) + break; + status = Write16_0(state, IQM_CF_DATATH__A, 1000); + if (status < 0) + break; + status = Write16_0(state, IQM_CF_BYPASSDET__A, 1); + if (status < 0) + break; + status = Write16_0(state, IQM_CF_DET_LCT__A, 0); + if (status < 0) + break; + status = Write16_0(state, IQM_CF_WND_LEN__A, 1); + if (status < 0) + break; + status = Write16_0(state, IQM_CF_PKDTH__A, 1); + if (status < 0) + break; + status = Write16_0(state, IQM_AF_INC_BYPASS__A, 1); + if (status < 0) + break; /* turn on IQMAF. Must be done before setAgc**() */ - CHK_ERROR(SetIqmAf(state, true)); - CHK_ERROR(Write16_0(state, IQM_AF_START_LOCK__A, 0x01)); + status = SetIqmAf(state, true); + if (status < 0) + break; + status = Write16_0(state, IQM_AF_START_LOCK__A, 0x01); + if (status < 0) + break; /* IQM will not be reset from here, sync ADC and update/init AGC */ - CHK_ERROR(ADCSynchronization(state)); + status = ADCSynchronization(state); + if (status < 0) + break; /* Set the FSM step period */ - CHK_ERROR(Write16_0 - (state, SCU_RAM_QAM_FSM_STEP_PERIOD__A, 2000)); + status = Write16_0(state, SCU_RAM_QAM_FSM_STEP_PERIOD__A, 2000); + if (status < 0) + break; /* Halt SCU to enable safe non-atomic accesses */ - CHK_ERROR(Write16_0 - (state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_HOLD)); + status = Write16_0(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_HOLD); + if (status < 0) + break; /* No more resets of the IQM, current standard correctly set => now AGCs can be configured. */ - CHK_ERROR(InitAGC(state, true)); - CHK_ERROR(SetPreSaw(state, &(state->m_qamPreSawCfg))); + status = InitAGC(state, true); + if (status < 0) + break; + status = SetPreSaw(state, &(state->m_qamPreSawCfg)); + if (status < 0) + break; /* Configure AGC's */ - CHK_ERROR(SetAgcRf(state, &(state->m_qamRfAgcCfg), true)); - CHK_ERROR(SetAgcIf(state, &(state->m_qamIfAgcCfg), true)); + status = SetAgcRf(state, &(state->m_qamRfAgcCfg), true); + if (status < 0) + break; + status = SetAgcIf(state, &(state->m_qamIfAgcCfg), true); + if (status < 0) + break; /* Activate SCU to enable SCU commands */ - CHK_ERROR(Write16_0 - (state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE)); + status = Write16_0(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE); + if (status < 0) + break; } while (0); return status; } @@ -4805,32 +5621,39 @@ static int WriteGPIO(struct drxk_state *state) do { /* stop lock indicator process */ - CHK_ERROR(Write16_0(state, SCU_RAM_GPIO__A, - SCU_RAM_GPIO_HW_LOCK_IND_DISABLE)); + status = Write16_0(state, SCU_RAM_GPIO__A, SCU_RAM_GPIO_HW_LOCK_IND_DISABLE); + if (status < 0) + break; /* Write magic word to enable pdr reg write */ - CHK_ERROR(Write16_0(state, SIO_TOP_COMM_KEY__A, - SIO_TOP_COMM_KEY_KEY)); + status = Write16_0(state, SIO_TOP_COMM_KEY__A, SIO_TOP_COMM_KEY_KEY); + if (status < 0) + break; if (state->m_hasSAWSW) { /* write to io pad configuration register - output mode */ - CHK_ERROR(Write16_0(state, SIO_PDR_SMA_TX_CFG__A, - state->m_GPIOCfg)); + status = Write16_0(state, SIO_PDR_SMA_TX_CFG__A, state->m_GPIOCfg); + if (status < 0) + break; /* use corresponding bit in io data output registar */ - CHK_ERROR(Read16_0 - (state, SIO_PDR_UIO_OUT_LO__A, &value)); + status = Read16_0(state, SIO_PDR_UIO_OUT_LO__A, &value); + if (status < 0) + break; if (state->m_GPIO == 0) value &= 0x7FFF; /* write zero to 15th bit - 1st UIO */ else value |= 0x8000; /* write one to 15th bit - 1st UIO */ /* write back to io data output register */ - CHK_ERROR(Write16_0 - (state, SIO_PDR_UIO_OUT_LO__A, value)); + status = Write16_0(state, SIO_PDR_UIO_OUT_LO__A, value); + if (status < 0) + break; } /* Write magic word to disable pdr reg write */ - CHK_ERROR(Write16_0(state, SIO_TOP_COMM_KEY__A, 0x0000)); + status = Write16_0(state, SIO_TOP_COMM_KEY__A, 0x0000); + if (status < 0) + break; } while (0); return status; } @@ -4874,18 +5697,25 @@ static int PowerDownDevice(struct drxk_state *state) do { if (state->m_bPDownOpenBridge) { /* Open I2C bridge before power down of DRXK */ - CHK_ERROR(ConfigureI2CBridge(state, true)); + status = ConfigureI2CBridge(state, true); + if (status < 0) + break; } /* driver 0.9.0 */ - CHK_ERROR(DVBTEnableOFDMTokenRing(state, false)); + status = DVBTEnableOFDMTokenRing(state, false); + if (status < 0) + break; - CHK_ERROR(Write16_0 - (state, SIO_CC_PWD_MODE__A, - SIO_CC_PWD_MODE_LEVEL_CLOCK)); - CHK_ERROR(Write16_0 - (state, SIO_CC_UPDATE__A, SIO_CC_UPDATE_KEY)); + status = Write16_0(state, SIO_CC_PWD_MODE__A, SIO_CC_PWD_MODE_LEVEL_CLOCK); + if (status < 0) + break; + status = Write16_0(state, SIO_CC_UPDATE__A, SIO_CC_UPDATE_KEY); + if (status < 0) + break; state->m_HICfgCtrl |= SIO_HI_RA_RAM_PAR_5_CFG_SLEEP_ZZZ; - CHK_ERROR(HI_CfgCommand(state)); + status = HI_CfgCommand(state); + if (status < 0) + break; } while (0); if (status < 0) @@ -4920,20 +5750,25 @@ static int init_drxk(struct drxk_state *state) if ((state->m_DrxkState == DRXK_UNINITIALIZED)) { do { - CHK_ERROR(PowerUpDevice(state)); - CHK_ERROR(DRXX_Open(state)); + status = PowerUpDevice(state); + if (status < 0) + break; + status = DRXX_Open(state); + if (status < 0) + break; /* Soft reset of OFDM-, sys- and osc-clockdomain */ - CHK_ERROR(Write16_0(state, SIO_CC_SOFT_RST__A, - SIO_CC_SOFT_RST_OFDM__M | - SIO_CC_SOFT_RST_SYS__M | - SIO_CC_SOFT_RST_OSC__M)); - CHK_ERROR(Write16_0 - (state, SIO_CC_UPDATE__A, - SIO_CC_UPDATE_KEY)); + status = Write16_0(state, SIO_CC_SOFT_RST__A, SIO_CC_SOFT_RST_OFDM__M | SIO_CC_SOFT_RST_SYS__M | SIO_CC_SOFT_RST_OSC__M); + if (status < 0) + break; + status = Write16_0(state, SIO_CC_UPDATE__A, SIO_CC_UPDATE_KEY); + if (status < 0) + break; /* TODO is this needed, if yes how much delay in worst case scenario */ msleep(1); state->m_DRXK_A3_PATCH_CODE = true; - CHK_ERROR(GetDeviceCapabilities(state)); + status = GetDeviceCapabilities(state); + if (status < 0) + break; /* Bridge delay, uses oscilator clock */ /* Delay = (delay (nano seconds) * oscclk (kHz))/ 1000 */ @@ -4952,69 +5787,79 @@ static int init_drxk(struct drxk_state *state) state->m_HICfgBridgeDelay << SIO_HI_RA_RAM_PAR_3_CFG_DBL_SCL__B; - CHK_ERROR(InitHI(state)); + status = InitHI(state); + if (status < 0) + break; /* disable various processes */ #if NOA1ROM if (!(state->m_DRXK_A1_ROM_CODE) && !(state->m_DRXK_A2_ROM_CODE)) #endif { - CHK_ERROR(Write16_0 - (state, SCU_RAM_GPIO__A, - SCU_RAM_GPIO_HW_LOCK_IND_DISABLE)); + status = Write16_0(state, SCU_RAM_GPIO__A, SCU_RAM_GPIO_HW_LOCK_IND_DISABLE); + if (status < 0) + break; } /* disable MPEG port */ - CHK_ERROR(MPEGTSDisable(state)); + status = MPEGTSDisable(state); + if (status < 0) + break; /* Stop AUD and SCU */ - CHK_ERROR(Write16_0 - (state, AUD_COMM_EXEC__A, - AUD_COMM_EXEC_STOP)); - CHK_ERROR(Write16_0 - (state, SCU_COMM_EXEC__A, - SCU_COMM_EXEC_STOP)); + status = Write16_0(state, AUD_COMM_EXEC__A, AUD_COMM_EXEC_STOP); + if (status < 0) + break; + status = Write16_0(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_STOP); + if (status < 0) + break; /* enable token-ring bus through OFDM block for possible ucode upload */ - CHK_ERROR(Write16_0 - (state, SIO_OFDM_SH_OFDM_RING_ENABLE__A, - SIO_OFDM_SH_OFDM_RING_ENABLE_ON)); + status = Write16_0(state, SIO_OFDM_SH_OFDM_RING_ENABLE__A, SIO_OFDM_SH_OFDM_RING_ENABLE_ON); + if (status < 0) + break; /* include boot loader section */ - CHK_ERROR(Write16_0 - (state, SIO_BL_COMM_EXEC__A, - SIO_BL_COMM_EXEC_ACTIVE)); - CHK_ERROR(BLChainCmd(state, 0, 6, 100)); + status = Write16_0(state, SIO_BL_COMM_EXEC__A, SIO_BL_COMM_EXEC_ACTIVE); + if (status < 0) + break; + status = BLChainCmd(state, 0, 6, 100); + if (status < 0) + break; #if 0 if (state->m_DRXK_A3_PATCH_CODE) - CHK_ERROR(DownloadMicrocode(state, - DRXK_A3_microcode, - DRXK_A3_microcode_length)); + status = DownloadMicrocode(state, DRXK_A3_microcode, DRXK_A3_microcode_length); + if (status < 0) + break; #else load_microcode(state, "drxk_a3.mc"); #endif #if NOA1ROM if (state->m_DRXK_A2_PATCH_CODE) - CHK_ERROR(DownloadMicrocode(state, - DRXK_A2_microcode, - DRXK_A2_microcode_length)); + status = DownloadMicrocode(state, DRXK_A2_microcode, DRXK_A2_microcode_length); + if (status < 0) + break; #endif /* disable token-ring bus through OFDM block for possible ucode upload */ - CHK_ERROR(Write16_0 - (state, SIO_OFDM_SH_OFDM_RING_ENABLE__A, - SIO_OFDM_SH_OFDM_RING_ENABLE_OFF)); + status = Write16_0(state, SIO_OFDM_SH_OFDM_RING_ENABLE__A, SIO_OFDM_SH_OFDM_RING_ENABLE_OFF); + if (status < 0) + break; /* Run SCU for a little while to initialize microcode version numbers */ - CHK_ERROR(Write16_0 - (state, SCU_COMM_EXEC__A, - SCU_COMM_EXEC_ACTIVE)); - CHK_ERROR(DRXX_Open(state)); + status = Write16_0(state, SCU_COMM_EXEC__A, SCU_COMM_EXEC_ACTIVE); + if (status < 0) + break; + status = DRXX_Open(state); + if (status < 0) + break; /* added for test */ msleep(30); powerMode = DRXK_POWER_DOWN_OFDM; - CHK_ERROR(CtrlPowerMode(state, &powerMode)); + status = CtrlPowerMode(state, &powerMode); + if (status < 0) + break; /* Stamp driver version number in SCU data RAM in BCD code Done to enable field application engineers to retreive drxdriver version @@ -5027,17 +5872,17 @@ static int init_drxk(struct drxk_state *state) (((DRXK_VERSION_MAJOR / 10) % 10) << 8) + ((DRXK_VERSION_MAJOR % 10) << 4) + (DRXK_VERSION_MINOR % 10); - CHK_ERROR(Write16_0 - (state, SCU_RAM_DRIVER_VER_HI__A, - driverVersion)); + status = Write16_0(state, SCU_RAM_DRIVER_VER_HI__A, driverVersion); + if (status < 0) + break; driverVersion = (((DRXK_VERSION_PATCH / 1000) % 10) << 12) + (((DRXK_VERSION_PATCH / 100) % 10) << 8) + (((DRXK_VERSION_PATCH / 10) % 10) << 4) + (DRXK_VERSION_PATCH % 10); - CHK_ERROR(Write16_0 - (state, SCU_RAM_DRIVER_VER_LO__A, - driverVersion)); + status = Write16_0(state, SCU_RAM_DRIVER_VER_LO__A, driverVersion); + if (status < 0) + break; printk(KERN_INFO "DRXK driver version %d.%d.%d\n", DRXK_VERSION_MAJOR, DRXK_VERSION_MINOR, @@ -5051,27 +5896,39 @@ static int init_drxk(struct drxk_state *state) /* m_dvbtRfAgcCfg.speed = 3; */ /* Reset driver debug flags to 0 */ - CHK_ERROR(Write16_0 - (state, SCU_RAM_DRIVER_DEBUG__A, 0)); + status = Write16_0(state, SCU_RAM_DRIVER_DEBUG__A, 0); + if (status < 0) + break; /* driver 0.9.0 */ /* Setup FEC OC: NOTE: No more full FEC resets allowed afterwards!! */ - CHK_ERROR(Write16_0 - (state, FEC_COMM_EXEC__A, - FEC_COMM_EXEC_STOP)); + status = Write16_0(state, FEC_COMM_EXEC__A, FEC_COMM_EXEC_STOP); + if (status < 0) + break; /* MPEGTS functions are still the same */ - CHK_ERROR(MPEGTSDtoInit(state)); - CHK_ERROR(MPEGTSStop(state)); - CHK_ERROR(MPEGTSConfigurePolarity(state)); - CHK_ERROR(MPEGTSConfigurePins - (state, state->m_enableMPEGOutput)); + status = MPEGTSDtoInit(state); + if (status < 0) + break; + status = MPEGTSStop(state); + if (status < 0) + break; + status = MPEGTSConfigurePolarity(state); + if (status < 0) + break; + status = MPEGTSConfigurePins(state, state->m_enableMPEGOutput); + if (status < 0) + break; /* added: configure GPIO */ - CHK_ERROR(WriteGPIO(state)); + status = WriteGPIO(state); + if (status < 0) + break; state->m_DrxkState = DRXK_STOPPED; if (state->m_bPowerDown) { - CHK_ERROR(PowerDownDevice(state)); + status = PowerDownDevice(state); + if (status < 0) + break; state->m_DrxkState = DRXK_POWERED_DOWN; } else state->m_DrxkState = DRXK_STOPPED; diff --git a/drivers/media/dvb/frontends/tda18271c2dd.c b/drivers/media/dvb/frontends/tda18271c2dd.c index a8afc221272..7f526143ba4 100644 --- a/drivers/media/dvb/frontends/tda18271c2dd.c +++ b/drivers/media/dvb/frontends/tda18271c2dd.c @@ -817,7 +817,7 @@ static int ChannelConfiguration(struct tda_state *state, u8 BP_Filter = 0; u8 RF_Band = 0; u8 GainTaper = 0; - u8 IR_Meas; + u8 IR_Meas = 0; state->IF = IntermediateFrequency; /* printk("%s Freq = %d Standard = %d IF = %d\n", __func__, Frequency, Standard, IntermediateFrequency); */ @@ -884,7 +884,7 @@ static int ChannelConfiguration(struct tda_state *state, state->m_Regs[EB4] &= ~0x20; /* LO_forceSrce = 0 */ CHK_ERROR(UpdateReg(state, EB4)); } else { - u8 PostDiv; + u8 PostDiv = 0; u8 Div; CHK_ERROR(CalcCalPLL(state, Frequency + IntermediateFrequency)); |