From: Martin Peres <martin.peres@free.fr>
To: Christopher James Halse Rogers
<christopher.halse.rogers@canonical.com>,
linux-arch@vger.kernel.org, linux-kernel@vger.kernel.org,
dri-devel@lists.freedesktop.org, linaro-mm-sig@lists.linaro.org,
robclark@gmail.com, linux-media@vger.kernel.org
Subject: Re: [PATCH] dma-buf: Expose buffer size to userspace (v2)
Date: Wed, 04 Sep 2013 14:29:24 +0200 [thread overview]
Message-ID: <522727A4.6050109@free.fr> (raw)
In-Reply-To: <20130904120504.GB28675@phenom.ffwll.local>
Le 04/09/2013 14:05, Daniel Vetter a écrit :
> On Wed, Sep 04, 2013 at 12:24:27PM +0200, Martin Peres wrote:
>> Hi Christopher,
>> Le 04/09/2013 05:15, Christopher James Halse Rogers a écrit :
>>> Each dma-buf has an associated size and it's reasonable for userspace
>>> to want to know what it is.
>>>
>>> Since userspace already has an fd, expose the size using the
>>> size = lseek(fd, SEEK_END, 0); lseek(fd, SEEK_CUR, 0);
>>> idiom.
>>>
>>> v2: Added Daniel's sugeested documentation, with minor fixups
>>>
>>> Signed-off-by: Christopher James Halse Rogers <christopher.halse.rogers@canonical.com>
>>> Reviewed-by: Daniel Vetter <daniel.vetter@ffwll.ch>
>>> Tested-by: Daniel Vetter <daniel.vetter@ffwll.ch>
>>> ---
>>> Documentation/dma-buf-sharing.txt | 12 ++++++++++++
>>> drivers/base/dma-buf.c | 28 ++++++++++++++++++++++++++++
>>> 2 files changed, 40 insertions(+)
>>>
>>> diff --git a/Documentation/dma-buf-sharing.txt b/Documentation/dma-buf-sharing.txt
>>> index 0b23261..849e982 100644
>>> --- a/Documentation/dma-buf-sharing.txt
>>> +++ b/Documentation/dma-buf-sharing.txt
>>> @@ -407,6 +407,18 @@ Being able to mmap an export dma-buf buffer object has 2 main use-cases:
>>> interesting ways depending upong the exporter (if userspace starts depending
>>> upon this implicit synchronization).
>>> +Other Interfaces Exposed to Userspace on the dma-buf FD
>>> +------------------------------------------------------
>>> +
>>> +- Since kernel 3.12 the dma-buf FD supports the llseek system call, but only
>>> + with offset=0 and whence=SEEK_END|SEEK_SET. SEEK_SET is supported to allow
>>> + the usual size discover pattern size = SEEK_END(0); SEEK_SET(0). Every other
>>> + llseek operation will report -EINVAL.
>>> +
>>> + If llseek on dma-buf FDs isn't support the kernel will report -ESPIPE for all
>> Shouldn't it be "supported" instead of "support"?
>>
>> Anyway, I'm just curious, in which case is it important to know the size?
>> Do we already have a way to get the dimensions (x, y and stripe)?
> Size is an invariant part of a dma-buf. Everything else wrt metadata isn't
> tracked in the kernel, so doesn't make much sense to expose it ;-)
> -Daniel
ACK, thanks Daniel.
prev parent reply other threads:[~2013-09-04 12:29 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-09-04 3:15 [PATCH] dma-buf: Expose buffer size to userspace (v2) Christopher James Halse Rogers
2013-09-04 10:24 ` Martin Peres
2013-09-04 12:05 ` Daniel Vetter
2013-09-04 12:29 ` Martin Peres [this message]
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=522727A4.6050109@free.fr \
--to=martin.peres@free.fr \
--cc=christopher.halse.rogers@canonical.com \
--cc=dri-devel@lists.freedesktop.org \
--cc=linaro-mm-sig@lists.linaro.org \
--cc=linux-arch@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-media@vger.kernel.org \
--cc=robclark@gmail.com \
/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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.