[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <CAG0bkvJJZMH__6SL4D+72D7yUBh07dJuiq=dcA-yRN3cRkBRFg@mail.gmail.com>
Date: Mon, 9 Mar 2015 12:29:26 +0530
From: Naveen Kumar Parna <pnaveenkos@...il.com>
To: Michal Hocko <mhocko@...e.cz>
Cc: linux-kernel@...r.kernel.org
Subject: Re: Synchronization mechanism between wait_for_completion_interruptible_timeout()
& complete()
I am having a PCIe device , it asserts two types if Tx interrupts i.e.
TX Queue count interrupt & TX Queue timer interrupt.
TX Queue count interrupt related to “TX Queue count register” : No. of
TXQ transactions to move from host before asserting TX Queue count
interrupt
TX Queue timer interrupt related to “TX Queue timer register”: Time
out value in uSec. The timeout covers the case where a burst of
transactions are sent but not enough to trigger the count interrupt.
I am getting lot many TX Queue timer interrupts for larger write
requests and the current driver implementation is calling complete()
API in both TX Queue count & timer interrupts. Here “x->done > 0”
because of multiple TX Queue timer interrupts.
Yes I agree with you. I need to correct driver write() function.
Thanks,
Naveen
On Fri, Mar 6, 2015 at 2:18 PM, Michal Hocko <mhocko@...e.cz> wrote:
> On Fri 06-03-15 14:04:53, Naveen Kumar Parna wrote:
>> Thanks Michal.
>>
>> Now I am clearing x->done to zero before
>> wait_for_completion_interruptible_timeout.
>
> You shouldn't touch this internal thing. Why would you want that
> anyway? If x->done > 0 then there has been something completed.
>
>> On Thu, Mar 5, 2015 at 6:53 PM, Michal Hocko <mhocko@...e.cz> wrote:
>> > On Wed 04-03-15 18:46:43, Naveen Kumar Parna wrote:
>> >> Hello,
>> >>
>> >> I have a question regarding the synchronization mechanism between
>> >> wait_for_completion_interruptible_timeout() & complete(). I used
>> >> complete() API in the ISR Tx interrupt path and
>> >> wait_for_completion_interruptible_timeout() in struct file_operations
>> >> .write method.
>> >>
>> >> Let assume a scenario in which Tx interrupt occurred and ISR called
>> >> complete() API before any process actually blocked at write method on
>> >> wait_for_completion_interruptible_timeout().
>> >>
>> >> After a few milli seconds, a process called write() API. Does it gets
>> >> blocked on wait_for_completion_interruptible_timeout() for completion
>> >> of a specific task to be signaled from new Tx interrupt?
>> >
>> > No, see do_wait_for_common resp. complete and x->done handling.
>> >
>> > --
>> > Michal Hocko
>> > SUSE Labs
>
> --
> Michal Hocko
> SUSE Labs
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists