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:
parent
52c8be9da9
commit
a18ec987bf
@ -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 */
|
|
||||||
/** @} */
|
/** @} */
|
||||||
|
|
||||||
|
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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");
|
||||||
|
Loading…
Reference in New Issue
Block a user