Re: Query on workqueue

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



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@xxxxxxxxx>:
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@xxxxxxxxxxxxxxxxx
http://lists.kernelnewbies.org/mailman/listinfo/kernelnewbies

_______________________________________________
Kernelnewbies mailing list
Kernelnewbies@xxxxxxxxxxxxxxxxx
http://lists.kernelnewbies.org/mailman/listinfo/kernelnewbies

[Index of Archives]     [Newbies FAQ]     [Linux Kernel Mentors]     [Linux Kernel Development]     [IETF Annouce]     [Git]     [Networking]     [Security]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux RAID]     [Linux SCSI]     [Linux ACPI]
  Powered by Linux