dvb_frontend_invoke_release(fe, fe->ops.release_sec);
        dvb_frontend_invoke_release(fe, fe->ops.tuner_ops.release);
        dvb_frontend_invoke_release(fe, fe->ops.analog_ops.release);
+       dvb_frontend_invoke_release(fe, fe->ops.detach);
        dvb_frontend_invoke_release(fe, fe->ops.release);
 }
 EXPORT_SYMBOL(dvb_frontend_detach);
 
  *
  * @info:              embedded struct dvb_tuner_info with tuner properties
  * @delsys:            Delivery systems supported by the frontend
- * @release:           callback function called when frontend is dettached.
+ * @detach:            callback function called when frontend is detached.
+ *                     drivers should clean up, but not yet free the struct
+ *                     dvb_frontend allocation.
+ * @release:           callback function called when frontend is ready to be
+ *                     freed.
  *                     drivers should free any allocated memory.
  * @release_sec:       callback function requesting that the Satelite Equipment
  *                     Control (SEC) driver to release and free any memory
 
        u8 delsys[MAX_DELSYS];
 
+       void (*detach)(struct dvb_frontend *fe);
        void (*release)(struct dvb_frontend* fe);
        void (*release_sec)(struct dvb_frontend* fe);