From: ranshalit@gmail.com (Ran Shalit)
To: kernelnewbies@lists.kernelnewbies.org
Subject: Driver to allow DMA from user space
Date: Fri, 30 Dec 2016 20:11:56 +0200 [thread overview]
Message-ID: <CAJ2oMh+CEfwN6T8RLa0bSXtwvQH-1t8pr-Pqe8S5fLnqmtW7Yw@mail.gmail.com> (raw)
In-Reply-To: <20161225123703.GB11659@kroah.com>
On Sun, Dec 25, 2016 at 2:37 PM, Greg KH <greg@kroah.com> wrote:
> On Sat, Dec 24, 2016 at 05:47:19PM +0200, Ran Shalit wrote:
>>
>>
>> On Tue, Dec 20, 2016 at 12:26 PM, Greg KH <greg@kroah.com> wrote:
>>
>> On Tue, Dec 20, 2016 at 12:15:22PM +0200, Ran Shalit wrote:
>> > On Tue, Dec 20, 2016 at 11:38 AM, Greg KH <greg@kroah.com> wrote:
>> > > On Mon, Dec 19, 2016 at 06:08:47PM +0200, Ran Shalit wrote:
>> > >> Hello,
>> > >>
>> > >> I want to use DMA from userspace.
>> > >
>> > > Why?
>> >
>> > Hi Greg,
>> >
>> > We want that a userspace layer (a library) will do some HW related
>> issues.
>> > We have a memory mapped space (from FPGA), so we think it will be
>> > easier, and I think also more correct way , that we create the driver,
>> > and interact hadrware using the mapped memory space, and also do the
>> > protocols in userspace. The only thing that is less easy in userspace
>> > is using interrupt, and dma. but that is also possible if we just wrap
>> > the dma, and interrupt in a character device (or use uio as you
>> > suggested below).
>> > >
>> > >> I already use dma in kernel, and now I want can create a character
>> > >> device which will be responsible for this.
>> > >
>> > > Why?
>> > >
>> > >> The only problem is that I want to use the same memory which was
>> > >> allocated in kernel with dma_alloc_coherent.
>> > >
>> > > Why?
>> >
>> > in kernel we use dma_alloc_coherent, which returns contiguous memory.
>> > As I understand, we can mmap in userspace the returned physical
>> > address, and use the returned virtual address in userspace.
>> >
>> >
>> > >
>> > >> Is it correct to use mmap in order to use the phsyical memory which
>> > >> was allocated with dma_alloc_coherent ?
>> > >>
>> > >> If it's that simple it can be surely helpful, and the simple driver
>> > >> which wraps dma_alloc_coherent can do the job for dmaing from
>> > >> userspace.
>> > >
>> > > Have you looked at the uio driver interface?
>> > >
>> > > But again, why? What problem are you trying to solve here?
>> >
>> > We need to do some interaction with HW , but since most of the HW is
>> > mapped to physical address (FPGA), it seem simpler to do that in
>> > userspace (HW library), instead of doing this in kernel. What do you
>> > think ?
>>
>> I think you should use the UIO driver api, as that's exactly what it was
>> written for. Have you looked at it yet? It handles your interrupt
>> logic for you.
>>
>>
>> Hello,
>>
>> If I may please ask, I made some reading about uio, but didn't yet
understand
>> what's the benefit of using uio instead of creating a character device ?
>
> It's a lot less work than writing a custom char driver that will not be
> accepted upstream because you are not using the expected UIO api
> interface :)
>
> Writing a UIO driver should be very simple, and very small, all of the
> framework is already done, in a correct way, why would you _not_ want to
> use the UIO interface?
>
Hi,
UIO drivers seems like a good choice in my case, I am familiar with
generic-uio interface in devicetree.
Just for my understanding, I am trying to understand the difference between
writing a small character device which notifies the interrupt, to using uio
interface.
Is there any advantage of using uio over the the small chracter device?(I
am sure there is. I just do not know it yet)
Another question, in performance terms which is better: uio driver or
kernel driver?
Thank you,
Ran
> thanks,
>
> greg k-h
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://lists.kernelnewbies.org/pipermail/kernelnewbies/attachments/20161230/40d3c481/attachment.html
next prev parent reply other threads:[~2016-12-30 18:11 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-12-19 16:08 Driver to allow DMA from user space Ran Shalit
2016-12-20 9:38 ` Greg KH
2016-12-20 10:15 ` Ran Shalit
2016-12-20 10:26 ` Greg KH
2016-12-24 15:47 ` Ran Shalit
2016-12-25 12:37 ` Greg KH
2016-12-30 18:11 ` Ran Shalit [this message]
2016-12-31 10:55 ` Greg KH
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=CAJ2oMh+CEfwN6T8RLa0bSXtwvQH-1t8pr-Pqe8S5fLnqmtW7Yw@mail.gmail.com \
--to=ranshalit@gmail.com \
--cc=kernelnewbies@lists.kernelnewbies.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).