[RFCv2 PATCH 3/9] v4l: vb2: Add dma-contig allocator as dma_buf user
Laurent Pinchart
laurent.pinchart at ideasonboard.com
Wed Mar 28 08:50:18 PDT 2012
Hi Tomasz,
On Monday 26 March 2012 17:53:09 Tomasz Stanislawski wrote:
> On 03/22/2012 12:04 PM, Laurent Pinchart wrote:
> > On Tuesday 13 March 2012 11:17:01 Tomasz Stanislawski wrote:
[snip]
> >> +static void vb2_dc_detach_dmabuf(void *mem_priv)
> >> +{
> >> + struct vb2_dc_buf *buf = mem_priv;
> >> +
> >> + if (buf->dma_addr)
> >> + vb2_dc_unmap_dmabuf(buf);
> >
> > Can detach() be called with the buffer still mapped() ? Wouldn't that be a
> > bug in the caller ?
>
> No, it is not. The functions from vb2_dc_*_dmabuf are called by vb2-core.
> It is not a part of DMABUF API itself. Therefore usage can be a bit
> different. Please refer to the function __qbuf_dmabuf function vb2-core. If
> new DMABUF is passed to in the QBUF then old DMABUF is released by calling
> detach_dmabuf without unmap. However, this part of code is probably not
> reachable if the buffer was not dequeued.
>
> Detach without unmap may happen in a case of closing a video fd
> without prior dequeuing of all buffers.
>
> Do you think it would be a good idea to move a call map_dmabuf to
> __enqueue_in_driver and add calling unmap_dmabuf to vb2_buffer_done?
That's hard to tell. From the DRM point of view, I expect that you will be
asked to keep the buffer mapped for as little time as possible. This is a sane
behaviour, but will have a performance impact as we will have to constantly
map/unmap buffers. From a V4L2 point of view I would prefer keeping the
mappins when possible. This topic has already been discussed, and we haven't
reached any consensus yet as far as I know :-/
> >> +
> >> + /* detach this attachment */
> >> + dma_buf_detach(buf->db_attach->dmabuf, buf->db_attach);
> >> + kfree(buf);
> >> +}
> >
> > There's nothing allocator-specific in the attach/detach operations.
> > Shouldn't they be moved to the vb2 core ?
>
> Calling dma_buf_attach could be moved to vb2-core. But it gives little gain.
> First, the pointer of dma_buf_attachment would have to be added to struct
> vb2_plane. Second, the allocator would have to keep in the copy of this
> pointer in its context structure for use of vb2_dc_(un)map_dmabuf
> functions.
Right. Would it make sense to pass the vb2_plane pointer, or possibly the
dma_buf_attachment pointer, to the mmap_dmabuf and unmap_dmabuf operations ?
> Third, dma_buf_attach requires a pointer to 'struct device' which is not
> available in the vb2-core layer.
OK, that's a problem.
> Because of the mentioned reasons I decided to keep attach_dmabuf in
> allocator-specific code.
Maybe it would make sense to create a vb2_mem_buf structure from which
vb2_dc_buf (and other allocator-specific buffer descriptors) would inherit ?
That structure would store the dma_buf_attach pointer, and common dma-buf code
could be put in videobuf2-memops.c and shared between allocators. Just an
idea.
--
Regards,
Laurent Pinchart
More information about the dri-devel
mailing list