I am designing a linux driver for a DVB/ASI PCI card.
One of the IOCTL commands implemented in my driver allows the user to
transfer a buffer to the PCI card (using DMA). While the DMA is in progress
I want to sleep the user process/thread. For the sleeping I use the
wait_event function, which waits for an event that is 'fired' from the DMA
done interrupt (with wake_up call). As soon as the interrupt handler calls
the wake_up my system freezes completely, without any Oops or other
exception message.
As far as I can gather from the linux device driver book and other sources
from drivers it is common practice to use a wake_up in the interrupt routine
to awaken any sleeping user threads. I am pretty sure that I have
initialised my wait_queue_head_t correctly with a call to
init_waitqueue_head.
Does anyone have any idea why the system hangs on the wake-up from the
interrupt handler?
Below you will find some pseudo code for with the wait_event and the
wake_up:
// wait from DMA IOCTL handler
void Dta1xxTxIoCtlDma()
{
startdma();
wait_event(my_wait_queue, ( 1==dma_done_flag) );
return;
}
// wake_up from interrupt handler
void Dta1xxIRQ()
{
if ( IsDmaDoneInterruptSet() ) {
dma_done_flag = 1;
wake_up(&my_wait_queue);
}
}
I am using linux kernel version 2.4.18.
Regards,
Maarten
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/