Oliver Neukum 4004e3
From 099d03f02dbffe1575d86063b2bf416502faa5e9 Mon Sep 17 00:00:00 2001
Oliver Neukum 4004e3
From: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Oliver Neukum 4004e3
Date: Mon, 29 Jul 2019 16:35:05 +0300
Oliver Neukum 4004e3
Subject: [PATCH] NFC: nxp-nci: Add GPIO ACPI mapping table
Oliver Neukum 4004e3
Git-commit: 099d03f02dbffe1575d86063b2bf416502faa5e9
Oliver Neukum 4004e3
References: bsc#1185589
Oliver Neukum 4004e3
Patch-mainline: v5.4-rc1
Oliver Neukum 4004e3
Oliver Neukum 4004e3
In order to unify GPIO resource request prepare gpiod_get_index()
Oliver Neukum 4004e3
to behave correctly when there is no mapping provided by firmware.
Oliver Neukum 4004e3
Oliver Neukum 4004e3
Here we add explicit mapping between _CRS GpioIo() resources and
Oliver Neukum 4004e3
their names used in the driver.
Oliver Neukum 4004e3
Oliver Neukum 4004e3
Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Oliver Neukum 4004e3
Tested-by: Sedat Dilek <sedat.dilek@gmail.com>
Oliver Neukum 4004e3
Signed-off-by: David S. Miller <davem@davemloft.net>
Oliver Neukum 4004e3
Signed-off-by: Oliver Neukum <oneukum@suse.com>
Oliver Neukum 4004e3
---
Oliver Neukum 4004e3
 drivers/nfc/nxp-nci/i2c.c | 18 ++++++++++++++++--
Oliver Neukum 4004e3
 1 file changed, 16 insertions(+), 2 deletions(-)
Oliver Neukum 4004e3
Oliver Neukum 4004e3
diff --git a/drivers/nfc/nxp-nci/i2c.c b/drivers/nfc/nxp-nci/i2c.c
Oliver Neukum 4004e3
index 713c267acf88..7344405feddf 100644
Oliver Neukum 4004e3
--- a/drivers/nfc/nxp-nci/i2c.c
Oliver Neukum 4004e3
+++ b/drivers/nfc/nxp-nci/i2c.c
Oliver Neukum 4004e3
@@ -247,6 +247,15 @@ static irqreturn_t nxp_nci_i2c_irq_thread_fn(int irq, void *phy_id)
Oliver Neukum 4004e3
 	return IRQ_NONE;
Oliver Neukum 4004e3
 }
Oliver Neukum 4004e3
 
Oliver Neukum 4004e3
+static const struct acpi_gpio_params firmware_gpios = { 1, 0, false };
Oliver Neukum 4004e3
+static const struct acpi_gpio_params enable_gpios = { 2, 0, false };
Oliver Neukum 4004e3
+
Oliver Neukum 4004e3
+static const struct acpi_gpio_mapping acpi_nxp_nci_gpios[] = {
Oliver Neukum 4004e3
+	{ "enable-gpios", &enable_gpios, 1 },
Oliver Neukum 4004e3
+	{ "firmware-gpios", &firmware_gpios, 1 },
Oliver Neukum 4004e3
+	{ }
Oliver Neukum 4004e3
+};
Oliver Neukum 4004e3
+
Oliver Neukum 4004e3
 static int nxp_nci_i2c_parse_devtree(struct i2c_client *client)
Oliver Neukum 4004e3
 {
Oliver Neukum 4004e3
 	struct nxp_nci_i2c_phy *phy = i2c_get_clientdata(client);
Oliver Neukum 4004e3
@@ -269,9 +278,14 @@ static int nxp_nci_i2c_parse_devtree(struct i2c_client *client)
Oliver Neukum 4004e3
 static int nxp_nci_i2c_acpi_config(struct nxp_nci_i2c_phy *phy)
Oliver Neukum 4004e3
 {
Oliver Neukum 4004e3
 	struct i2c_client *client = phy->i2c_dev;
Oliver Neukum 4004e3
+	int r;
Oliver Neukum 4004e3
 
Oliver Neukum 4004e3
-	phy->gpiod_en = devm_gpiod_get_index(&client->dev, NULL, 2, GPIOD_OUT_LOW);
Oliver Neukum 4004e3
-	phy->gpiod_fw = devm_gpiod_get_index(&client->dev, NULL, 1, GPIOD_OUT_LOW);
Oliver Neukum 4004e3
+	r = devm_acpi_dev_add_driver_gpios(&client->dev, acpi_nxp_nci_gpios);
Oliver Neukum 4004e3
+	if (r)
Oliver Neukum 4004e3
+		return r;
Oliver Neukum 4004e3
+
Oliver Neukum 4004e3
+	phy->gpiod_en = devm_gpiod_get(&client->dev, "enable", GPIOD_OUT_LOW);
Oliver Neukum 4004e3
+	phy->gpiod_fw = devm_gpiod_get(&client->dev, "firmware", GPIOD_OUT_LOW);
Oliver Neukum 4004e3
 
Oliver Neukum 4004e3
 	if (IS_ERR(phy->gpiod_en) || IS_ERR(phy->gpiod_fw)) {
Oliver Neukum 4004e3
 		nfc_err(&client->dev, "No GPIOs\n");
Oliver Neukum 4004e3
-- 
Oliver Neukum 4004e3
2.26.2
Oliver Neukum 4004e3