Skip to content

Commit

Permalink
spi: sc18is602: Add reset control via gpio pin.
Browse files Browse the repository at this point in the history
This sc18is602 has a reset pin that may need to be deasserted.
Add optional binding to specifiy the reset pin via a gpio and deassert
during probe.

Signed-off-by: Phil Reid <preid@electromag.com.au>
Signed-off-by: Mark Brown <broonie@kernel.org>
  • Loading branch information
Phil Reid authored and Mark Brown committed Sep 1, 2016
1 parent 29b4817 commit f990080
Showing 1 changed file with 9 additions and 0 deletions.
9 changes: 9 additions & 0 deletions drivers/spi/spi-sc18is602.c
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
#include <linux/pm_runtime.h>
#include <linux/of.h>
#include <linux/platform_data/sc18is602.h>
#include <linux/gpio/consumer.h>

enum chips { sc18is602, sc18is602b, sc18is603 };

Expand Down Expand Up @@ -50,6 +51,8 @@ struct sc18is602 {
u8 buffer[SC18IS602_BUFSIZ + 1];
int tlen; /* Data queued for tx in buffer */
int rindex; /* Receive data index in buffer */

struct gpio_desc *reset;
};

static int sc18is602_wait_ready(struct sc18is602 *hw, int len)
Expand Down Expand Up @@ -257,6 +260,12 @@ static int sc18is602_probe(struct i2c_client *client,
hw = spi_master_get_devdata(master);
i2c_set_clientdata(client, hw);

/* assert reset and then release */
hw->reset = devm_gpiod_get_optional(dev, "reset", GPIOD_OUT_HIGH);
if (IS_ERR(hw->reset))
return PTR_ERR(hw->reset);
gpiod_set_value(hw->reset, 0);

hw->master = master;
hw->client = client;
hw->dev = dev;
Expand Down

0 comments on commit f990080

Please sign in to comment.