diff options
author | Christopher James Halse Rogers <christopher.halse.rogers@canonical.com> | 2013-09-10 02:06:45 -0400 |
---|---|---|
committer | Sumit Semwal <sumit.semwal@linaro.org> | 2013-09-10 02:06:45 -0400 |
commit | 19e8697ba45e7bcdb04f2adf6110fbf4882863e5 (patch) | |
tree | 249547a50a16d33e2c3c2dea96a592b2b823dc2b /Documentation | |
parent | 9022e24e8946400d53719a761815069c3183e2bd (diff) |
dma-buf: Expose buffer size to userspace (v2)
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>
Signed-off-by: Sumit Semwal <sumit.semwal@linaro.org>
Diffstat (limited to 'Documentation')
-rw-r--r-- | Documentation/dma-buf-sharing.txt | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/Documentation/dma-buf-sharing.txt b/Documentation/dma-buf-sharing.txt index e31a2a9d2b07..505e71172ae7 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: | |||
407 | interesting ways depending upong the exporter (if userspace starts depending | 407 | interesting ways depending upong the exporter (if userspace starts depending |
408 | upon this implicit synchronization). | 408 | upon this implicit synchronization). |
409 | 409 | ||
410 | Other Interfaces Exposed to Userspace on the dma-buf FD | ||
411 | ------------------------------------------------------ | ||
412 | |||
413 | - Since kernel 3.12 the dma-buf FD supports the llseek system call, but only | ||
414 | with offset=0 and whence=SEEK_END|SEEK_SET. SEEK_SET is supported to allow | ||
415 | the usual size discover pattern size = SEEK_END(0); SEEK_SET(0). Every other | ||
416 | llseek operation will report -EINVAL. | ||
417 | |||
418 | If llseek on dma-buf FDs isn't support the kernel will report -ESPIPE for all | ||
419 | cases. Userspace can use this to detect support for discovering the dma-buf | ||
420 | size using llseek. | ||
421 | |||
410 | Miscellaneous notes | 422 | Miscellaneous notes |
411 | ------------------- | 423 | ------------------- |
412 | 424 | ||