Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp1998026pxk; Tue, 1 Sep 2020 12:58:15 -0700 (PDT) X-Google-Smtp-Source: ABdhPJywW2wHFBhP+0wDvkuQA9QJ6b679VBzD27iLENIXpUOUH8/eVtHH9uGVWVpjccPjw95Yc04 X-Received: by 2002:a17:906:3e81:: with SMTP id a1mr3059850ejj.227.1598990295071; Tue, 01 Sep 2020 12:58:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1598990295; cv=none; d=google.com; s=arc-20160816; b=plUPlqbM6q9YkhdcrYm1EwEXz4Z3jzKtvGHUp2y17MHVqRTLDT8WmC3d5Z8hCuPaXA PhHN6m/nYsWqM2dd+K6KiDv/9X/SGJZpMAnyKQ0fDVFVY+xmZ7w7BbDh8j7x5YEz1MNp S1MllxfENRLe25rl1Vl8cqzL+WVVjp0Kpmyt1A/stwbFpMtAtzsjVkkxf7+YWG3lSFvt sG2T5PgIg+IxHQ4nSRTS7P84TDHUEkPexarpb1g/W0pStnCziIGq3DHqhY82Uh4+1tcH CTeDjgIZ0Us2O97knV6lhl2k/3Pd63blstUKTC8ntZa4EipMsCqZ4efTUfvIrRZBTxmx G/4g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=vTh4xK9ICYyWAhQ1AjvgpVatdsiJILBoZz3WQfMZEeA=; b=zl0ruBn05fm8LXsF9Z8DFKrohA2oz0LIX5O6EbHisQ1lCcaMryKYO65sT/YnbnyJJU Q/phQsmAIRFrpwF62VlmtpAP/I57LhKMrpRktczY2SrdBqnzKN6ysAOe3qlTip3QXofG /A4XVgK2HoX/i2Ivxg0Ar7pqnxPNId/PMyL0DsqqkhCg07ji4cLscrYLQh/DMWNNluTU UFNUJ/NYeXbVYmWT4nR/dpO8GP1jiYeumP9M4qn6prDe5gruL012PImOkS39iBcMfqSB uVFA5m4RZ/UtuY70k3Swaex4U6fmNtgeE2eW5QDCdXE+uFhW64UtTuPKwN8Urzq0yxPL 39FA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id bu6si1092237edb.287.2020.09.01.12.57.45; Tue, 01 Sep 2020 12:58:15 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731162AbgIATyQ (ORCPT + 99 others); Tue, 1 Sep 2020 15:54:16 -0400 Received: from foss.arm.com ([217.140.110.172]:49172 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726936AbgIATyQ (ORCPT ); Tue, 1 Sep 2020 15:54:16 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 597CC1FB; Tue, 1 Sep 2020 12:54:15 -0700 (PDT) Received: from [10.57.40.122] (unknown [10.57.40.122]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id A33DA3F66F; Tue, 1 Sep 2020 12:54:13 -0700 (PDT) Subject: Re: [Intel-gfx] [PATCH v9 08/32] drm: i915: fix common struct sg_table related issues To: "Ruhl, Michael J" , Marek Szyprowski , "dri-devel@lists.freedesktop.org" , "iommu@lists.linux-foundation.org" , "linaro-mm-sig@lists.linaro.org" , "linux-kernel@vger.kernel.org" Cc: Bartlomiej Zolnierkiewicz , David Airlie , "intel-gfx@lists.freedesktop.org" , Christoph Hellwig , "linux-arm-kernel@lists.infradead.org" References: <20200826063316.23486-1-m.szyprowski@samsung.com> <20200826063316.23486-9-m.szyprowski@samsung.com> <259df561c4bb4ef484799e3776dbb402@intel.com> From: Robin Murphy Message-ID: <1825327a-efd5-b836-d57e-d9356e279762@arm.com> Date: Tue, 1 Sep 2020 20:54:12 +0100 User-Agent: Mozilla/5.0 (Windows NT 10.0; rv:68.0) Gecko/20100101 Thunderbird/68.12.0 MIME-Version: 1.0 In-Reply-To: <259df561c4bb4ef484799e3776dbb402@intel.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-GB Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2020-09-01 20:38, Ruhl, Michael J wrote: >> -----Original Message----- >> From: Intel-gfx On Behalf Of >> Marek Szyprowski >> Sent: Wednesday, August 26, 2020 2:33 AM >> To: dri-devel@lists.freedesktop.org; iommu@lists.linux-foundation.org; >> linaro-mm-sig@lists.linaro.org; linux-kernel@vger.kernel.org >> Cc: Bartlomiej Zolnierkiewicz ; David Airlie >> ; intel-gfx@lists.freedesktop.org; Robin Murphy >> ; Christoph Hellwig ; linux-arm- >> kernel@lists.infradead.org; Marek Szyprowski >> >> Subject: [Intel-gfx] [PATCH v9 08/32] drm: i915: fix common struct sg_table >> related issues >> >> The Documentation/DMA-API-HOWTO.txt states that the dma_map_sg() >> function >> returns the number of the created entries in the DMA address space. >> However the subsequent calls to the dma_sync_sg_for_{device,cpu}() and >> dma_unmap_sg must be called with the original number of the entries >> passed to the dma_map_sg(). >> >> struct sg_table is a common structure used for describing a non-contiguous >> memory buffer, used commonly in the DRM and graphics subsystems. It >> consists of a scatterlist with memory pages and DMA addresses (sgl entry), >> as well as the number of scatterlist entries: CPU pages (orig_nents entry) >> and DMA mapped pages (nents entry). >> >> It turned out that it was a common mistake to misuse nents and orig_nents >> entries, calling DMA-mapping functions with a wrong number of entries or >> ignoring the number of mapped entries returned by the dma_map_sg() >> function. >> >> This driver creatively uses sg_table->orig_nents to store the size of the >> allocated scatterlist and ignores the number of the entries returned by >> dma_map_sg function. The sg_table->orig_nents is (mis)used to properly >> free the (over)allocated scatterlist. >> >> This patch only introduces the common DMA-mapping wrappers operating >> directly on the struct sg_table objects to the dmabuf related functions, >> so the other drivers, which might share buffers with i915 could rely on >> the properly set nents and orig_nents values. >> >> Signed-off-by: Marek Szyprowski >> --- >> drivers/gpu/drm/i915/gem/i915_gem_dmabuf.c | 11 +++-------- >> drivers/gpu/drm/i915/gem/selftests/mock_dmabuf.c | 7 +++---- >> 2 files changed, 6 insertions(+), 12 deletions(-) >> >> diff --git a/drivers/gpu/drm/i915/gem/i915_gem_dmabuf.c >> b/drivers/gpu/drm/i915/gem/i915_gem_dmabuf.c >> index 2679380159fc..8a988592715b 100644 >> --- a/drivers/gpu/drm/i915/gem/i915_gem_dmabuf.c >> +++ b/drivers/gpu/drm/i915/gem/i915_gem_dmabuf.c >> @@ -48,12 +48,9 @@ static struct sg_table *i915_gem_map_dma_buf(struct >> dma_buf_attachment *attachme >> src = sg_next(src); >> } >> >> - if (!dma_map_sg_attrs(attachment->dev, >> - st->sgl, st->nents, dir, >> - DMA_ATTR_SKIP_CPU_SYNC)) { >> - ret = -ENOMEM; > > You have dropped this error value. > > Do you now if this is a benign loss? True, dma_map_sgtable() will return -EINVAL rather than -ENOMEM for failure. A quick look through other .map_dma_buf callbacks suggests they're returning a motley mix of error values and NULL for failure cases, so I'd imagine that importers shouldn't be too sensitive to the exact value. Robin. > > M > >> + ret = dma_map_sgtable(attachment->dev, st, dir, >> DMA_ATTR_SKIP_CPU_SYNC); >> + if (ret) >> goto err_free_sg; >> - } >> >> return st; >> >> @@ -73,9 +70,7 @@ static void i915_gem_unmap_dma_buf(struct >> dma_buf_attachment *attachment, >> { >> struct drm_i915_gem_object *obj = dma_buf_to_obj(attachment- >>> dmabuf); >> >> - dma_unmap_sg_attrs(attachment->dev, >> - sg->sgl, sg->nents, dir, >> - DMA_ATTR_SKIP_CPU_SYNC); >> + dma_unmap_sgtable(attachment->dev, sg, dir, >> DMA_ATTR_SKIP_CPU_SYNC); >> sg_free_table(sg); >> kfree(sg); >> >> diff --git a/drivers/gpu/drm/i915/gem/selftests/mock_dmabuf.c >> b/drivers/gpu/drm/i915/gem/selftests/mock_dmabuf.c >> index debaf7b18ab5..be30b27e2926 100644 >> --- a/drivers/gpu/drm/i915/gem/selftests/mock_dmabuf.c >> +++ b/drivers/gpu/drm/i915/gem/selftests/mock_dmabuf.c >> @@ -28,10 +28,9 @@ static struct sg_table *mock_map_dma_buf(struct >> dma_buf_attachment *attachment, >> sg = sg_next(sg); >> } >> >> - if (!dma_map_sg(attachment->dev, st->sgl, st->nents, dir)) { >> - err = -ENOMEM; >> + err = dma_map_sgtable(attachment->dev, st, dir, 0); >> + if (err) >> goto err_st; >> - } >> >> return st; >> >> @@ -46,7 +45,7 @@ static void mock_unmap_dma_buf(struct >> dma_buf_attachment *attachment, >> struct sg_table *st, >> enum dma_data_direction dir) >> { >> - dma_unmap_sg(attachment->dev, st->sgl, st->nents, dir); >> + dma_unmap_sgtable(attachment->dev, st, dir, 0); >> sg_free_table(st); >> kfree(st); >> } >> -- >> 2.17.1 >> >> _______________________________________________ >> Intel-gfx mailing list >> Intel-gfx@lists.freedesktop.org >> https://lists.freedesktop.org/mailman/listinfo/intel-gfx