Hi, I've noticed that locking in drivers/media/dvb/frontends/dib9000.c is not correct: static int dib9000_fw_get_channel(...) { ... DibAcquireLock(&state->platform.risc.mem_mbx_lock); ... error: DibReleaseLock(&state->platform.risc.mem_mbx_lock); return ret; } #define DibAcquireLock(lock) do { if (mutex_lock_interruptible(lock) < 0) dprintk("could not get the lock"); } while (0) #define DibReleaseLock(lock) mutex_unlock(lock) 1) If mutex is not hold, then the critical section is not protected. 2) If mutex was not hold, then the code tries to release not holded mutex. This locking "style" is used all over the driver. Thanks, -- Vasiliy Kulikov http://www.openwall.com - bringing security into open computing environments -- To unsubscribe from this list: send the line "unsubscribe linux-media" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html