From patchwork Thu Apr 14 17:25:35 2016 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Lorenzo Pieralisi X-Patchwork-Id: 8840141 X-Patchwork-Delegate: bhelgaas@google.com Return-Path: X-Original-To: patchwork-linux-pci@patchwork.kernel.org Delivered-To: patchwork-parsemail@patchwork1.web.kernel.org Received: from mail.kernel.org (mail.kernel.org [198.145.29.136]) by patchwork1.web.kernel.org (Postfix) with ESMTP id D1E869F71A for ; Thu, 14 Apr 2016 17:25:52 +0000 (UTC) Received: from mail.kernel.org (localhost [127.0.0.1]) by mail.kernel.org (Postfix) with ESMTP id 0229F2034A for ; Thu, 14 Apr 2016 17:25:52 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id 27AE9202F0 for ; Thu, 14 Apr 2016 17:25:49 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755664AbcDNRXQ (ORCPT ); Thu, 14 Apr 2016 13:23:16 -0400 Received: from foss.arm.com ([217.140.101.70]:44807 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754995AbcDNRXN (ORCPT ); Thu, 14 Apr 2016 13:23:13 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 97BF74A7; Thu, 14 Apr 2016 10:21:58 -0700 (PDT) Received: from red-moon.cambridge.arm.com (red-moon.cambridge.arm.com [10.1.203.137]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 6F2F13F25F; Thu, 14 Apr 2016 10:23:10 -0700 (PDT) From: Lorenzo Pieralisi To: iommu@lists.linux-foundation.org Cc: Lorenzo Pieralisi , Joerg Roedel , "Rafael J. Wysocki" , Will Deacon , Marc Zyngier , Robin Murphy , Tomasz Nowicki , Hanjun Guo , Jon Masters , Sinan Kaya , linux-acpi@vger.kernel.org, linux-pci@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org Subject: [RFC PATCH 03/11] drivers: iommu: add FWNODE_IOMMU fwnode type Date: Thu, 14 Apr 2016 18:25:35 +0100 Message-Id: <1460654743-7896-4-git-send-email-lorenzo.pieralisi@arm.com> X-Mailer: git-send-email 2.6.4 In-Reply-To: <1460654743-7896-1-git-send-email-lorenzo.pieralisi@arm.com> References: <1460654743-7896-1-git-send-email-lorenzo.pieralisi@arm.com> Sender: linux-pci-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-pci@vger.kernel.org X-Spam-Status: No, score=-7.9 required=5.0 tests=BAYES_00, RCVD_IN_DNSWL_HI, RP_MATCHES_RCVD, UNPARSEABLE_RELAY autolearn=unavailable version=3.3.1 X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on mail.kernel.org X-Virus-Scanned: ClamAV using ClamSMTP On systems booting with a device tree, every struct device is associated with a struct device_node, that represents its DT representation. The device node can be used in generic kernel contexts (eg IRQ translation, IOMMU streamid mapping), to retrieve the properties associated with the device and carry out kernel operation accordingly. Owing to the 1:1 relationship between the device and its device_node, the device_node can also be used as a look-up token for the device (eg looking up a device through its device_node), to retrieve the device in kernel paths where the device_node is available. On systems booting with ACPI, the same abstraction provided by the device_node is required to provide: - Look-up functionality - Identify the device in kernel functions that must be firmware agnostic (eg IOMMU of_xlate() callbacks) Therefore, mirroring the approach implemented in the IRQ domain kernel layer, this patch adds an additional fwnode type FWNODE_IOMMU. This patch also implements a glue kernel layer that allows to allocate/free FWNODE_IOMMU fwnode_handle structures and associate them with IOMMU devices. Signed-off-by: Lorenzo Pieralisi Cc: Joerg Roedel Cc: "Rafael J. Wysocki" --- include/linux/fwnode.h | 1 + include/linux/iommu.h | 25 +++++++++++++++++++++++++ 2 files changed, 26 insertions(+) diff --git a/include/linux/fwnode.h b/include/linux/fwnode.h index 8516717..6e10050 100644 --- a/include/linux/fwnode.h +++ b/include/linux/fwnode.h @@ -19,6 +19,7 @@ enum fwnode_type { FWNODE_ACPI_DATA, FWNODE_PDATA, FWNODE_IRQCHIP, + FWNODE_IOMMU, }; struct fwnode_handle { diff --git a/include/linux/iommu.h b/include/linux/iommu.h index a5c539f..0bba25e 100644 --- a/include/linux/iommu.h +++ b/include/linux/iommu.h @@ -37,6 +37,7 @@ struct bus_type; struct device; struct iommu_domain; struct notifier_block; +struct fwnode_handle; /* iommu fault flags */ #define IOMMU_FAULT_READ 0x0 @@ -542,4 +543,28 @@ static inline void iommu_device_unlink(struct device *dev, struct device *link) #endif /* CONFIG_IOMMU_API */ +/* IOMMU fwnode handling */ +static inline bool is_fwnode_iommu(struct fwnode_handle *fwnode) +{ + return fwnode && fwnode->type == FWNODE_IOMMU; +} + +static inline struct fwnode_handle *iommu_alloc_fwnode(void) +{ + struct fwnode_handle *fwnode; + + fwnode = kzalloc(sizeof(struct fwnode_handle), GFP_KERNEL); + fwnode->type = FWNODE_IOMMU; + + return fwnode; +} + +static inline void iommu_free_fwnode(struct fwnode_handle *fwnode) +{ + if (WARN_ON(!is_fwnode_iommu(fwnode))) + return; + + kfree(fwnode); +} + #endif /* __LINUX_IOMMU_H */