提交 e6f7ed9d 编写于 作者: A Alexander Aring 提交者: Marcel Holtmann

at86rf230: add support for sleep state

This patch adds support for sleep state when between stop and start
period. In this period the transceiver isn't used by the subsystem, in
this time we disable the irq and going into the sleep state.
Signed-off-by: NAlexander Aring <alex.aring@gmail.com>
Signed-off-by: NMarcel Holtmann <marcel@holtmann.org>
上级 9ff19e6f
...@@ -47,6 +47,8 @@ struct at86rf2xx_chip_data { ...@@ -47,6 +47,8 @@ struct at86rf2xx_chip_data {
u16 t_reset_to_off; u16 t_reset_to_off;
u16 t_off_to_aack; u16 t_off_to_aack;
u16 t_off_to_tx_on; u16 t_off_to_tx_on;
u16 t_off_to_sleep;
u16 t_sleep_to_off;
u16 t_frame; u16 t_frame;
u16 t_p_ack; u16 t_p_ack;
int rssi_base_val; int rssi_base_val;
...@@ -869,13 +871,33 @@ at86rf230_ed(struct ieee802154_hw *hw, u8 *level) ...@@ -869,13 +871,33 @@ at86rf230_ed(struct ieee802154_hw *hw, u8 *level)
static int static int
at86rf230_start(struct ieee802154_hw *hw) at86rf230_start(struct ieee802154_hw *hw)
{ {
struct at86rf230_local *lp = hw->priv;
if (gpio_is_valid(lp->slp_tr)) {
gpio_set_value(lp->slp_tr, 0);
usleep_range(lp->data->t_sleep_to_off,
lp->data->t_sleep_to_off + 100);
}
enable_irq(lp->spi->irq);
return at86rf230_sync_state_change(hw->priv, STATE_RX_AACK_ON); return at86rf230_sync_state_change(hw->priv, STATE_RX_AACK_ON);
} }
static void static void
at86rf230_stop(struct ieee802154_hw *hw) at86rf230_stop(struct ieee802154_hw *hw)
{ {
struct at86rf230_local *lp = hw->priv;
at86rf230_sync_state_change(hw->priv, STATE_FORCE_TRX_OFF); at86rf230_sync_state_change(hw->priv, STATE_FORCE_TRX_OFF);
disable_irq(lp->spi->irq);
if (gpio_is_valid(lp->slp_tr)) {
gpio_set_value(lp->slp_tr, 1);
usleep_range(lp->data->t_off_to_sleep,
lp->data->t_off_to_sleep + 10);
}
} }
static int static int
...@@ -1241,6 +1263,8 @@ static struct at86rf2xx_chip_data at86rf233_data = { ...@@ -1241,6 +1263,8 @@ static struct at86rf2xx_chip_data at86rf233_data = {
.t_reset_to_off = 26, .t_reset_to_off = 26,
.t_off_to_aack = 80, .t_off_to_aack = 80,
.t_off_to_tx_on = 80, .t_off_to_tx_on = 80,
.t_off_to_sleep = 35,
.t_sleep_to_off = 210,
.t_frame = 4096, .t_frame = 4096,
.t_p_ack = 545, .t_p_ack = 545,
.rssi_base_val = -91, .rssi_base_val = -91,
...@@ -1254,6 +1278,8 @@ static struct at86rf2xx_chip_data at86rf231_data = { ...@@ -1254,6 +1278,8 @@ static struct at86rf2xx_chip_data at86rf231_data = {
.t_reset_to_off = 37, .t_reset_to_off = 37,
.t_off_to_aack = 110, .t_off_to_aack = 110,
.t_off_to_tx_on = 110, .t_off_to_tx_on = 110,
.t_off_to_sleep = 35,
.t_sleep_to_off = 380,
.t_frame = 4096, .t_frame = 4096,
.t_p_ack = 545, .t_p_ack = 545,
.rssi_base_val = -91, .rssi_base_val = -91,
...@@ -1267,6 +1293,8 @@ static struct at86rf2xx_chip_data at86rf212_data = { ...@@ -1267,6 +1293,8 @@ static struct at86rf2xx_chip_data at86rf212_data = {
.t_reset_to_off = 26, .t_reset_to_off = 26,
.t_off_to_aack = 200, .t_off_to_aack = 200,
.t_off_to_tx_on = 200, .t_off_to_tx_on = 200,
.t_off_to_sleep = 35,
.t_sleep_to_off = 380,
.t_frame = 4096, .t_frame = 4096,
.t_p_ack = 545, .t_p_ack = 545,
.rssi_base_val = -100, .rssi_base_val = -100,
...@@ -1640,6 +1668,16 @@ static int at86rf230_probe(struct spi_device *spi) ...@@ -1640,6 +1668,16 @@ static int at86rf230_probe(struct spi_device *spi)
if (rc) if (rc)
goto free_dev; goto free_dev;
/* disable_irq by default and wait for starting hardware */
disable_irq(spi->irq);
/* going into sleep by default */
if (gpio_is_valid(slp_tr)) {
gpio_set_value(slp_tr, 1);
usleep_range(lp->data->t_off_to_sleep,
lp->data->t_off_to_sleep + 10);
}
rc = ieee802154_register_hw(lp->hw); rc = ieee802154_register_hw(lp->hw);
if (rc) if (rc)
goto free_dev; goto free_dev;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册