{
        struct stv *state = fe->tuner_priv;
        u32 index = (cutoff_frequency + 999999) / 1000000;
+       int stat = 0;
 
        if (index < 6)
                index = 6;
        state->reg[0x08] = (state->reg[0x08] & ~0xFC) | ((index - 6) << 2);
        state->reg[0x09] = (state->reg[0x09] & ~0x0C) | 0x08;
        if (fe->ops.i2c_gate_ctrl)
-               fe->ops.i2c_gate_ctrl(fe, 1);
-       write_regs(state, 0x08, 2);
-       wait_for_call_done(state, 0x08);
-       if (fe->ops.i2c_gate_ctrl)
+               stat = fe->ops.i2c_gate_ctrl(fe, 1);
+       if (!stat) {
+               write_regs(state, 0x08, 2);
+               wait_for_call_done(state, 0x08);
+       }
+       if (fe->ops.i2c_gate_ctrl && !stat)
                fe->ops.i2c_gate_ctrl(fe, 0);
-       return 0;
+       return stat;
 }
 
 static int set_lof(struct stv *state, u32 local_frequency, u32 cutoff_frequency)
        struct stv *state = fe->tuner_priv;
        struct dtv_frontend_properties *p = &fe->dtv_property_cache;
        u32 freq, cutoff;
+       int stat = 0;
 
        if (p->delivery_system != SYS_DVBS && p->delivery_system != SYS_DVBS2)
                return -EINVAL;
        cutoff = 5000000 + muldiv32(p->symbol_rate, 135, 200);
 
        if (fe->ops.i2c_gate_ctrl)
-               fe->ops.i2c_gate_ctrl(fe, 1);
-       set_lof(state, freq, cutoff);
-       if (fe->ops.i2c_gate_ctrl)
+               stat = fe->ops.i2c_gate_ctrl(fe, 1);
+       if (!stat)
+               set_lof(state, freq, cutoff);
+       if (fe->ops.i2c_gate_ctrl && !stat)
                fe->ops.i2c_gate_ctrl(fe, 0);
        return 0;
 }
        if ((state->reg[0x03] & 0x60) == 0) {
                /* RF Mode, Read AGC ADC */
                u8 reg = 0;
+               int stat = 0;
 
                if (fe->ops.i2c_gate_ctrl)
-                       fe->ops.i2c_gate_ctrl(fe, 1);
-               write_reg(state, 0x02, state->reg[0x02] | 0x20);
-               read_reg(state, 2, ®);
-               if (reg & 0x20)
+                       stat = fe->ops.i2c_gate_ctrl(fe, 1);
+               if (!stat) {
+                       write_reg(state, 0x02, state->reg[0x02] | 0x20);
                        read_reg(state, 2, ®);
-               if (fe->ops.i2c_gate_ctrl)
+                       if (reg & 0x20)
+                               read_reg(state, 2, ®);
+               }
+               if (fe->ops.i2c_gate_ctrl && !stat)
                        fe->ops.i2c_gate_ctrl(fe, 0);
 
                if ((state->reg[0x02] & 0x80) == 0)
                                    struct i2c_adapter *i2c, u8 adr)
 {
        struct stv *state;
-       int stat;
+       int stat = -ENODEV;
+       int gatestat = 0;
 
        state = kzalloc(sizeof(*state), GFP_KERNEL);
        if (!state)
        init_state(state);
 
        if (fe->ops.i2c_gate_ctrl)
-               fe->ops.i2c_gate_ctrl(fe, 1);
-       stat = attach_init(state);
-       if (fe->ops.i2c_gate_ctrl)
+               gatestat = fe->ops.i2c_gate_ctrl(fe, 1);
+       if (!gatestat)
+               stat = attach_init(state);
+       if (fe->ops.i2c_gate_ctrl && !gatestat)
                fe->ops.i2c_gate_ctrl(fe, 0);
        if (stat < 0) {
                kfree(state);