Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp174881imm; Thu, 26 Jul 2018 16:24:30 -0700 (PDT) X-Google-Smtp-Source: AAOMgpcywwhuCLBFz3PswI4T/gddTBzdZ0n4ZjAri67AR2R/lbIfCE5CBu01hkpA8ifZxiEQM9t2 X-Received: by 2002:a17:902:820e:: with SMTP id x14-v6mr3741470pln.218.1532647470710; Thu, 26 Jul 2018 16:24:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1532647470; cv=none; d=google.com; s=arc-20160816; b=BqGJF0XL7cDSJ9bDLHyMgjezkp4rnu8L4uBJIsu2x0Pn+zD7FjAWuRDYX34ANUQWOQ 7hsHQKXi2grFgoTS5WN2zUZLJnVfyvV+HNhkGMHQFoNLIswtTfCrDnzwjiOS042x1Ypb +K79jyw7UoPRfb9gLqc93R93pANA0LzMhKFQ+XZOs2rwRh3wuFghA+fRqPFk4CaICzPa xhRnQTIIg5vM0pDFnAWtkUzLpOckQx0W+PYoz2ZAn3HqUQt/8K/W4VA27KsJ8Utr5UWW alz5TIuCZWeL05kpsnQH+zuy9KLLIQht/MYTm1Tb5l66C4zYX4Iw232ybL9E6sC99soI AKWw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=O+e/im9YZ70ju1A0neTQHuRteCq93hPLVv7chPKaQl4=; b=qk2vVvyvlS7SCd7QEtkBj/B92Eyumj0eAxK7cpeCf/4GbWVmRe786LNRoLGcv6hwdu XKvcbTvqRgr6OR4PH5R5uuKw2yOFM/rQo+bDEsvfZ7RxnpFmjDMQ//xm0WtS1r7yE5j7 95PzrLXfyh9uY7th9Xp3iCAgfatuhgEqG70BsyWTDZzpSFG0boRcPOfY08OYFw1OJMKe p+z6tfTuVt229CT9+2C8xaXSXfHNfPw3LFumPVqTNB0oWVc4PJGO22Ujofl/Z66HKdTE x9qyjzQmspBDZfXLEhn8xkE09U7/qmmrOzlUDgMAtj4XUKWAco3h/Ty0Hk6Kc5OzsUct HOFg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=GYSTlGSt; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h90-v6si2171983plb.484.2018.07.26.16.24.13; Thu, 26 Jul 2018 16:24:30 -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=@gmail.com header.s=20161025 header.b=GYSTlGSt; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732059AbeG0Alg (ORCPT + 99 others); Thu, 26 Jul 2018 20:41:36 -0400 Received: from mail-lf1-f67.google.com ([209.85.167.67]:46124 "EHLO mail-lf1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730610AbeG0Alf (ORCPT ); Thu, 26 Jul 2018 20:41:35 -0400 Received: by mail-lf1-f67.google.com with SMTP id l16-v6so2319946lfc.13; Thu, 26 Jul 2018 16:22:33 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=O+e/im9YZ70ju1A0neTQHuRteCq93hPLVv7chPKaQl4=; b=GYSTlGStsfO6u4BW3It+2ufAu0sofqFlN0hIoZczNqvzwqXWYDxq+20VmXlEWcut9n GsdgdRLdd23ns7uXhr1bFXG0mDeoRTVd2h14CrvtK81k8RGyMQGRRUG8aTLcaF5pKuSc 3rOlL0IM788wIugFJS28KUd8vY/1IdIWn1pr95vlWzSomhL6+2bQhLFZUKrdXxC79VAf XEa3yKdy3BA2KP5j7ojV2Xen85dY5XJyiH2pk+Mf1Jp8Xhv/oEM86IJ6fb1xlOMtx6se Jrbjd2QJpnxP0Vl0ieJWJDXxKPGyoJZT804sUxK/aBH6+m6HkZdOFkhhX2BFKfOcj3Qe oQ9A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=O+e/im9YZ70ju1A0neTQHuRteCq93hPLVv7chPKaQl4=; b=hwFejf5RJTqUoBinbLxYLN2j/co3oQ53VDwW7YBaHICKDGvwwPDPGFd4n2lz22Y6CA t3nuyI5T5rNDNaqk6nuXsq+9MTrObFWDUFiZvtf5cKS3cb/ualDQ4lYTZzGJPLGIVxeU Bu+DoKAhbRLgex8Q9VBIMuqYeFZ4w+hEeaPjVybtxR71Cd0i823qaKiZf8OHHjsyeOCc ZjaZar2d7gr5Ap5LQulHvXsiAhYOcEcIHKzNYf/EXnM0vEE+t4KA+dgWvCnj7dHjUyVc dlp8aH8Clpp7gsio1zMZwVKhTI5dN5Icb7ddvxvMErXJYzpaxnOIoUz/VYAb/ybf9gC5 hVxA== X-Gm-Message-State: AOUpUlF+yynOTKDF67EBzxY45J4MDAjDXuMlrC66+LNXFGkeZFr5+8nU VTd/4w0FjTgKvxZRdZkI9Mo= X-Received: by 2002:a19:4ecd:: with SMTP id u74-v6mr2410628lfk.57.1532647352254; Thu, 26 Jul 2018 16:22:32 -0700 (PDT) Received: from localhost.localdomain (109-252-90-13.nat.spd-mgts.ru. [109.252.90.13]) by smtp.gmail.com with ESMTPSA id q15-v6sm411541ljg.62.2018.07.26.16.22.31 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 26 Jul 2018 16:22:31 -0700 (PDT) From: Dmitry Osipenko To: Greg Kroah-Hartman , "Rafael J. Wysocki" , Thierry Reding , Jonathan Hunter , Mikko Perttunen , Rob Herring , Frank Rowand , Ben Skeggs , Russell King , Catalin Marinas , Will Deacon , Joerg Roedel , Nicolas Chauvet Cc: devicetree@vger.kernel.org, nouveau@lists.freedesktop.org, iommu@lists.linux-foundation.org, dri-devel@lists.freedesktop.org, linux-tegra@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [RFC PATCH v1 2/6] of/device: Don't back devices DMA with IOMMU if that's undesired by driver Date: Fri, 27 Jul 2018 02:16:20 +0300 Message-Id: <20180726231624.21084-3-digetx@gmail.com> X-Mailer: git-send-email 2.18.0 In-Reply-To: <20180726231624.21084-1-digetx@gmail.com> References: <20180726231624.21084-1-digetx@gmail.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Respect device driver requirement for device DMA not to be implicitly backed with IOMMU by skipping the backing setup for drivers that do not want that. Signed-off-by: Dmitry Osipenko --- drivers/of/device.c | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/drivers/of/device.c b/drivers/of/device.c index 33d85511d790..e70b7a886875 100644 --- a/drivers/of/device.c +++ b/drivers/of/device.c @@ -163,6 +163,13 @@ int of_dma_configure(struct device *dev, struct device_node *np, bool force_dma) dev_dbg(dev, "device is%sbehind an iommu\n", iommu ? " " : " not "); + /* + * Respect device driver requirement for device DMA not to be + * implicitly backed with IOMMU. + */ + if (iommu && dev->driver->no_implicit_iommu) + iommu = NULL; + arch_setup_dma_ops(dev, dma_addr, size, iommu, coherent); return 0; -- 2.18.0