Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751735AbbBKIHZ (ORCPT ); Wed, 11 Feb 2015 03:07:25 -0500 Received: from mailout1.w1.samsung.com ([210.118.77.11]:65380 "EHLO mailout1.w1.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751011AbbBKIHY (ORCPT ); Wed, 11 Feb 2015 03:07:24 -0500 X-AuditID: cbfec7f5-b7fc86d0000066b7-ac-54db0d268443 Message-id: <54DB0DB8.1010701@samsung.com> Date: Wed, 11 Feb 2015 09:07:20 +0100 From: Marek Szyprowski User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:31.0) Gecko/20100101 Thunderbird/31.4.0 MIME-version: 1.0 To: Ricardo Ribalda Delgado , Hans Verkuil , Pawel Osciak , Kyungmin Park , Mauro Carvalho Chehab , linux-media@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH 2/3] media/videobuf2-dma-contig: Fix handling of sg_table structure References: <1423498466-16718-1-git-send-email-ricardo.ribalda@gmail.com> <1423498466-16718-2-git-send-email-ricardo.ribalda@gmail.com> In-reply-to: <1423498466-16718-2-git-send-email-ricardo.ribalda@gmail.com> Content-type: text/plain; charset=utf-8; format=flowed Content-transfer-encoding: 7bit X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFtrOLMWRmVeSWpSXmKPExsVy+t/xK7pqvLdDDNZul7RY8nMXk8XZpjfs Fpd3zWGz6NmwldVi9bMKiylvf7JbdHXPY3Jg95jyeyOrx85Zd9k9Hv96yeaxpR/I6tuyitHj 8ya5ALYoLpuU1JzMstQifbsErowlZ9ewFlyUqPi3/TZLA+MW4S5GTg4JAROJg2tmsUDYYhIX 7q1n62Lk4hASWMoo8bRnNZTziVHi1fkbrCBVvAJaEpcX32AGsVkEVCW+XfvBBGKzCRhKdL3t YgOxRQViJN6t6mOGqBeU+DH5HgvIIBGBeUwSX17/YAdJCAtESqy58gdstZBAJ6PEo19gNqeA l8SnP/fBapgFzCS+vDzMCmHLS2xe85Z5AiP/LCRzZyEpm4WkbAEj8ypG0dTS5ILipPRcI73i xNzi0rx0veT83E2MkMD+uoNx6TGrQ4wCHIxKPLwWMbdChFgTy4orcw8xSnAwK4nwZr8BCvGm JFZWpRblxxeV5qQWH2Jk4uCUamDMPbaxJe5k6P3GordM2n5HnqppGf5KOmB/g3H7VhvR13Xi yxr/vourqbzIcO83e+PlNk+ON2VpylPaChuuW5aJMJrPXPfSN+rVNBOBBcYeui82tLhl1XVN PH3TuOH4qpSTV4uvKVeaVRXy/vBK2PtdMso8wGre36c5a2ba/b56w8b1pHd8n4oSS3FGoqEW c1FxIgAINdqRSgIAAA== Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3307 Lines: 96 Hello, On 2015-02-09 17:14, Ricardo Ribalda Delgado wrote: > when sg_alloc_table_from_pages() does not fail it returns a sg_table > structure with nents and nents_orig initialized to the same value. > > dma_map_sg returns the dma_map_sg returns the number of areas mapped > by the hardware, which could be different than the areas given as an input. > The output must be saved to nent. > Unfortunately nent differs in sign to the output of dma_map_sg, so an > intermediate value must be used. > > The output of dma_map, should be used to transverse the scatter list. > > dma_unmap_sg needs the value passed to dma_map_sg (nents_orig). > > sg_free_tables uses also orig_nent. > > This patch fix the file to follow this paradigm. > > Signed-off-by: Ricardo Ribalda Delgado > --- > drivers/media/v4l2-core/videobuf2-dma-contig.c | 10 ++++++---- > 1 file changed, 6 insertions(+), 4 deletions(-) > > diff --git a/drivers/media/v4l2-core/videobuf2-dma-contig.c b/drivers/media/v4l2-core/videobuf2-dma-contig.c > index b481d20..c7e4bdd 100644 > --- a/drivers/media/v4l2-core/videobuf2-dma-contig.c > +++ b/drivers/media/v4l2-core/videobuf2-dma-contig.c > @@ -56,7 +56,7 @@ static void vb2_dc_sgt_foreach_page(struct sg_table *sgt, > struct scatterlist *s; > unsigned int i; > > - for_each_sg(sgt->sgl, s, sgt->orig_nents, i) { > + for_each_sg(sgt->sgl, s, sgt->nents, i) { > struct page *page = sg_page(s); > unsigned int n_pages = PAGE_ALIGN(s->offset + s->length) > >> PAGE_SHIFT; This code iterates over memory pages added to the scatter list not the dma chunks, so orig_nents must be used. This change is not needed. > @@ -260,7 +260,7 @@ static int vb2_dc_dmabuf_ops_attach(struct dma_buf *dbuf, struct device *dev, > > rd = buf->sgt_base->sgl; > wr = sgt->sgl; > - for (i = 0; i < sgt->orig_nents; ++i) { > + for (i = 0; i < sgt->nents; ++i) { > sg_set_page(wr, sg_page(rd), rd->length, rd->offset); > rd = sg_next(rd); > wr = sg_next(wr); Same comment as for videobuf2-dma-sg.c patch. > @@ -324,6 +324,7 @@ static struct sg_table *vb2_dc_dmabuf_ops_map( > mutex_unlock(lock); > return ERR_PTR(-EIO); > } > + sgt->nents = ret; > > attach->dma_dir = dma_dir; > > @@ -669,13 +670,14 @@ static void *vb2_dc_get_userptr(void *alloc_ctx, unsigned long vaddr, > * No need to sync to the device, this will happen later when the > * prepare() memop is called. > */ > - sgt->nents = dma_map_sg_attrs(buf->dev, sgt->sgl, sgt->orig_nents, > + ret = dma_map_sg_attrs(buf->dev, sgt->sgl, sgt->orig_nents, > buf->dma_dir, &attrs); > - if (sgt->nents <= 0) { > + if (ret <= 0) { > pr_err("failed to map scatterlist\n"); > ret = -EIO; > goto fail_sgt_init; > } > + sgt->nents = ret; This one is okay, although the check for error could be simplified to a check for zero value. > > contig_size = vb2_dc_get_contiguous_size(sgt); > if (contig_size < size) { Best regards -- Marek Szyprowski, PhD Samsung R&D Institute Poland -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/