From patchwork Thu May 27 19:37:09 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Rob Herring \(Arm\)" X-Patchwork-Id: 448866 Delivered-To: patch@linaro.org Received: by 2002:a02:7a1b:0:0:0:0:0 with SMTP id a27csp810538jac; Thu, 27 May 2021 12:37:15 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxZlKMrFe+ASPHVE9bc06Q5ABvio10f49HH8FiIj9pOMr9dt1uZuD+soVkBVSYwRx4GfhcW X-Received: by 2002:a05:6602:21ca:: with SMTP id c10mr4147894ioc.10.1622144235561; Thu, 27 May 2021 12:37:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1622144235; cv=none; d=google.com; s=arc-20160816; b=CNIoQz/twYr/rCdHKrRpCJIkRwalXi0mK4sGxzXhtA9pwBiBasxuUOmC0Bp1+BrB42 mLzb5ICDpmWlMY708facIniALtrWcvAvu4iDTnpgmq7hR96Tf4FoeaNVlOF8Gt709oKX tX5IfpNHmqTzP1k9JIf4glBcsXGV8N/C4IDWHoBGGOOEJlgq7AmkAfiI3XysiEYlNLQ6 lqe5phA8VRkMGXuCXFPu9MZXiTbjXh4/mCf/Ucka5oGo3zV+K8kiBLfw0uO9zN0ilIol 1dN39blrl3nXPvN6QCekRbzyRf8ImAsw/pFCBN0DF5CoP5MFlpJ2FXMTuS3akj2CFP3E S/7A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=bM7teNdrWGeeKeqjqgBnHJlc51CGMA8O85N2k47LNWU=; b=KxwT4MsEWtXdXtCPiYKSR+SjiuYw6acYyyOYoFAp4adqFJC4rZXYbEbSgZKU6eNXjs 46yU4C5L6Q8wTveEVrlqOSHR11h7ZFkuqpIkXJ/VTy0RcsSEwH274q9GxnwEdC48alUk UwEwwkSNTQn24Vch4HGOE7bXY9Y6T5wkharTX6PQxE2k7eP5apF2rWx+FMH6Ofu1gF3G wK+X3ZPwI+0FtRDk40Cv5Ap/mhjrL/e+IyMaULt2rY+dVvtcZqU3yzn3p1DinQ2UZumB yY6MxxQh8e3hyMX72XBgGXIlsS+WPSDZSdWfINN27yUhOM71zAfj36I/VnJCX2B0UvAh uVNg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of devicetree-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=devicetree-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g3si3839987jan.54.2021.05.27.12.37.15; Thu, 27 May 2021 12:37:15 -0700 (PDT) Received-SPF: pass (google.com: domain of devicetree-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 devicetree-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=devicetree-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235109AbhE0Tir (ORCPT + 7 others); Thu, 27 May 2021 15:38:47 -0400 Received: from mail-ot1-f51.google.com ([209.85.210.51]:42727 "EHLO mail-ot1-f51.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235065AbhE0Tir (ORCPT ); Thu, 27 May 2021 15:38:47 -0400 Received: by mail-ot1-f51.google.com with SMTP id n3-20020a9d74030000b029035e65d0a0b8so1288901otk.9 for ; Thu, 27 May 2021 12:37:12 -0700 (PDT) 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:mime-version :content-transfer-encoding; bh=bM7teNdrWGeeKeqjqgBnHJlc51CGMA8O85N2k47LNWU=; b=A7ktCqK2hIhxMfwjg38RFwcaIudh5A7ol3f74pJtxj2A/SxFXhNhq8rh9NCSL+1v9W Ujkp9WOc+t8jjRpuLx6BummI60i4ZXb7gh5AxzoqAmMSHaGn2ND95E4ysf8AsRWQdp4r hYJO95Dcpo/19zDRuMPw5BqnxRvsTHXyvJNUu/CxSe/qGXPJbHETa/oAdjAk0DDR3S0E btxFDRf2/6nfFAYCWXjLiqLNenYoTsq6Qr/zBASgKPZ+0rLsYtNDSq8qoXOkWa47BcVI xfe+los4WAQTkixYsFJC3ZxNYQjVr6NlSnQKCnNl9fjliegd8gIqRDbd+QcMk1WRua0T mpdA== X-Gm-Message-State: AOAM533IrJTbiGm2h7TnBzx+PFpBuVJCnomKiX25LzOSILUnhzcxj3Ei GAGABKeS1D0qzUCu5w5AAQ== X-Received: by 2002:a05:6830:1e54:: with SMTP id e20mr4116083otj.227.1622144232461; Thu, 27 May 2021 12:37:12 -0700 (PDT) Received: from xps15.herring.priv (24-155-109-49.dyn.grandenetworks.net. [24.155.109.49]) by smtp.googlemail.com with ESMTPSA id v19sm686961otk.22.2021.05.27.12.37.10 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 27 May 2021 12:37:11 -0700 (PDT) From: Rob Herring To: Joerg Roedel , Will Deacon Cc: devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, Frank Rowand , iommu@lists.linux-foundation.org Subject: [PATCH 1/2] iommu: Remove unused of_get_dma_window() Date: Thu, 27 May 2021 14:37:09 -0500 Message-Id: <20210527193710.1281746-1-robh@kernel.org> X-Mailer: git-send-email 2.27.0 MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org of_get_dma_window() was added in 2012 and removed in 2014 in commit 891846516317 ("memory: Add NVIDIA Tegra memory controller support"). Remove it and simplify the header to use forward declarations for structs rather than includes. Cc: Joerg Roedel Cc: Will Deacon Cc: Frank Rowand Cc: iommu@lists.linux-foundation.org Signed-off-by: Rob Herring --- drivers/iommu/of_iommu.c | 68 ---------------------------------------- include/linux/of_iommu.h | 17 ++-------- 2 files changed, 3 insertions(+), 82 deletions(-) -- 2.27.0 diff --git a/drivers/iommu/of_iommu.c b/drivers/iommu/of_iommu.c index a9d2df001149..5696314ae69e 100644 --- a/drivers/iommu/of_iommu.c +++ b/drivers/iommu/of_iommu.c @@ -19,74 +19,6 @@ #define NO_IOMMU 1 -/** - * of_get_dma_window - Parse *dma-window property and returns 0 if found. - * - * @dn: device node - * @prefix: prefix for property name if any - * @index: index to start to parse - * @busno: Returns busno if supported. Otherwise pass NULL - * @addr: Returns address that DMA starts - * @size: Returns the range that DMA can handle - * - * This supports different formats flexibly. "prefix" can be - * configured if any. "busno" and "index" are optionally - * specified. Set 0(or NULL) if not used. - */ -int of_get_dma_window(struct device_node *dn, const char *prefix, int index, - unsigned long *busno, dma_addr_t *addr, size_t *size) -{ - const __be32 *dma_window, *end; - int bytes, cur_index = 0; - char propname[NAME_MAX], addrname[NAME_MAX], sizename[NAME_MAX]; - - if (!dn || !addr || !size) - return -EINVAL; - - if (!prefix) - prefix = ""; - - snprintf(propname, sizeof(propname), "%sdma-window", prefix); - snprintf(addrname, sizeof(addrname), "%s#dma-address-cells", prefix); - snprintf(sizename, sizeof(sizename), "%s#dma-size-cells", prefix); - - dma_window = of_get_property(dn, propname, &bytes); - if (!dma_window) - return -ENODEV; - end = dma_window + bytes / sizeof(*dma_window); - - while (dma_window < end) { - u32 cells; - const void *prop; - - /* busno is one cell if supported */ - if (busno) - *busno = be32_to_cpup(dma_window++); - - prop = of_get_property(dn, addrname, NULL); - if (!prop) - prop = of_get_property(dn, "#address-cells", NULL); - - cells = prop ? be32_to_cpup(prop) : of_n_addr_cells(dn); - if (!cells) - return -EINVAL; - *addr = of_read_number(dma_window, cells); - dma_window += cells; - - prop = of_get_property(dn, sizename, NULL); - cells = prop ? be32_to_cpup(prop) : of_n_size_cells(dn); - if (!cells) - return -EINVAL; - *size = of_read_number(dma_window, cells); - dma_window += cells; - - if (cur_index++ == index) - break; - } - return 0; -} -EXPORT_SYMBOL_GPL(of_get_dma_window); - static int of_iommu_xlate(struct device *dev, struct of_phandle_args *iommu_spec) { diff --git a/include/linux/of_iommu.h b/include/linux/of_iommu.h index 16f4b3e87f20..55c1eb300a86 100644 --- a/include/linux/of_iommu.h +++ b/include/linux/of_iommu.h @@ -2,29 +2,18 @@ #ifndef __OF_IOMMU_H #define __OF_IOMMU_H -#include -#include -#include +struct device; +struct device_node; +struct iommu_ops; #ifdef CONFIG_OF_IOMMU -extern int of_get_dma_window(struct device_node *dn, const char *prefix, - int index, unsigned long *busno, dma_addr_t *addr, - size_t *size); - extern const struct iommu_ops *of_iommu_configure(struct device *dev, struct device_node *master_np, const u32 *id); #else -static inline int of_get_dma_window(struct device_node *dn, const char *prefix, - int index, unsigned long *busno, dma_addr_t *addr, - size_t *size) -{ - return -EINVAL; -} - static inline const struct iommu_ops *of_iommu_configure(struct device *dev, struct device_node *master_np, const u32 *id)