LKML Archive on lore.kernel.org help / color / mirror / Atom feed
From: Anand Ashok Dumbre <anand.ashok.dumbre@xilinx.com> To: <linux-kernel@vger.kernel.org>, <jic23@kernel.org>, <lars@metafoo.de>, <linux-iio@vger.kernel.org>, <git@xilinx.com>, <michal.simek@xilinx.com>, <gregkh@linuxfoundation.org>, <rafael@kernel.org>, <linux-acpi@vger.kernel.org>, <andriy.shevchenko@linux.intel.com>, <heikki.krogerus@linux.intel.com> Cc: Anand Ashok Dumbre <anand.ashok.dumbre@xilinx.com> Subject: [PATCH v11 1/5] device property: Add fwnode_iomap() Date: Wed, 24 Nov 2021 22:54:03 +0000 [thread overview] Message-ID: <20211124225407.17793-2-anand.ashok.dumbre@xilinx.com> (raw) In-Reply-To: <20211124225407.17793-1-anand.ashok.dumbre@xilinx.com> This patch introduces a new helper routine - fwnode_iomap(), which allows to map the memory mapped IO for a given device node. This implementation does not cover the ACPI case and may be expanded in the future. The main purpose here is to be able to develop resource provider agnostic drivers. Suggested-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com> Signed-off-by: Anand Ashok Dumbre <anand.ashok.dumbre@xilinx.com> Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com> --- drivers/base/property.c | 16 ++++++++++++++++ include/linux/property.h | 2 ++ 2 files changed, 18 insertions(+) diff --git a/drivers/base/property.c b/drivers/base/property.c index f1f35b48ab8b..f2e38be3a999 100644 --- a/drivers/base/property.c +++ b/drivers/base/property.c @@ -958,6 +958,22 @@ int fwnode_irq_get(const struct fwnode_handle *fwnode, unsigned int index) } EXPORT_SYMBOL(fwnode_irq_get); +/** + * fwnode_iomap - Maps the memory mapped IO for a given fwnode + * @fwnode: Pointer to the firmware node + * @index: Index of the IO range + * + * Returns a pointer to the mapped memory. + */ +void __iomem *fwnode_iomap(struct fwnode_handle *fwnode, int index) +{ + if (is_of_node(fwnode)) + return of_iomap(to_of_node(fwnode), index); + + return NULL; +} +EXPORT_SYMBOL(fwnode_iomap); + /** * fwnode_graph_get_next_endpoint - Get next endpoint firmware node * @fwnode: Pointer to the parent firmware node diff --git a/include/linux/property.h b/include/linux/property.h index 88fa726a76df..6670d5a1ec2a 100644 --- a/include/linux/property.h +++ b/include/linux/property.h @@ -122,6 +122,8 @@ void fwnode_handle_put(struct fwnode_handle *fwnode); int fwnode_irq_get(const struct fwnode_handle *fwnode, unsigned int index); +void __iomem *fwnode_iomap(struct fwnode_handle *fwnode, int index); + unsigned int device_get_child_node_count(struct device *dev); static inline bool device_property_read_bool(struct device *dev, -- 2.17.1
next prev parent reply other threads:[~2021-11-24 22:54 UTC|newest] Thread overview: 19+ messages / expand[flat|nested] mbox.gz Atom feed top 2021-11-24 22:54 [PATCH v11 0/5] Add Xilinx AMS Driver Anand Ashok Dumbre 2021-11-24 22:54 ` Anand Ashok Dumbre [this message] 2021-11-25 11:42 ` [PATCH v11 1/5] device property: Add fwnode_iomap() Andy Shevchenko 2021-11-30 21:58 ` Anand Ashok Dumbre 2021-12-02 9:10 ` Anand Ashok Dumbre 2021-12-02 9:37 ` Andy Shevchenko 2021-12-02 11:46 ` Anand Ashok Dumbre 2021-12-02 12:34 ` Anand Ashok Dumbre 2021-11-27 11:54 ` kernel test robot 2021-11-24 22:54 ` [PATCH v11 2/5] arm64: zynqmp: DT: Add Xilinx AMS node Anand Ashok Dumbre 2021-11-24 22:54 ` [PATCH v11 3/5] iio: adc: Add Xilinx AMS driver Anand Ashok Dumbre 2021-11-25 12:14 ` Andy Shevchenko 2021-12-02 16:32 ` Anand Ashok Dumbre 2021-12-02 16:51 ` Andy Shevchenko 2021-11-27 2:43 ` kernel test robot 2021-11-27 17:50 ` Jonathan Cameron 2021-11-27 5:16 ` kernel test robot 2021-11-24 22:54 ` [PATCH v11 4/5] dt-bindings: iio: adc: Add Xilinx AMS binding documentation Anand Ashok Dumbre 2021-11-24 22:54 ` [PATCH v11 5/5] MAINTAINERS: Add maintainer for xilinx-ams Anand Ashok Dumbre
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=20211124225407.17793-2-anand.ashok.dumbre@xilinx.com \ --to=anand.ashok.dumbre@xilinx.com \ --cc=andriy.shevchenko@linux.intel.com \ --cc=git@xilinx.com \ --cc=gregkh@linuxfoundation.org \ --cc=heikki.krogerus@linux.intel.com \ --cc=jic23@kernel.org \ --cc=lars@metafoo.de \ --cc=linux-acpi@vger.kernel.org \ --cc=linux-iio@vger.kernel.org \ --cc=linux-kernel@vger.kernel.org \ --cc=michal.simek@xilinx.com \ --cc=rafael@kernel.org \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).