lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20160209083214.GB18781@lunn.ch>
Date:	Tue, 9 Feb 2016 09:32:14 +0100
From:	Andrew Lunn <andrew@...n.ch>
To:	Helmut Buchsbaum <helmut.buchsbaum@...il.com>
Cc:	"David S. Miller" <davem@...emloft.net>,
	Florian Fainelli <f.fainelli@...il.com>, netdev@...r.kernel.org
Subject: Re: [PATCH v2 3/6] net: phy: spi_ks8995: add support for resetting
 switch using GPIO

On Mon, Feb 08, 2016 at 06:35:34PM +0100, Helmut Buchsbaum wrote:
> When using device tree it is no more possible to reset the PHY at board
> level. Furthermore, doing in the driver allows to power down the switch
> when it is not used any more.
> 
> The patch introduces a new optional property "reset-gpios" denoting an
> appropriate GPIO handle, e.g.:
> 
> reset-gpios = <&gpio0 46 1>

Hi Helmut

Since you are respinning, please change the 1 to GPIO_ACTIVE_LOW.

Reviewed-by: Andrew Lunn <andrew@...n.ch>

Thanks
	Andrew

> 
> Signed-off-by: Helmut Buchsbaum <helmut.buchsbaum@...il.com>
> ---
>  drivers/net/phy/spi_ks8995.c | 71 ++++++++++++++++++++++++++++++++++++++------
>  1 file changed, 62 insertions(+), 9 deletions(-)
> 
> diff --git a/drivers/net/phy/spi_ks8995.c b/drivers/net/phy/spi_ks8995.c
> index 2803c8e..04d468f 100644
> --- a/drivers/net/phy/spi_ks8995.c
> +++ b/drivers/net/phy/spi_ks8995.c
> @@ -18,6 +18,9 @@
>  #include <linux/module.h>
>  #include <linux/delay.h>
>  #include <linux/device.h>
> +#include <linux/of.h>
> +#include <linux/gpio.h>
> +#include <linux/of_gpio.h>
>  
>  #include <linux/spi/spi.h>
>  
> @@ -120,7 +123,8 @@ static const struct ks8995_chip_params ks8995_chip[] = {
>  };
>  
>  struct ks8995_pdata {
> -	/* not yet implemented */
> +	int reset_gpio;
> +	enum of_gpio_flags reset_gpio_flags;
>  };
>  
>  struct ks8995_switch {
> @@ -339,6 +343,24 @@ err_out:
>  	return err;
>  }
>  
> +/* ks8995_parse_dt - setup platform data from devicetree
> + * @ks: pointer to switch instance
> + *
> + * Parses supported DT properties and sets up platform data
> + * accordingly.
> + */
> +static void ks8995_parse_dt(struct ks8995_switch *ks)
> +{
> +	struct device_node *np = ks->spi->dev.of_node;
> +	struct ks8995_pdata *pdata = ks->pdata;
> +
> +	if (!np)
> +		return;
> +
> +	pdata->reset_gpio = of_get_named_gpio_flags(np, "reset-gpios", 0,
> +		&pdata->reset_gpio_flags);
> +}
> +
>  static const struct bin_attribute ks8995_registers_attr = {
>  	.attr = {
>  		.name   = "registers",
> @@ -352,14 +374,10 @@ static const struct bin_attribute ks8995_registers_attr = {
>  /* ------------------------------------------------------------------------ */
>  static int ks8995_probe(struct spi_device *spi)
>  {
> -	struct ks8995_switch    *ks;
> -	struct ks8995_pdata     *pdata;
> -	int     err;
> +	struct ks8995_switch *ks;
> +	int err;
>  	int variant = spi_get_device_id(spi)->driver_data;
>  
> -	/* Chip description */
> -	pdata = spi->dev.platform_data;
> -
>  	if (variant >= max_variant) {
>  		dev_err(&spi->dev, "bad chip variant %d\n", variant);
>  		return -ENODEV;
> @@ -370,10 +388,42 @@ static int ks8995_probe(struct spi_device *spi)
>  		return -ENOMEM;
>  
>  	mutex_init(&ks->lock);
> -	ks->pdata = pdata;
>  	ks->spi = spi_dev_get(spi);
>  	ks->chip = &ks8995_chip[variant];
>  
> +	if (ks->spi->dev.of_node) {
> +		ks->pdata = devm_kzalloc(&spi->dev, sizeof(*ks->pdata),
> +					 GFP_KERNEL);
> +		if (!ks->pdata)
> +			return -ENOMEM;
> +
> +		ks->pdata->reset_gpio = -1;
> +
> +		ks8995_parse_dt(ks);
> +	}
> +
> +	if (!ks->pdata)
> +		ks->pdata = spi->dev.platform_data;
> +
> +	/* de-assert switch reset */
> +	if (ks->pdata && gpio_is_valid(ks->pdata->reset_gpio)) {
> +		unsigned long flags;
> +
> +		flags = (ks->pdata->reset_gpio_flags == OF_GPIO_ACTIVE_LOW ?
> +			 GPIOF_ACTIVE_LOW : 0);
> +
> +		err = devm_gpio_request_one(&spi->dev,
> +					    ks->pdata->reset_gpio,
> +					    flags, "switch-reset");
> +		if (err) {
> +			dev_err(&spi->dev,
> +				"failed to get reset-gpios: %d\n", err);
> +			return -EIO;
> +		}
> +
> +		gpiod_set_value(gpio_to_desc(ks->pdata->reset_gpio), 0);
> +	}
> +
>  	spi_set_drvdata(spi, ks);
>  
>  	spi->mode = SPI_MODE_0;
> @@ -414,11 +464,14 @@ static int ks8995_remove(struct spi_device *spi)
>  
>  	sysfs_remove_bin_file(&spi->dev.kobj, &ks->regs_attr);
>  
> +	/* assert reset */
> +	if (ks->pdata && gpio_is_valid(ks->pdata->reset_gpio))
> +		gpiod_set_value(gpio_to_desc(ks->pdata->reset_gpio), 1);
> +
>  	return 0;
>  }
>  
>  /* ------------------------------------------------------------------------ */
> -
>  static struct spi_driver ks8995_driver = {
>  	.driver = {
>  		.name	    = "spi-ks8995",
> -- 
> 2.1.4
> 

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ