[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <1376483423-603-1-git-send-email-yexl@marvell.com>
Date: Wed, 14 Aug 2013 20:30:22 +0800
From: Xiaolong Ye <yexl@...vell.com>
To: <hjk@...sjkoch.de>, <greg@...ah.com>,
<linux-kernel@...r.kernel.org>
CC: Xiaolong Ye <yexl@...vell.com>
Subject: [PATCH] Add uio_sync_event interface to support mulit-instances case in UIO framework
Hi, guys,
Recently, we have met fake interrupt issue when using UIO as our vpu driver in mulit-instances case,
the issue can be described as below:
In multi-instances case, we use vpu_lock(semaphore) to implement the mutually exclusive access to the
device, each instace open uio device once and will be associated with a fd and its own uio_listener,
we use poll to wait for the hardware interrupt. So let's assume that there are two instances, A and B,
their uio_listener->event_count and idev->event are all 0 at the beginning, then A get the vpu_lock and start
to work, it will block at poll()(because listener->event_count == idev->count) until H/W interrupt happens
(atomic_inc(&idev->event)), after it releases vpu_lock, B will get the lock and start to work, however,
its poll will return immediately because B's uio_listener->event_count is 0 while idev->event has been 1,
that's how the fake interrupt happens.
Our proposal:
Add new uio_sync_event(struct uio_listener *listener) function in uio,c, so that we can call it directly
when we want to sync the event count.
Xiaolong Ye (1):
uio: add uio_event_sync interface
drivers/uio/uio.c | 12 ++++++++++++
include/linux/uio_driver.h | 1 +
2 files changed, 13 insertions(+)
--
1.7.9.5
--
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