kernelnewbies.kernelnewbies.org archive mirror
 help / color / mirror / Atom feed
From: greg@kroah.com (Greg KH)
To: kernelnewbies@lists.kernelnewbies.org
Subject: Driver to allow DMA from user space
Date: Sun, 25 Dec 2016 13:37:03 +0100	[thread overview]
Message-ID: <20161225123703.GB11659@kroah.com> (raw)
In-Reply-To: <CAJ2oMhJUHpk-DS+_u8bKYSxELHOha3HYFzs+fE=4CsnjvHGuKg@mail.gmail.com>

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?

thanks,

greg k-h

  reply	other threads:[~2016-12-25 12:37 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 [this message]
2016-12-30 18:11           ` Ran Shalit
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=20161225123703.GB11659@kroah.com \
    --to=greg@kroah.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).