Commit 9f2ad955 authored by Stefan Schmidt's avatar Stefan Schmidt

Revert "at86rf230: convert to gpio descriptors"

This reverts commit 622bd6ea.

Dmitry Torokhov points out that this conversion leaves an existing board
in reset state due to not properly handled polarity. Additionally, the
GPIO name inadvertenly changes from "reset-gpio" to "rstn-gpios".
Revert to avoid these regressions.

Follow up patches for a better conversion are applied as well.
Signed-off-by: default avatarStefan Schmidt <stefan@datenfreihafen.org>
parent 6755dee8
...@@ -15,12 +15,13 @@ ...@@ -15,12 +15,13 @@
#include <linux/jiffies.h> #include <linux/jiffies.h>
#include <linux/interrupt.h> #include <linux/interrupt.h>
#include <linux/irq.h> #include <linux/irq.h>
#include <linux/gpio.h>
#include <linux/delay.h> #include <linux/delay.h>
#include <linux/gpio/consumer.h>
#include <linux/spi/spi.h> #include <linux/spi/spi.h>
#include <linux/property.h> #include <linux/spi/at86rf230.h>
#include <linux/regmap.h> #include <linux/regmap.h>
#include <linux/skbuff.h> #include <linux/skbuff.h>
#include <linux/of_gpio.h>
#include <linux/ieee802154.h> #include <linux/ieee802154.h>
#include <net/mac802154.h> #include <net/mac802154.h>
...@@ -81,7 +82,7 @@ struct at86rf230_local { ...@@ -81,7 +82,7 @@ struct at86rf230_local {
struct ieee802154_hw *hw; struct ieee802154_hw *hw;
struct at86rf2xx_chip_data *data; struct at86rf2xx_chip_data *data;
struct regmap *regmap; struct regmap *regmap;
struct gpio_desc *slp_tr; int slp_tr;
bool sleep; bool sleep;
struct completion state_complete; struct completion state_complete;
...@@ -106,8 +107,8 @@ at86rf230_async_state_change(struct at86rf230_local *lp, ...@@ -106,8 +107,8 @@ at86rf230_async_state_change(struct at86rf230_local *lp,
static inline void static inline void
at86rf230_sleep(struct at86rf230_local *lp) at86rf230_sleep(struct at86rf230_local *lp)
{ {
if (lp->slp_tr) { if (gpio_is_valid(lp->slp_tr)) {
gpiod_set_value(lp->slp_tr, 1); gpio_set_value(lp->slp_tr, 1);
usleep_range(lp->data->t_off_to_sleep, usleep_range(lp->data->t_off_to_sleep,
lp->data->t_off_to_sleep + 10); lp->data->t_off_to_sleep + 10);
lp->sleep = true; lp->sleep = true;
...@@ -117,8 +118,8 @@ at86rf230_sleep(struct at86rf230_local *lp) ...@@ -117,8 +118,8 @@ at86rf230_sleep(struct at86rf230_local *lp)
static inline void static inline void
at86rf230_awake(struct at86rf230_local *lp) at86rf230_awake(struct at86rf230_local *lp)
{ {
if (lp->slp_tr) { if (gpio_is_valid(lp->slp_tr)) {
gpiod_set_value(lp->slp_tr, 0); gpio_set_value(lp->slp_tr, 0);
usleep_range(lp->data->t_sleep_to_off, usleep_range(lp->data->t_sleep_to_off,
lp->data->t_sleep_to_off + 100); lp->data->t_sleep_to_off + 100);
lp->sleep = false; lp->sleep = false;
...@@ -203,9 +204,9 @@ at86rf230_write_subreg(struct at86rf230_local *lp, ...@@ -203,9 +204,9 @@ at86rf230_write_subreg(struct at86rf230_local *lp,
static inline void static inline void
at86rf230_slp_tr_rising_edge(struct at86rf230_local *lp) at86rf230_slp_tr_rising_edge(struct at86rf230_local *lp)
{ {
gpiod_set_value(lp->slp_tr, 1); gpio_set_value(lp->slp_tr, 1);
udelay(1); udelay(1);
gpiod_set_value(lp->slp_tr, 0); gpio_set_value(lp->slp_tr, 0);
} }
static bool static bool
...@@ -818,7 +819,7 @@ at86rf230_write_frame_complete(void *context) ...@@ -818,7 +819,7 @@ at86rf230_write_frame_complete(void *context)
ctx->trx.len = 2; ctx->trx.len = 2;
if (lp->slp_tr) if (gpio_is_valid(lp->slp_tr))
at86rf230_slp_tr_rising_edge(lp); at86rf230_slp_tr_rising_edge(lp);
else else
at86rf230_async_write_reg(lp, RG_TRX_STATE, STATE_BUSY_TX, ctx, at86rf230_async_write_reg(lp, RG_TRX_STATE, STATE_BUSY_TX, ctx,
...@@ -1414,6 +1415,32 @@ static int at86rf230_hw_init(struct at86rf230_local *lp, u8 xtal_trim) ...@@ -1414,6 +1415,32 @@ static int at86rf230_hw_init(struct at86rf230_local *lp, u8 xtal_trim)
return at86rf230_write_subreg(lp, SR_SLOTTED_OPERATION, 0); return at86rf230_write_subreg(lp, SR_SLOTTED_OPERATION, 0);
} }
static int
at86rf230_get_pdata(struct spi_device *spi, int *rstn, int *slp_tr,
u8 *xtal_trim)
{
struct at86rf230_platform_data *pdata = spi->dev.platform_data;
int ret;
if (!IS_ENABLED(CONFIG_OF) || !spi->dev.of_node) {
if (!pdata)
return -ENOENT;
*rstn = pdata->rstn;
*slp_tr = pdata->slp_tr;
*xtal_trim = pdata->xtal_trim;
return 0;
}
*rstn = of_get_named_gpio(spi->dev.of_node, "reset-gpio", 0);
*slp_tr = of_get_named_gpio(spi->dev.of_node, "sleep-gpio", 0);
ret = of_property_read_u8(spi->dev.of_node, "xtal-trim", xtal_trim);
if (ret < 0 && ret != -EINVAL)
return ret;
return 0;
}
static int static int
at86rf230_detect_device(struct at86rf230_local *lp) at86rf230_detect_device(struct at86rf230_local *lp)
{ {
...@@ -1520,8 +1547,7 @@ static int at86rf230_probe(struct spi_device *spi) ...@@ -1520,8 +1547,7 @@ static int at86rf230_probe(struct spi_device *spi)
struct ieee802154_hw *hw; struct ieee802154_hw *hw;
struct at86rf230_local *lp; struct at86rf230_local *lp;
unsigned int status; unsigned int status;
int rc, irq_type; int rc, irq_type, rstn, slp_tr;
struct gpio_desc *rstn, *slp_tr;
u8 xtal_trim = 0; u8 xtal_trim = 0;
if (!spi->irq) { if (!spi->irq) {
...@@ -1529,26 +1555,32 @@ static int at86rf230_probe(struct spi_device *spi) ...@@ -1529,26 +1555,32 @@ static int at86rf230_probe(struct spi_device *spi)
return -EINVAL; return -EINVAL;
} }
rc = device_property_read_u8(&spi->dev, "xtal-trim", &xtal_trim); rc = at86rf230_get_pdata(spi, &rstn, &slp_tr, &xtal_trim);
if (rc < 0 && rc != -EINVAL) { if (rc < 0) {
dev_err(&spi->dev, "failed to parse xtal-trim: %d\n", rc); dev_err(&spi->dev, "failed to parse platform_data: %d\n", rc);
return rc; return rc;
} }
rstn = devm_gpiod_get_optional(&spi->dev, "rstn", GPIOD_OUT_HIGH); if (gpio_is_valid(rstn)) {
if (IS_ERR(rstn)) rc = devm_gpio_request_one(&spi->dev, rstn,
return PTR_ERR(rstn); GPIOF_OUT_INIT_HIGH, "rstn");
if (rc)
return rc;
}
slp_tr = devm_gpiod_get_optional(&spi->dev, "slp_tr", GPIOD_OUT_LOW); if (gpio_is_valid(slp_tr)) {
if (IS_ERR(slp_tr)) rc = devm_gpio_request_one(&spi->dev, slp_tr,
return PTR_ERR(slp_tr); GPIOF_OUT_INIT_LOW, "slp_tr");
if (rc)
return rc;
}
/* Reset */ /* Reset */
if (rstn) { if (gpio_is_valid(rstn)) {
udelay(1); udelay(1);
gpiod_set_value_cansleep(rstn, 0); gpio_set_value_cansleep(rstn, 0);
udelay(1); udelay(1);
gpiod_set_value_cansleep(rstn, 1); gpio_set_value_cansleep(rstn, 1);
usleep_range(120, 240); usleep_range(120, 240);
} }
...@@ -1650,7 +1682,7 @@ MODULE_DEVICE_TABLE(spi, at86rf230_device_id); ...@@ -1650,7 +1682,7 @@ MODULE_DEVICE_TABLE(spi, at86rf230_device_id);
static struct spi_driver at86rf230_driver = { static struct spi_driver at86rf230_driver = {
.id_table = at86rf230_device_id, .id_table = at86rf230_device_id,
.driver = { .driver = {
.of_match_table = at86rf230_of_match, .of_match_table = of_match_ptr(at86rf230_of_match),
.name = "at86rf230", .name = "at86rf230",
}, },
.probe = at86rf230_probe, .probe = at86rf230_probe,
......
/* SPDX-License-Identifier: GPL-2.0-only */
/*
* AT86RF230/RF231 driver
*
* Copyright (C) 2009-2012 Siemens AG
*
* Written by:
* Dmitry Eremin-Solenikov <dmitry.baryshkov@siemens.com>
*/
#ifndef AT86RF230_H
#define AT86RF230_H
struct at86rf230_platform_data {
int rstn;
int slp_tr;
int dig2;
u8 xtal_trim;
};
#endif
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment