Use wait_event() instead of the deprecated sleep_on() function. Since wait_event() expects the condition passed in to be the stopping condition, negate the current one. Signed-off-by: Nishanth Aravamudan Signed-off-by: Domen Puncer --- kj-domen/arch/m68k/atari/stdma.c | 10 +++++----- 1 files changed, 5 insertions(+), 5 deletions(-) diff -puN arch/m68k/atari/stdma.c~wait_event-arch_m68k_atari_stdma arch/m68k/atari/stdma.c --- kj/arch/m68k/atari/stdma.c~wait_event-arch_m68k_atari_stdma 2005-03-02 10:43:41.000000000 +0100 +++ kj-domen/arch/m68k/atari/stdma.c 2005-03-02 10:43:41.000000000 +0100 @@ -34,6 +34,7 @@ #include #include #include +#include #include #include @@ -81,11 +82,10 @@ void stdma_lock(irqreturn_t (*handler)(i local_irq_save(flags); /* protect lock */ - while(stdma_locked) - /* Since the DMA is used for file system purposes, we - have to sleep uninterruptible (there may be locked - buffers) */ - sleep_on(&stdma_wait); + /* Since the DMA is used for file system purposes, we + have to sleep uninterruptible (there may be locked + buffers) */ + wait_event(stdma_wait, !stdma_locked); stdma_locked = 1; stdma_isr = handler; _