Commit fc0719e6 authored by Alexander Aring's avatar Alexander Aring Committed by Marcel Holtmann

at86rf230: use STATE_TX_ARET mode only

This patch changes the state change behaviour of at86rf230 to always
TX_ARET mode. According the at86rf2xx datasheets TX_ARET mode doesn't
mean to be always waiting for ack frames after transmit. The transceiver
will automatically wait for ack frames or not if the acknowledge request
bit is set. See section "TX_ARET_ON – Transmit with Automatic Frame
Retransmission and CSMA-CA Retry".
Reviewed-by: default avatarStefan Schmidt <stefan@osg.samsung.com>
Signed-off-by: default avatarAlexander Aring <alex.aring@gmail.com>
Signed-off-by: default avatarMarcel Holtmann <marcel@holtmann.org>
parent 89c7d788
...@@ -97,9 +97,7 @@ struct at86rf230_local { ...@@ -97,9 +97,7 @@ struct at86rf230_local {
struct at86rf230_state_change irq; struct at86rf230_state_change irq;
bool tx_aret;
unsigned long cal_timeout; unsigned long cal_timeout;
s8 max_frame_retries;
bool is_tx; bool is_tx;
bool is_tx_from_off; bool is_tx_from_off;
u8 tx_retry; u8 tx_retry;
...@@ -651,7 +649,7 @@ at86rf230_tx_complete(void *context) ...@@ -651,7 +649,7 @@ at86rf230_tx_complete(void *context)
enable_irq(ctx->irq); enable_irq(ctx->irq);
ieee802154_xmit_complete(lp->hw, lp->tx_skb, !lp->tx_aret); ieee802154_xmit_complete(lp->hw, lp->tx_skb, false);
} }
static void static void
...@@ -760,17 +758,10 @@ at86rf230_irq_trx_end(struct at86rf230_local *lp) ...@@ -760,17 +758,10 @@ at86rf230_irq_trx_end(struct at86rf230_local *lp)
{ {
if (lp->is_tx) { if (lp->is_tx) {
lp->is_tx = 0; lp->is_tx = 0;
at86rf230_async_state_change(lp, &lp->irq,
if (lp->tx_aret) STATE_FORCE_TX_ON,
at86rf230_async_state_change(lp, &lp->irq, at86rf230_tx_trac_status,
STATE_FORCE_TX_ON, true);
at86rf230_tx_trac_status,
true);
else
at86rf230_async_state_change(lp, &lp->irq,
STATE_RX_AACK_ON,
at86rf230_tx_complete,
true);
} else { } else {
at86rf230_async_read_reg(lp, RG_TRX_STATE, &lp->irq, at86rf230_async_read_reg(lp, RG_TRX_STATE, &lp->irq,
at86rf230_rx_trac_check, true); at86rf230_rx_trac_check, true);
...@@ -876,24 +867,16 @@ at86rf230_xmit_start(void *context) ...@@ -876,24 +867,16 @@ at86rf230_xmit_start(void *context)
struct at86rf230_state_change *ctx = context; struct at86rf230_state_change *ctx = context;
struct at86rf230_local *lp = ctx->lp; struct at86rf230_local *lp = ctx->lp;
/* In ARET mode we need to go into STATE_TX_ARET_ON after we /* check if we change from off state */
* are in STATE_TX_ON. The pfad differs here, so we change if (lp->is_tx_from_off) {
* the complete handler. lp->is_tx_from_off = false;
*/ at86rf230_async_state_change(lp, ctx, STATE_TX_ARET_ON,
if (lp->tx_aret) { at86rf230_write_frame,
if (lp->is_tx_from_off) { false);
lp->is_tx_from_off = false;
at86rf230_async_state_change(lp, ctx, STATE_TX_ARET_ON,
at86rf230_write_frame,
false);
} else {
at86rf230_async_state_change(lp, ctx, STATE_TX_ON,
at86rf230_xmit_tx_on,
false);
}
} else { } else {
at86rf230_async_state_change(lp, ctx, STATE_TX_ON, at86rf230_async_state_change(lp, ctx, STATE_TX_ON,
at86rf230_write_frame, false); at86rf230_xmit_tx_on,
false);
} }
} }
...@@ -1267,15 +1250,8 @@ static int ...@@ -1267,15 +1250,8 @@ static int
at86rf230_set_frame_retries(struct ieee802154_hw *hw, s8 retries) at86rf230_set_frame_retries(struct ieee802154_hw *hw, s8 retries)
{ {
struct at86rf230_local *lp = hw->priv; struct at86rf230_local *lp = hw->priv;
int rc = 0;
lp->tx_aret = retries >= 0;
lp->max_frame_retries = retries;
if (retries >= 0) return at86rf230_write_subreg(lp, SR_MAX_FRAME_RETRIES, retries);
rc = at86rf230_write_subreg(lp, SR_MAX_FRAME_RETRIES, retries);
return rc;
} }
static int static int
......
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