1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00

drivers/mrf24j40: make TX/RX IRQs read only

This brings the implementation in sync with the API.
This commit is contained in:
Marian Buschsieweke 2021-02-26 10:53:22 +01:00
parent 52c8be9da9
commit a18ec987bf
No known key found for this signature in database
GPG Key ID: 61F64C6599B1539F
3 changed files with 4 additions and 54 deletions

View File

@ -96,14 +96,6 @@ extern "C" {
#define MRF24J40_OPT_PROMISCUOUS (0x0200) /**< promiscuous mode #define MRF24J40_OPT_PROMISCUOUS (0x0200) /**< promiscuous mode
* active */ * active */
#define MRF24J40_OPT_PRELOADING (0x0400) /**< preloading enabled */ #define MRF24J40_OPT_PRELOADING (0x0400) /**< preloading enabled */
#define MRF24J40_OPT_TELL_TX_START (0x0800) /**< notify MAC layer on TX
* start */
#define MRF24J40_OPT_TELL_TX_END (0x1000) /**< notify MAC layer on TX
* finished */
#define MRF24J40_OPT_TELL_RX_START (0x2000) /**< notify MAC layer on RX
* start */
#define MRF24J40_OPT_TELL_RX_END (0x4000) /**< notify MAC layer on RX
* finished */
/** @} */ /** @} */

View File

@ -156,7 +156,7 @@ void mrf24j40_tx_exec(mrf24j40_t *dev)
else { else {
mrf24j40_reg_write_short(dev, MRF24J40_REG_TXNCON, MRF24J40_TXNCON_TXNTRIG); mrf24j40_reg_write_short(dev, MRF24J40_REG_TXNCON, MRF24J40_TXNCON_TXNTRIG);
} }
if (netdev->event_callback && (dev->netdev.flags & MRF24J40_OPT_TELL_TX_START)) { if (netdev->event_callback) {
netdev->event_callback(netdev, NETDEV_EVENT_TX_STARTED); netdev->event_callback(netdev, NETDEV_EVENT_TX_STARTED);
} }
} }

View File

@ -231,26 +231,10 @@ static int _get(netdev_t *netdev, netopt_t opt, void *val, size_t max_len)
break; break;
case NETOPT_RX_START_IRQ: case NETOPT_RX_START_IRQ:
*((netopt_enable_t *)val) =
!!(dev->netdev.flags & MRF24J40_OPT_TELL_RX_START);
res = sizeof(netopt_enable_t);
break;
case NETOPT_RX_END_IRQ: case NETOPT_RX_END_IRQ:
*((netopt_enable_t *)val) =
!!(dev->netdev.flags & MRF24J40_OPT_TELL_RX_END);
res = sizeof(netopt_enable_t);
break;
case NETOPT_TX_START_IRQ: case NETOPT_TX_START_IRQ:
*((netopt_enable_t *)val) =
!!(dev->netdev.flags & MRF24J40_OPT_TELL_TX_START);
res = sizeof(netopt_enable_t);
break;
case NETOPT_TX_END_IRQ: case NETOPT_TX_END_IRQ:
*((netopt_enable_t *)val) = *((netopt_enable_t *)val) = NETOPT_ENABLE;
!!(dev->netdev.flags & MRF24J40_OPT_TELL_TX_END);
res = sizeof(netopt_enable_t); res = sizeof(netopt_enable_t);
break; break;
@ -486,30 +470,6 @@ static int _set(netdev_t *netdev, netopt_t opt, const void *val, size_t len)
res = sizeof(netopt_enable_t); res = sizeof(netopt_enable_t);
break; break;
case NETOPT_RX_START_IRQ:
mrf24j40_set_option(dev, MRF24J40_OPT_TELL_RX_START,
((const bool *)val)[0]);
res = sizeof(netopt_enable_t);
break;
case NETOPT_RX_END_IRQ:
mrf24j40_set_option(dev, MRF24J40_OPT_TELL_RX_END,
((const bool *)val)[0]);
res = sizeof(netopt_enable_t);
break;
case NETOPT_TX_START_IRQ:
mrf24j40_set_option(dev, MRF24J40_OPT_TELL_TX_START,
((const bool *)val)[0]);
res = sizeof(netopt_enable_t);
break;
case NETOPT_TX_END_IRQ:
mrf24j40_set_option(dev, MRF24J40_OPT_TELL_TX_END,
((const bool *)val)[0]);
res = sizeof(netopt_enable_t);
break;
case NETOPT_CSMA: case NETOPT_CSMA:
mrf24j40_set_option(dev, MRF24J40_OPT_CSMA, mrf24j40_set_option(dev, MRF24J40_OPT_CSMA,
((const bool *)val)[0]); ((const bool *)val)[0]);
@ -570,7 +530,7 @@ static void _isr(netdev_t *netdev)
dev->pending &= ~(MRF24J40_TASK_TX_READY); dev->pending &= ~(MRF24J40_TASK_TX_READY);
DEBUG("[mrf24j40] EVT - TX_END\n"); DEBUG("[mrf24j40] EVT - TX_END\n");
#ifdef MODULE_NETSTATS_L2 #ifdef MODULE_NETSTATS_L2
if (netdev->event_callback && (dev->netdev.flags & MRF24J40_OPT_TELL_TX_END)) { if (netdev->event_callback) {
uint8_t txstat = mrf24j40_reg_read_short(dev, MRF24J40_REG_TXSTAT); uint8_t txstat = mrf24j40_reg_read_short(dev, MRF24J40_REG_TXSTAT);
dev->tx_retries = (txstat >> MRF24J40_TXSTAT_MAX_FRAME_RETRIES_SHIFT); dev->tx_retries = (txstat >> MRF24J40_TXSTAT_MAX_FRAME_RETRIES_SHIFT);
/* transmission failed */ /* transmission failed */
@ -595,9 +555,7 @@ static void _isr(netdev_t *netdev)
/* Receive interrupt occurred */ /* Receive interrupt occurred */
if (dev->pending & MRF24J40_TASK_RX_READY) { if (dev->pending & MRF24J40_TASK_RX_READY) {
DEBUG("[mrf24j40] EVT - RX_END\n"); DEBUG("[mrf24j40] EVT - RX_END\n");
if ((dev->netdev.flags & MRF24J40_OPT_TELL_RX_END)) { netdev->event_callback(netdev, NETDEV_EVENT_RX_COMPLETE);
netdev->event_callback(netdev, NETDEV_EVENT_RX_COMPLETE);
}
dev->pending &= ~(MRF24J40_TASK_RX_READY); dev->pending &= ~(MRF24J40_TASK_RX_READY);
} }
DEBUG("[mrf24j40] END IRQ\n"); DEBUG("[mrf24j40] END IRQ\n");