Re: [PATCH v2] NFC: nxp-nci: Make firmware GPIO pin optional
From: Andy Shevchenko
Date: Tue Dec 01 2020 - 06:21:28 EST
On Tue, Dec 1, 2020 at 10:12 AM Schrempf Frieder
<frieder.schrempf@xxxxxxxxxx> wrote:
>
> From: Frieder Schrempf <frieder.schrempf@xxxxxxxxxx>
>
> There are other NXP NCI compatible NFC controllers such as the PN7150
> that use an integrated firmware and therefore do not have a GPIO to
> select firmware downloading mode. To support these kind of chips,
these -> this
OR
kind -> kinds
> let's make the firmware GPIO optional.
FWIW,
Reviewed-by: Andy Shevchenko <andy.shevchenko@xxxxxxxxx>
> Signed-off-by: Frieder Schrempf <frieder.schrempf@xxxxxxxxxx>
>
> ---
> Changes in v2:
> * Remove unneeded null check for phy->gpiod_fw
> ---
> Documentation/devicetree/bindings/net/nfc/nxp-nci.txt | 2 +-
> drivers/nfc/nxp-nci/i2c.c | 2 +-
> 2 files changed, 2 insertions(+), 2 deletions(-)
>
> diff --git a/Documentation/devicetree/bindings/net/nfc/nxp-nci.txt b/Documentation/devicetree/bindings/net/nfc/nxp-nci.txt
> index cfaf88998918..cb2385c277d0 100644
> --- a/Documentation/devicetree/bindings/net/nfc/nxp-nci.txt
> +++ b/Documentation/devicetree/bindings/net/nfc/nxp-nci.txt
> @@ -6,11 +6,11 @@ Required properties:
> - reg: address on the bus
> - interrupts: GPIO interrupt to which the chip is connected
> - enable-gpios: Output GPIO pin used for enabling/disabling the chip
> -- firmware-gpios: Output GPIO pin used to enter firmware download mode
>
> Optional SoC Specific Properties:
> - pinctrl-names: Contains only one value - "default".
> - pintctrl-0: Specifies the pin control groups used for this controller.
> +- firmware-gpios: Output GPIO pin used to enter firmware download mode
>
> Example (for ARM-based BeagleBone with NPC100 NFC controller on I2C2):
>
> diff --git a/drivers/nfc/nxp-nci/i2c.c b/drivers/nfc/nxp-nci/i2c.c
> index 9f60e4dc5a90..7e451c10985d 100644
> --- a/drivers/nfc/nxp-nci/i2c.c
> +++ b/drivers/nfc/nxp-nci/i2c.c
> @@ -286,7 +286,7 @@ static int nxp_nci_i2c_probe(struct i2c_client *client,
> return PTR_ERR(phy->gpiod_en);
> }
>
> - phy->gpiod_fw = devm_gpiod_get(dev, "firmware", GPIOD_OUT_LOW);
> + phy->gpiod_fw = devm_gpiod_get_optional(dev, "firmware", GPIOD_OUT_LOW);
> if (IS_ERR(phy->gpiod_fw)) {
> nfc_err(dev, "Failed to get FW gpio\n");
> return PTR_ERR(phy->gpiod_fw);
> --
> 2.17.1
>
--
With Best Regards,
Andy Shevchenko