return 1;
        }
 
+       if (state->config->set_lock_led)
+               state->config->set_lock_led(fe, *status == 0 ? 0 : 1);
+
        dprintk("%s: status = 0x%02x\n", __func__, lock);
 
        return 0;
 static void ds3000_release(struct dvb_frontend *fe)
 {
        struct ds3000_state *state = fe->demodulator_priv;
+
+       if (state->config->set_lock_led)
+               state->config->set_lock_led(fe, 0);
+
        dprintk("%s\n", __func__);
        kfree(state);
 }
 
 static enum dvbfe_algo ds3000_get_algo(struct dvb_frontend *fe)
 {
+       struct ds3000_state *state = fe->demodulator_priv;
+
+       if (state->config->set_lock_led)
+               state->config->set_lock_led(fe, 0);
+
        dprintk("%s()\n", __func__);
        return DVBFE_ALGO_HW;
 }
 
        u8 ci_mode;
        /* Set device param to start dma */
        int (*set_ts_params)(struct dvb_frontend *fe, int is_punctured);
+       /* Hook for Lock LED */
+       void (*set_lock_led)(struct dvb_frontend *fe, int offon);
 };
 
 #if defined(CONFIG_DVB_DS3000) || \
 
        .tuner_address = 0x60,
 };
 
+static struct ds3000_config s660_ds3000_config = {
+       .demod_address = 0x68,
+       .set_lock_led = dw210x_led_ctrl,
+};
+
 static struct stv0900_config dw2104a_stv0900_config = {
        .demod_address = 0x6a,
        .demod_mode = 0,
        struct s6x0_state *st = (struct s6x0_state *)d->dev->priv;
        u8 obuf[] = {7, 1};
 
-       d->fe_adap[0].fe = dvb_attach(ds3000_attach, &dw2104_ds3000_config,
+       d->fe_adap[0].fe = dvb_attach(ds3000_attach, &s660_ds3000_config,
                        &d->dev->i2c_adap);
 
        if (d->fe_adap[0].fe == NULL)