mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-15 17:52:45 +01:00
eb1279005c
Replace direct accesses to sched_active_thread and sched_active_pid with the helper functions thread_getpid() and thread_get_active(). This serves two purposes: 1. It makes accidental writes to those variable from outside core less likely. 2. Casting off the volatile qualifier is now well contained to those two functions
100 lines
2.9 KiB
C
100 lines
2.9 KiB
C
/*
|
|
* Copyright (C) 2017 Freie Universität Berlin
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
* directory for more details.
|
|
*/
|
|
|
|
/**
|
|
* @{
|
|
*
|
|
* @file
|
|
* @author Martine Lenders <m.lenders@fu-berlin.de>
|
|
*/
|
|
|
|
#include "common.h"
|
|
#include "msg.h"
|
|
#include "net/gnrc.h"
|
|
#include "net/ethernet.h"
|
|
#include "net/gnrc/ipv6/nib.h"
|
|
#include "net/gnrc/netif/ethernet.h"
|
|
#include "net/gnrc/netif/internal.h"
|
|
#include "net/netdev_test.h"
|
|
#include "sched.h"
|
|
#include "test_utils/expect.h"
|
|
#include "thread.h"
|
|
|
|
#define _MSG_QUEUE_SIZE (2)
|
|
|
|
gnrc_netif_t *_mock_netif = NULL;
|
|
static gnrc_netif_t _netif;
|
|
|
|
static netdev_test_t _mock_netdev;
|
|
static char _mock_netif_stack[THREAD_STACKSIZE_DEFAULT];
|
|
static gnrc_netreg_entry_t dumper;
|
|
static msg_t _main_msg_queue[_MSG_QUEUE_SIZE];
|
|
|
|
void _common_set_up(void)
|
|
{
|
|
expect(_mock_netif != NULL);
|
|
gnrc_ipv6_nib_init();
|
|
gnrc_netif_acquire(_mock_netif);
|
|
gnrc_ipv6_nib_init_iface(_mock_netif);
|
|
gnrc_netif_release(_mock_netif);
|
|
}
|
|
|
|
int _get_device_type(netdev_t *dev, void *value, size_t max_len)
|
|
{
|
|
(void)dev;
|
|
expect(max_len == sizeof(uint16_t));
|
|
*((uint16_t *)value) = NETDEV_TYPE_ETHERNET;
|
|
return sizeof(uint16_t);
|
|
}
|
|
|
|
int _get_max_packet_size(netdev_t *dev, void *value, size_t max_len)
|
|
{
|
|
(void)dev;
|
|
expect(max_len == sizeof(uint16_t));
|
|
*((uint16_t *)value) = ETHERNET_DATA_LEN;
|
|
return sizeof(uint16_t);
|
|
}
|
|
|
|
int _get_address(netdev_t *dev, void *value, size_t max_len)
|
|
{
|
|
static const uint8_t addr[] = { _LL0, _LL1, _LL2, _LL3, _LL4, _LL5 };
|
|
|
|
(void)dev;
|
|
expect(max_len >= sizeof(addr));
|
|
memcpy(value, addr, sizeof(addr));
|
|
return sizeof(addr);
|
|
}
|
|
|
|
void _tests_init(void)
|
|
{
|
|
msg_init_queue(_main_msg_queue, _MSG_QUEUE_SIZE);
|
|
netdev_test_setup(&_mock_netdev, 0);
|
|
netdev_test_set_get_cb(&_mock_netdev, NETOPT_DEVICE_TYPE,
|
|
_get_device_type);
|
|
netdev_test_set_get_cb(&_mock_netdev, NETOPT_MAX_PDU_SIZE,
|
|
_get_max_packet_size);
|
|
netdev_test_set_get_cb(&_mock_netdev, NETOPT_ADDRESS,
|
|
_get_address);
|
|
int res = gnrc_netif_ethernet_create(&_netif,
|
|
_mock_netif_stack, THREAD_STACKSIZE_DEFAULT, GNRC_NETIF_PRIO,
|
|
"mockup_eth", &_mock_netdev.netdev
|
|
);
|
|
_mock_netif = &_netif;
|
|
expect(res == 0);
|
|
/* we do not want to test for SLAAC here so just assure the configured
|
|
* address is valid */
|
|
expect(!ipv6_addr_is_unspecified(&_mock_netif->ipv6.addrs[0]));
|
|
_mock_netif->ipv6.addrs_flags[0] &= ~GNRC_NETIF_IPV6_ADDRS_FLAGS_STATE_MASK;
|
|
_mock_netif->ipv6.addrs_flags[0] |= GNRC_NETIF_IPV6_ADDRS_FLAGS_STATE_VALID;
|
|
gnrc_netreg_entry_init_pid(&dumper, GNRC_NETREG_DEMUX_CTX_ALL,
|
|
thread_getpid());
|
|
gnrc_netreg_register(GNRC_NETTYPE_NDP, &dumper);
|
|
}
|
|
|
|
/** @} */
|