1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-17 05:12:57 +01:00

Merge pull request #15188 from benpicco/drivers/kw41zrf-register

drivers/kw41zrf: register with netdev
This commit is contained in:
benpicco 2020-10-31 14:30:00 +01:00 committed by GitHub
commit e77d12da26
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 16 additions and 14 deletions

View File

@ -135,8 +135,10 @@ typedef struct {
* @brief Setup an KW41ZRF based device state
*
* @param[out] dev device descriptor
* @param[in] index index of @p params in a global parameter struct array.
* If initialized manually, pass a unique identifier instead.
*/
void kw41zrf_setup(kw41zrf_t *dev);
void kw41zrf_setup(kw41zrf_t *dev, uint8_t index);
/**
* @brief Initialize the given KW41ZRF device

View File

@ -283,6 +283,7 @@ typedef enum {
NETDEV_CC2538,
NETDEV_DOSE,
NETDEV_ENC28J60,
NETDEV_KW41ZRF,
NETDEV_MRF24J40,
NETDEV_NRF802154,
/* add more if needed */

View File

@ -1,4 +1,3 @@
USEMODULE += luid
USEMODULE += netif
USEMODULE += ieee802154
USEMODULE += netdev_ieee802154

View File

@ -21,7 +21,6 @@
#include "log.h"
#include "msg.h"
#include "luid.h"
#include "net/gnrc.h"
#include "net/ieee802154.h"
@ -39,23 +38,24 @@
static void kw41zrf_set_address(kw41zrf_t *dev)
{
DEBUG("[kw41zrf] Set MAC address\n");
eui64_t addr_long;
network_uint16_t addr_short;
/* get unique IDs to use as hardware addresses */
luid_get_eui64(&addr_long);
luid_get_short(&addr_short);
/* set short and long address */
kw41zrf_set_addr_long(dev, &addr_long);
kw41zrf_set_addr_short(dev, &addr_short);
kw41zrf_set_addr_long(dev, (eui64_t *)&dev->netdev.long_addr);
kw41zrf_set_addr_short(dev, (network_uint16_t *)&dev->netdev.short_addr);
}
void kw41zrf_setup(kw41zrf_t *dev)
void kw41zrf_setup(kw41zrf_t *dev, uint8_t index)
{
netdev_t *netdev = (netdev_t *)dev;
netdev->driver = &kw41zrf_driver;
/* register with netdev */
netdev_register(netdev, NETDEV_KW41ZRF, index);
/* get unique IDs to use as hardware addresses */
netdev_ieee802154_setup(&dev->netdev);
/* initialize device descriptor */
dev->idle_seq = XCVSEQ_RECEIVE;
dev->pm_blocked = 0;

View File

@ -82,7 +82,7 @@ void openthread_bootstrap(void)
netdev_t *netdev = (netdev_t *) &at86rf2xx_dev;
#endif
#ifdef MODULE_KW41ZRF
kw41zrf_setup(&kw41z_dev);
kw41zrf_setup(&kw41z_dev, 0);
netdev_t *netdev = (netdev_t *) &kw41z_dev;
#endif
#ifdef MODULE_CC2538_RF

View File

@ -56,7 +56,7 @@ void auto_init_kw41zrf(void)
{
for (unsigned i = 0; i < KW41ZRF_NUMOF; i++) {
LOG_DEBUG("[auto_init_netif] initializing kw41zrf #%u\n", i);
kw41zrf_setup(&kw41zrf_devs[i]);
kw41zrf_setup(&kw41zrf_devs[i], i);
#if defined(MODULE_GNRC_GOMACH)
gnrc_netif_gomach_create(&_netif[i], _kw41zrf_stacks[i], KW41ZRF_NETIF_STACKSIZE,