Query on workqueue

Richard Maciel Costa richard.costa.sidi at gmail.com
Tue Jan 13 12:21:28 EST 2015


Hi Victor,

I don't think it's a good idea to block an entire IRQ line for so much time
(i.e. until a work queue runs), unless you're sure you're the sole user of
it.

How about you try a more traditional approach and make the IRQ handler
schedule a work queue after it completes?

Or, if you need to run as fast as possible, why don't you create a tasklet?
Remember that you can't sleep in this case.

- Richard

2015-01-13 11:51 GMT-02:00 Victor Ascroft <victorascroft at gmail.com>:

> Hello,
>
> Is it ok to use wait_for_completion in a workqueue?
>
> static void my_work(struct work_struct *work)
> {
>
>         while (true)
>         {
>                 wait_for_completion(completion);
>
>                 // Do something here
>
>                 reinit_completion(completion);
>                 enable_irq(irq);
>         }
> }
>
> static irqreturn_t my_irq_handler(int irq, void *dev)
> {
>         disable_irq(irq);
>
>         complete(completion);
>
>         return IRQ_HANDLED;
> }
>
> Something like the above is what I have. Is it a correct way to
> do things or complete idiotic brainfart. Workqueues can sleep so
> I thought of the above code, but, was not sure.
>
> And I am not using _interruptible or _interruptible_timeout because
> I absolutely want it to wait for the IRQ. Now as such though this
> works I get stack traces with hung task complaining and I have
> to set /proc/sys/kernel/hung_task_timeout_secs to 0. And were the IRQ
> not generated I do get NMI watchdog hang.
>
> I will accept I have only little knowledge of these things.
>
> Regards,
> Victor.
>
> _______________________________________________
> Kernelnewbies mailing list
> Kernelnewbies at kernelnewbies.org
> http://lists.kernelnewbies.org/mailman/listinfo/kernelnewbies
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://lists.kernelnewbies.org/pipermail/kernelnewbies/attachments/20150113/7d9f9e92/attachment.html 


More information about the Kernelnewbies mailing list