mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
Merge pull request #3059 from authmillenon/ng_netif/api/adapt-ng_netif_get
ng_netif: adapt ng_netif_get for holey lists
This commit is contained in:
commit
627dd72d7d
@ -83,12 +83,12 @@ void ng_netif_remove(kernel_pid_t pid);
|
||||
/**
|
||||
* @brief Get all active interfaces.
|
||||
*
|
||||
* @param[out] size Size of the resulting array.
|
||||
* @param[out] netifs List of all active interfaces. There is no order ensured.
|
||||
* It must at least fit @ref NG_NETIF_NUMOF elements.
|
||||
*
|
||||
* @return All active interfaces. If @p size is 0 on return, the return value
|
||||
* is undefined. No order must be ensured.
|
||||
* @return The number of active interfaces.
|
||||
*/
|
||||
kernel_pid_t *ng_netif_get(size_t *size);
|
||||
size_t ng_netif_get(kernel_pid_t *netifs);
|
||||
|
||||
/**
|
||||
* @brief Converts a hardware address to a human readable string.
|
||||
|
@ -91,13 +91,17 @@ void ng_netif_remove(kernel_pid_t pid)
|
||||
ifs[i] = KERNEL_PID_UNDEF; /* set in case of i == (NG_NETIF_NUMOF - 1) */
|
||||
}
|
||||
|
||||
kernel_pid_t *ng_netif_get(size_t *size)
|
||||
size_t ng_netif_get(kernel_pid_t *netifs)
|
||||
{
|
||||
for (*size = 0;
|
||||
(*size < NG_NETIF_NUMOF) && (ifs[*size] != KERNEL_PID_UNDEF);
|
||||
(*size)++);
|
||||
size_t size = 0;
|
||||
|
||||
return ifs;
|
||||
for (int i = 0; i < NG_NETIF_NUMOF; i++) {
|
||||
if (ifs[i] != KERNEL_PID_UNDEF) {
|
||||
netifs[size++] = ifs[i];
|
||||
}
|
||||
}
|
||||
|
||||
return size;
|
||||
}
|
||||
|
||||
/** @} */
|
||||
|
@ -326,12 +326,11 @@ static void _send_multicast(kernel_pid_t iface, ng_pktsnip_t *pkt,
|
||||
bool prep_hdr)
|
||||
{
|
||||
ng_pktsnip_t *netif;
|
||||
kernel_pid_t *ifs;
|
||||
size_t ifnum;
|
||||
kernel_pid_t ifs[NG_NETIF_NUMOF];
|
||||
|
||||
if (iface == KERNEL_PID_UNDEF) {
|
||||
/* get list of interfaces */
|
||||
ifs = ng_netif_get(&ifnum);
|
||||
size_t ifnum = ng_netif_get(ifs);
|
||||
|
||||
/* throw away packet if no one is interested */
|
||||
if (ifnum == 0) {
|
||||
|
@ -220,10 +220,8 @@ void ng_ndp_retrans_nbr_sol(ng_ipv6_nc_t *nc_entry)
|
||||
|
||||
if (nc_entry->iface == KERNEL_PID_UNDEF) {
|
||||
timex_t t = { 0, NG_NDP_RETRANS_TIMER };
|
||||
kernel_pid_t *ifs;
|
||||
size_t ifnum;
|
||||
|
||||
ifs = ng_netif_get(&ifnum);
|
||||
kernel_pid_t ifs[NG_NETIF_NUMOF];
|
||||
size_t ifnum = ng_netif_get(ifs);
|
||||
|
||||
for (size_t i = 0; i < ifnum; i++) {
|
||||
_send_nbr_sol(ifs[i], &nc_entry->ipv6_addr, &dst);
|
||||
@ -413,10 +411,8 @@ kernel_pid_t ng_ndp_next_hop_l2addr(uint8_t *l2addr, uint8_t *l2addr_len,
|
||||
|
||||
if (iface == KERNEL_PID_UNDEF) {
|
||||
timex_t t = { 0, NG_NDP_RETRANS_TIMER };
|
||||
kernel_pid_t *ifs;
|
||||
size_t ifnum;
|
||||
|
||||
ifs = ng_netif_get(&ifnum);
|
||||
kernel_pid_t ifs[NG_NETIF_NUMOF];
|
||||
size_t ifnum = ng_netif_get(ifs);
|
||||
|
||||
for (size_t i = 0; i < ifnum; i++) {
|
||||
_send_nbr_sol(ifs[i], next_hop_ip, &dst_sol);
|
||||
|
@ -87,8 +87,8 @@ static void _print_nc_type(ng_ipv6_nc_t *entry)
|
||||
static bool _is_iface(kernel_pid_t iface)
|
||||
{
|
||||
#ifdef MODULE_NG_NETIF
|
||||
size_t numof;
|
||||
kernel_pid_t *ifs = ng_netif_get(&numof);
|
||||
kernel_pid_t ifs[NG_NETIF_NUMOF];
|
||||
size_t numof = ng_netif_get(ifs);
|
||||
|
||||
for (size_t i = 0; i < numof; i++) {
|
||||
if (ifs[i] == iface) {
|
||||
|
@ -52,8 +52,8 @@ static bool _is_number(char *str)
|
||||
|
||||
static bool _is_iface(kernel_pid_t dev)
|
||||
{
|
||||
size_t numof;
|
||||
kernel_pid_t *ifs = ng_netif_get(&numof);
|
||||
kernel_pid_t ifs[NG_NETIF_NUMOF];
|
||||
size_t numof = ng_netif_get(ifs);
|
||||
|
||||
for (size_t i = 0; i < numof; i++) {
|
||||
if (ifs[i] == dev) {
|
||||
@ -700,8 +700,8 @@ int _netif_send(int argc, char **argv)
|
||||
int _netif_config(int argc, char **argv)
|
||||
{
|
||||
if (argc < 2) {
|
||||
size_t numof;
|
||||
kernel_pid_t *ifs = ng_netif_get(&numof);
|
||||
kernel_pid_t ifs[NG_NETIF_NUMOF];
|
||||
size_t numof = ng_netif_get(ifs);
|
||||
|
||||
for (size_t i = 0; i < numof; i++) {
|
||||
_netif_list(ifs[i]);
|
||||
|
@ -80,14 +80,14 @@ static void test_ipv6_netif_add__success(void)
|
||||
|
||||
static void test_netif_add__success_with_ipv6(void)
|
||||
{
|
||||
kernel_pid_t *pids;
|
||||
kernel_pid_t pids[NG_NETIF_NUMOF];
|
||||
size_t pid_num;
|
||||
ng_ipv6_netif_t *entry;
|
||||
ng_ipv6_addr_t exp_addr = NG_IPV6_ADDR_ALL_NODES_LINK_LOCAL;
|
||||
|
||||
ng_netif_add(DEFAULT_TEST_NETIF);
|
||||
|
||||
TEST_ASSERT_NOT_NULL((pids = ng_netif_get(&pid_num)));
|
||||
TEST_ASSERT_NOT_NULL((pid_num = ng_netif_get(pids)));
|
||||
TEST_ASSERT_EQUAL_INT(1, pid_num);
|
||||
TEST_ASSERT_EQUAL_INT(DEFAULT_TEST_NETIF, pids[0]);
|
||||
TEST_ASSERT_NOT_NULL((entry = ng_ipv6_netif_get(DEFAULT_TEST_NETIF)));
|
||||
|
@ -29,10 +29,11 @@ static void set_up(void)
|
||||
|
||||
static void test_ng_netif_add__KERNEL_PID_UNDEF(void)
|
||||
{
|
||||
size_t size = TEST_UINT8;
|
||||
kernel_pid_t ifs[NG_NETIF_NUMOF];
|
||||
size_t size;
|
||||
|
||||
TEST_ASSERT_EQUAL_INT(0, ng_netif_add(KERNEL_PID_UNDEF));
|
||||
ng_netif_get(&size);
|
||||
size = ng_netif_get(ifs);
|
||||
TEST_ASSERT_EQUAL_INT(0, size);
|
||||
}
|
||||
|
||||
@ -47,75 +48,75 @@ static void test_ng_netif_add__memfull(void)
|
||||
|
||||
static void test_ng_netif_add__success(void)
|
||||
{
|
||||
size_t size = TEST_UINT8;
|
||||
kernel_pid_t *res = NULL;
|
||||
kernel_pid_t ifs[NG_NETIF_NUMOF];
|
||||
size_t size;
|
||||
|
||||
TEST_ASSERT_EQUAL_INT(0, ng_netif_add(TEST_UINT8));
|
||||
|
||||
res = ng_netif_get(&size);
|
||||
size = ng_netif_get(ifs);
|
||||
TEST_ASSERT_EQUAL_INT(1, size);
|
||||
TEST_ASSERT_EQUAL_INT(TEST_UINT8, res[0]);
|
||||
TEST_ASSERT_EQUAL_INT(TEST_UINT8, ifs[0]);
|
||||
}
|
||||
|
||||
static void test_ng_netif_add__duplicate_entry(void)
|
||||
{
|
||||
size_t size = TEST_UINT8;
|
||||
kernel_pid_t *res = NULL;
|
||||
kernel_pid_t ifs[NG_NETIF_NUMOF];
|
||||
size_t size;
|
||||
|
||||
for (int i = 0; i < NG_NETIF_NUMOF + 4; i++) {
|
||||
TEST_ASSERT_EQUAL_INT(0, ng_netif_add(TEST_UINT8));
|
||||
}
|
||||
|
||||
res = ng_netif_get(&size);
|
||||
size = ng_netif_get(ifs);
|
||||
TEST_ASSERT_EQUAL_INT(1, size);
|
||||
TEST_ASSERT_EQUAL_INT(TEST_UINT8, res[0]);
|
||||
TEST_ASSERT_EQUAL_INT(TEST_UINT8, ifs[0]);
|
||||
}
|
||||
|
||||
static void test_ng_netif_remove__KERNEL_PID_UNDEF(void)
|
||||
{
|
||||
size_t size = TEST_UINT8;
|
||||
kernel_pid_t *res = NULL;
|
||||
kernel_pid_t ifs[NG_NETIF_NUMOF];
|
||||
size_t size;
|
||||
|
||||
test_ng_netif_add__success();
|
||||
|
||||
ng_netif_remove(KERNEL_PID_UNDEF);
|
||||
|
||||
res = ng_netif_get(&size);
|
||||
size = ng_netif_get(ifs);
|
||||
TEST_ASSERT_EQUAL_INT(1, size);
|
||||
TEST_ASSERT_EQUAL_INT(TEST_UINT8, res[0]);
|
||||
TEST_ASSERT_EQUAL_INT(TEST_UINT8, ifs[0]);
|
||||
}
|
||||
|
||||
static void test_ng_netif_remove__not_an_if(void)
|
||||
{
|
||||
size_t size = TEST_UINT8;
|
||||
kernel_pid_t *res = NULL;
|
||||
kernel_pid_t ifs[NG_NETIF_NUMOF];
|
||||
size_t size;
|
||||
|
||||
test_ng_netif_add__success();
|
||||
|
||||
ng_netif_remove(TEST_UINT8 + 1);
|
||||
|
||||
res = ng_netif_get(&size);
|
||||
size = ng_netif_get(ifs);
|
||||
TEST_ASSERT_EQUAL_INT(1, size);
|
||||
TEST_ASSERT_EQUAL_INT(TEST_UINT8, res[0]);
|
||||
TEST_ASSERT_EQUAL_INT(TEST_UINT8, ifs[0]);
|
||||
}
|
||||
|
||||
static void test_ng_netif_remove__success(void)
|
||||
{
|
||||
size_t size = TEST_UINT8;
|
||||
kernel_pid_t ifs[NG_NETIF_NUMOF];
|
||||
size_t size;
|
||||
|
||||
test_ng_netif_add__success();
|
||||
|
||||
ng_netif_remove(TEST_UINT8);
|
||||
|
||||
ng_netif_get(&size);
|
||||
size = ng_netif_get(ifs);
|
||||
TEST_ASSERT_EQUAL_INT(0, size);
|
||||
}
|
||||
|
||||
static void test_ng_netif_get__empty(void)
|
||||
{
|
||||
size_t size = TEST_UINT8;
|
||||
|
||||
ng_netif_get(&size);
|
||||
kernel_pid_t ifs[NG_NETIF_NUMOF];
|
||||
size_t size = ng_netif_get(ifs);
|
||||
TEST_ASSERT_EQUAL_INT(0, size);
|
||||
}
|
||||
|
||||
@ -123,8 +124,8 @@ static void test_ng_netif_get__empty(void)
|
||||
* are gotten regardless */
|
||||
static void test_ng_netif_get__success_3_minus_one(void)
|
||||
{
|
||||
size_t size = TEST_UINT8;
|
||||
kernel_pid_t *ifs;
|
||||
kernel_pid_t ifs[NG_NETIF_NUMOF];
|
||||
size_t size;
|
||||
int count = 0;
|
||||
|
||||
for (int i = 0; i < 3; i++) {
|
||||
@ -133,7 +134,7 @@ static void test_ng_netif_get__success_3_minus_one(void)
|
||||
|
||||
ng_netif_remove(TEST_UINT8 + 1);
|
||||
|
||||
ifs = ng_netif_get(&size);
|
||||
size = ng_netif_get(ifs);
|
||||
TEST_ASSERT_EQUAL_INT(2, size);
|
||||
|
||||
for (size_t i = 0; i < size; i++) {
|
||||
@ -147,13 +148,14 @@ static void test_ng_netif_get__success_3_minus_one(void)
|
||||
|
||||
static void test_ng_netif_get__full(void)
|
||||
{
|
||||
size_t size = TEST_UINT8;
|
||||
kernel_pid_t ifs[NG_NETIF_NUMOF];
|
||||
size_t size;
|
||||
|
||||
for (int i = 0; i < NG_NETIF_NUMOF; i++) {
|
||||
TEST_ASSERT_EQUAL_INT(0, ng_netif_add(TEST_UINT8 + i));
|
||||
}
|
||||
|
||||
TEST_ASSERT_NOT_NULL(ng_netif_get(&size));
|
||||
size = ng_netif_get(ifs);
|
||||
TEST_ASSERT_EQUAL_INT(NG_NETIF_NUMOF, size);
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user