Received: by 10.213.65.68 with SMTP id h4csp4383140imn; Tue, 10 Apr 2018 14:04:36 -0700 (PDT) X-Google-Smtp-Source: AIpwx4/yqCoqB3mCtC2lY+PBcWsi+xGfsI/RIdcJTicFYFEMx1hqC9rDIb2Z/8w0ounNlyIEizB9 X-Received: by 10.98.11.149 with SMTP id 21mr1648813pfl.64.1523394276409; Tue, 10 Apr 2018 14:04:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1523394276; cv=none; d=google.com; s=arc-20160816; b=eaNOE6qgS4P+OEI2+NjNyaBEP8GP2gHULpPHvBnT2nmhOD+gvD/tANeZIxbMEQXM9S SK6eDim903My35aewBGBvxHhzEhhh7TtKK6D6v3xNMs+wbpK4a0vSuFPEX6xKrryVBlx Bt+1/TKnG7teBGqpCjyT0LNKjRlK6nX0H8BJlcUX9X3JQyflnhtKkqY4mMQj2vmfPIhI lhL1ohJBE1OW0VygiH2Zji/8PV0EJhpdq7QPuSBsH/yOf96bHNnY8p6M3IodUMRMat+c 9zMIbv2kru0bKZguO99qFMgpxsolQNy95wm/SUu3dJ+lPjCOBxr5pQd7peGRZPsW/qes +IUw== 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:mime-version :message-id:date:subject:cc:to:from:dmarc-filter:dkim-signature :dkim-signature:arc-authentication-results; bh=BkWHQpAebUL95A7zZ2r333Yt6CjBjPiJFs+RQFtSCws=; b=YU7Vy/a7VgewZsRb3GyVUCLuQOuXOW4ZWpX7/0UZdNr7ZEdrFb5gZXr4jeYefPQH4H TbNpTqEcfMH/us7wVIe0WiPpXG5HIC3EokbyhzZs+9dLM24YJcctyvTCzGlKbF23w5Nb 4dmABqU8RPI5MaPMf9Iekll+9oP5E/2zZSpzhT98xvmbrlUPO0cAj1YQkLQ30XLlMoCH a43ted5fTkumue+Wnc6yhoQr1NMkA1qfM6LagosK7Gie+M4dSrZ/IMllEfuzBp/k1wXa 2Sm4w3G0POaX9q1JT98xmTT9We20Y45DI2+D454eaoBXPT2xD8LUwSXPeQNV/fDZdVpL nMKA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=fJa+1k6R; dkim=pass header.i=@codeaurora.org header.s=default header.b=fJa+1k6R; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v45si2322762pgn.379.2018.04.10.14.03.55; Tue, 10 Apr 2018 14:04:36 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=fJa+1k6R; dkim=pass header.i=@codeaurora.org header.s=default header.b=fJa+1k6R; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752168AbeDJVAL (ORCPT + 99 others); Tue, 10 Apr 2018 17:00:11 -0400 Received: from smtp.codeaurora.org ([198.145.29.96]:37704 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751611AbeDJVAJ (ORCPT ); Tue, 10 Apr 2018 17:00:09 -0400 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id ECA6E60249; Tue, 10 Apr 2018 21:00:08 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1523394008; bh=PIR4u6xx8DCBVCh7bx9/uYyI7sz1bQIEd2alW/l22wA=; h=From:To:Cc:Subject:Date:From; b=fJa+1k6REFdqHnWs6IEkX8CVpChecRplEE3wocce1Jpghv+FkZ/BOP0J1pYSlChWg 2dMTFWqmgS6WNowxYq2jLIUY4JIG7czM5SejvL0Mb+88jLTTMAmV6lqHGHhVJbxd5x gLNXMk8OSHwuRkwufxon69bdSiHlS9nTx0/0BGsY= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on pdx-caf-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.8 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_SIGNED,T_DKIM_INVALID autolearn=no autolearn_force=no version=3.4.0 Received: from drakthul.qualcomm.com (global_nat1_iad_fw.qualcomm.com [129.46.232.65]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: okaya@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id 3DC2160249; Tue, 10 Apr 2018 21:00:06 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1523394008; bh=PIR4u6xx8DCBVCh7bx9/uYyI7sz1bQIEd2alW/l22wA=; h=From:To:Cc:Subject:Date:From; b=fJa+1k6REFdqHnWs6IEkX8CVpChecRplEE3wocce1Jpghv+FkZ/BOP0J1pYSlChWg 2dMTFWqmgS6WNowxYq2jLIUY4JIG7czM5SejvL0Mb+88jLTTMAmV6lqHGHhVJbxd5x gLNXMk8OSHwuRkwufxon69bdSiHlS9nTx0/0BGsY= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 3DC2160249 Authentication-Results: pdx-caf-mail.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: pdx-caf-mail.web.codeaurora.org; spf=none smtp.mailfrom=okaya@codeaurora.org From: Sinan Kaya To: amd-gfx@lists.freedesktop.org, timur@codeaurora.org, sulrich@codeaurora.org Cc: linux-arm-msm@vger.kernel.org, linux-arm-kernel@lists.infradead.org, Sinan Kaya , Alex Deucher , =?UTF-8?q?Christian=20K=C3=B6nig?= , "David (ChunMing) Zhou" , David Airlie , Felix Kuehling , Monk Liu , Roger He , Jim Qu , Emily Deng , Feifei Xu , Huang Rui , Tom St Denis , David Panariti , dri-devel@lists.freedesktop.org (open list:DRM DRIVERS), linux-kernel@vger.kernel.org (open list) Subject: [PATCH V2] drm/amdgpu: limit DMA size to PAGE_SIZE for scatter-gather buffers Date: Tue, 10 Apr 2018 16:59:55 -0400 Message-Id: <1523394001-4615-1-git-send-email-okaya@codeaurora.org> X-Mailer: git-send-email 2.7.4 MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Code is expecing to observe the same number of buffers returned from dma_map_sg() function compared to sg_alloc_table_from_pages(). This doesn't hold true universally especially for systems with IOMMU. IOMMU driver tries to combine buffers into a single DMA address as much as it can. The right thing is to tell the DMA layer how much combining IOMMU can do. Signed-off-by: Sinan Kaya --- drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c | 2 +- drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c | 1 + drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c | 1 + drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c | 1 + 4 files changed, 4 insertions(+), 1 deletion(-) diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c b/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c index 8e28270..1b031eb 100644 --- a/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c +++ b/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c @@ -851,7 +851,7 @@ static int gmc_v6_0_sw_init(void *handle) pci_set_consistent_dma_mask(adev->pdev, DMA_BIT_MASK(32)); dev_warn(adev->dev, "amdgpu: No coherent DMA available.\n"); } - + dma_set_max_seg_size(adev->dev, PAGE_SIZE); r = gmc_v6_0_init_microcode(adev); if (r) { dev_err(adev->dev, "Failed to load mc firmware!\n"); diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c b/drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c index 86e9d682..0a4b2cc1 100644 --- a/drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c +++ b/drivers/gpu/drm/amd/amdgpu/gmc_v7_0.c @@ -999,6 +999,7 @@ static int gmc_v7_0_sw_init(void *handle) pci_set_consistent_dma_mask(adev->pdev, DMA_BIT_MASK(32)); pr_warn("amdgpu: No coherent DMA available\n"); } + dma_set_max_seg_size(adev->dev, PAGE_SIZE); r = gmc_v7_0_init_microcode(adev); if (r) { diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c b/drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c index 9a813d8..b171529 100644 --- a/drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c +++ b/drivers/gpu/drm/amd/amdgpu/gmc_v8_0.c @@ -1096,6 +1096,7 @@ static int gmc_v8_0_sw_init(void *handle) pci_set_consistent_dma_mask(adev->pdev, DMA_BIT_MASK(32)); pr_warn("amdgpu: No coherent DMA available\n"); } + dma_set_max_seg_size(adev->dev, PAGE_SIZE); r = gmc_v8_0_init_microcode(adev); if (r) { diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c index 3b7e7af..36e658ab 100644 --- a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c +++ b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c @@ -855,6 +855,7 @@ static int gmc_v9_0_sw_init(void *handle) pci_set_consistent_dma_mask(adev->pdev, DMA_BIT_MASK(32)); printk(KERN_WARNING "amdgpu: No coherent DMA available.\n"); } + dma_set_max_seg_size(adev->dev, PAGE_SIZE); r = gmc_v9_0_mc_init(adev); if (r) -- 2.7.4