mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
1242 lines
53 KiB
C
1242 lines
53 KiB
C
/*
|
|
* Copyright (C) 2016 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
|
|
*/
|
|
#include <errno.h>
|
|
#include <stdint.h>
|
|
#include <string.h>
|
|
|
|
#include "embUnit/embUnit.h"
|
|
|
|
#include "byteorder.h"
|
|
#include "net/ieee802154.h"
|
|
|
|
#include "unittests-constants.h"
|
|
#include "tests-ieee802154.h"
|
|
|
|
static inline le_uint16_t byteorder_htols(uint16_t v)
|
|
{
|
|
return byteorder_btols(byteorder_htons(v));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_flags0(void)
|
|
{
|
|
const le_uint16_t src_pan = byteorder_htols(0);
|
|
const le_uint16_t dst_pan = byteorder_htols(0);
|
|
const uint8_t exp[] = { 0x00, IEEE802154_FCF_VERS_V1, TEST_UINT8 };
|
|
uint8_t res[sizeof(exp)];
|
|
const uint8_t flags = 0;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp),
|
|
ieee802154_set_frame_hdr(res, NULL, 0,
|
|
NULL, 0,
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp, res, sizeof(exp)));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_flags0_non_beacon_non_ack(void)
|
|
{
|
|
const le_uint16_t src_pan = byteorder_htols(0);
|
|
const le_uint16_t dst_pan = byteorder_htols(0);
|
|
const uint8_t flags = IEEE802154_FCF_TYPE_DATA;
|
|
uint8_t res;
|
|
|
|
TEST_ASSERT_EQUAL_INT(0,
|
|
ieee802154_set_frame_hdr(&res, NULL, 0,
|
|
NULL, 0,
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_bcast_src0(void)
|
|
{
|
|
const le_uint16_t src_pan = byteorder_htols(0);
|
|
const le_uint16_t dst_pan = byteorder_htols(TEST_UINT16);
|
|
/* IEEE 802.15.4 is little endian! */
|
|
const uint8_t exp[] = { 0x00,
|
|
IEEE802154_FCF_VERS_V1 |
|
|
IEEE802154_FCF_DST_ADDR_SHORT,
|
|
TEST_UINT8,
|
|
dst_pan.u8[0], dst_pan.u8[1],
|
|
0xff, 0xff };
|
|
uint8_t res[sizeof(exp)];
|
|
const uint8_t flags = IEEE802154_BCAST;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp),
|
|
ieee802154_set_frame_hdr(res, NULL, 0,
|
|
NULL, 0,
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp, res, sizeof(exp)));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_bcast_src2(void)
|
|
{
|
|
const network_uint16_t src = byteorder_htons(TEST_UINT16);
|
|
const le_uint16_t src_pan = byteorder_htols(TEST_UINT16 + 1);
|
|
const le_uint16_t dst_pan = byteorder_htols(TEST_UINT16 + 2);
|
|
/* IEEE 802.15.4 is little endian! */
|
|
const uint8_t exp[] = { 0x00,
|
|
IEEE802154_FCF_VERS_V1 |
|
|
IEEE802154_FCF_DST_ADDR_SHORT |
|
|
IEEE802154_FCF_SRC_ADDR_SHORT,
|
|
TEST_UINT8,
|
|
dst_pan.u8[0], dst_pan.u8[1],
|
|
0xff, 0xff,
|
|
src_pan.u8[0], src_pan.u8[1],
|
|
src.u8[1], src.u8[0] };
|
|
uint8_t res[sizeof(exp)];
|
|
const uint8_t flags = IEEE802154_BCAST;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp),
|
|
ieee802154_set_frame_hdr(res, src.u8, sizeof(src),
|
|
NULL, 0,
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp, res, sizeof(exp)));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_bcast_dst2_src2(void)
|
|
{
|
|
const network_uint16_t src = byteorder_htons(TEST_UINT16);
|
|
const le_uint16_t src_pan = byteorder_htols(TEST_UINT16 + 1);
|
|
const network_uint16_t dst = byteorder_htons(TEST_UINT16);
|
|
const le_uint16_t dst_pan = byteorder_htols(TEST_UINT16 + 2);
|
|
/* IEEE 802.15.4 is little endian! */
|
|
const uint8_t exp[] = { 0x00,
|
|
IEEE802154_FCF_VERS_V1 |
|
|
IEEE802154_FCF_DST_ADDR_SHORT |
|
|
IEEE802154_FCF_SRC_ADDR_SHORT,
|
|
TEST_UINT8,
|
|
dst_pan.u8[0], dst_pan.u8[1],
|
|
0xff, 0xff,
|
|
src_pan.u8[0], src_pan.u8[1],
|
|
src.u8[1], src.u8[0] };
|
|
uint8_t res[sizeof(exp)];
|
|
const uint8_t flags = IEEE802154_BCAST; /* broadcast flag lets dst be ignored */
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp),
|
|
ieee802154_set_frame_hdr(res, src.u8, sizeof(src),
|
|
dst.u8, sizeof(dst),
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp, res, sizeof(exp)));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_bcast_dst8_src2(void)
|
|
{
|
|
const network_uint16_t src = byteorder_htons(TEST_UINT16);
|
|
const le_uint16_t src_pan = byteorder_htols(TEST_UINT16 + 1);
|
|
const network_uint64_t dst = byteorder_htonll(TEST_UINT64);
|
|
const le_uint16_t dst_pan = byteorder_htols(TEST_UINT16 + 2);
|
|
/* IEEE 802.15.4 is little endian! */
|
|
const uint8_t exp[] = { 0x00,
|
|
IEEE802154_FCF_VERS_V1 |
|
|
/* broadcast address is short */
|
|
IEEE802154_FCF_DST_ADDR_SHORT |
|
|
IEEE802154_FCF_SRC_ADDR_SHORT,
|
|
TEST_UINT8,
|
|
dst_pan.u8[0], dst_pan.u8[1],
|
|
0xff, 0xff,
|
|
src_pan.u8[0], src_pan.u8[1],
|
|
src.u8[1], src.u8[0] };
|
|
uint8_t res[sizeof(exp)];
|
|
const uint8_t flags = IEEE802154_BCAST; /* broadcast flag lets dst be ignored */
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp),
|
|
ieee802154_set_frame_hdr(res, src.u8, sizeof(src),
|
|
dst.u8, sizeof(dst),
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp, res, sizeof(exp)));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_bcast_src8(void)
|
|
{
|
|
const network_uint64_t src = byteorder_htonll(TEST_UINT64);
|
|
const le_uint16_t src_pan = byteorder_htols(TEST_UINT16);
|
|
const le_uint16_t dst_pan = byteorder_htols(TEST_UINT16 + 1);
|
|
/* IEEE 802.15.4 is little endian! */
|
|
const uint8_t exp[] = { 0x00,
|
|
IEEE802154_FCF_VERS_V1 |
|
|
IEEE802154_FCF_DST_ADDR_SHORT |
|
|
IEEE802154_FCF_SRC_ADDR_LONG,
|
|
TEST_UINT8,
|
|
dst_pan.u8[0], dst_pan.u8[1],
|
|
0xff, 0xff,
|
|
src_pan.u8[0], src_pan.u8[1],
|
|
src.u8[7], src.u8[6], src.u8[5], src.u8[4],
|
|
src.u8[3], src.u8[2], src.u8[1], src.u8[0] };
|
|
uint8_t res[sizeof(exp)];
|
|
const uint8_t flags = IEEE802154_BCAST;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp),
|
|
ieee802154_set_frame_hdr(res, src.u8, sizeof(src),
|
|
NULL, 0,
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp, res, sizeof(exp)));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_dst0_src2(void)
|
|
{
|
|
const network_uint16_t src = byteorder_htons(TEST_UINT16);
|
|
const le_uint16_t src_pan = byteorder_htols(TEST_UINT16 + 1);
|
|
const le_uint16_t dst_pan = byteorder_htols(0);
|
|
/* IEEE 802.15.4 is little endian! */
|
|
const uint8_t exp[] = { IEEE802154_FCF_ACK_REQ,
|
|
IEEE802154_FCF_VERS_V1 |
|
|
IEEE802154_FCF_DST_ADDR_VOID |
|
|
IEEE802154_FCF_SRC_ADDR_SHORT,
|
|
TEST_UINT8,
|
|
src_pan.u8[0], src_pan.u8[1],
|
|
src.u8[1], src.u8[0] };
|
|
uint8_t res[sizeof(exp)];
|
|
const uint8_t flags = IEEE802154_FCF_ACK_REQ;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp),
|
|
ieee802154_set_frame_hdr(res, src.u8, sizeof(src),
|
|
NULL, 0,
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp, res, sizeof(exp)));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_dst0_src8(void)
|
|
{
|
|
const network_uint64_t src = byteorder_htonll(TEST_UINT64);
|
|
const le_uint16_t src_pan = byteorder_htols(TEST_UINT16);
|
|
const le_uint16_t dst_pan = byteorder_htols(0);
|
|
/* IEEE 802.15.4 is little endian! */
|
|
const uint8_t exp[] = { IEEE802154_FCF_FRAME_PEND,
|
|
IEEE802154_FCF_VERS_V1 |
|
|
IEEE802154_FCF_DST_ADDR_VOID |
|
|
IEEE802154_FCF_SRC_ADDR_LONG,
|
|
TEST_UINT8,
|
|
src_pan.u8[0], src_pan.u8[1],
|
|
src.u8[7], src.u8[6], src.u8[5], src.u8[4],
|
|
src.u8[3], src.u8[2], src.u8[1], src.u8[0] };
|
|
uint8_t res[sizeof(exp)];
|
|
const uint8_t flags = IEEE802154_FCF_FRAME_PEND;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp),
|
|
ieee802154_set_frame_hdr(res, src.u8, sizeof(src),
|
|
NULL, 0,
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp, res, sizeof(exp)));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_dst0_src8_pancomp(void)
|
|
{
|
|
const network_uint64_t src = byteorder_htonll(TEST_UINT64);
|
|
const le_uint16_t src_pan = byteorder_htols(TEST_UINT16);
|
|
const le_uint16_t dst_pan = byteorder_htols(0);
|
|
uint8_t res;
|
|
const uint8_t flags = IEEE802154_FCF_PAN_COMP;
|
|
|
|
TEST_ASSERT_EQUAL_INT(0,
|
|
ieee802154_set_frame_hdr(&res, src.u8, sizeof(src),
|
|
NULL, 0,
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_dst2_src0(void)
|
|
{
|
|
const network_uint16_t dst = byteorder_htons(TEST_UINT16);
|
|
const le_uint16_t src_pan = byteorder_htols(0);
|
|
const le_uint16_t dst_pan = byteorder_htols(TEST_UINT16 + 1);
|
|
/* IEEE 802.15.4 is little endian! */
|
|
const uint8_t exp[] = { IEEE802154_FCF_TYPE_DATA,
|
|
IEEE802154_FCF_VERS_V1 |
|
|
IEEE802154_FCF_DST_ADDR_SHORT |
|
|
IEEE802154_FCF_SRC_ADDR_VOID,
|
|
TEST_UINT8,
|
|
dst_pan.u8[0], dst_pan.u8[1],
|
|
dst.u8[1], dst.u8[0] };
|
|
uint8_t res[sizeof(exp)];
|
|
const uint8_t flags = IEEE802154_FCF_TYPE_DATA;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp),
|
|
ieee802154_set_frame_hdr(res, NULL, 0,
|
|
dst.u8, sizeof(dst),
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp, res, sizeof(exp)));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_dst2_src0_pancomp(void)
|
|
{
|
|
const network_uint16_t dst = byteorder_htons(TEST_UINT16);
|
|
const le_uint16_t src_pan = byteorder_htols(0);
|
|
const le_uint16_t dst_pan = byteorder_htols(TEST_UINT16 + 1);
|
|
uint8_t res;
|
|
const uint8_t flags = IEEE802154_FCF_PAN_COMP;
|
|
|
|
TEST_ASSERT_EQUAL_INT(0,
|
|
ieee802154_set_frame_hdr(&res, NULL, 0,
|
|
dst.u8, sizeof(dst),
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_dst2_src2(void)
|
|
{
|
|
const network_uint16_t src = byteorder_htons(TEST_UINT16);
|
|
const le_uint16_t src_pan = byteorder_htols(TEST_UINT16 + 1);
|
|
const network_uint16_t dst = byteorder_htons(TEST_UINT16 + 2);
|
|
const le_uint16_t dst_pan = byteorder_htols(TEST_UINT16 + 3);
|
|
/* IEEE 802.15.4 is little endian! */
|
|
const uint8_t exp[] = { IEEE802154_FCF_TYPE_DATA,
|
|
IEEE802154_FCF_VERS_V1 |
|
|
IEEE802154_FCF_DST_ADDR_SHORT |
|
|
IEEE802154_FCF_SRC_ADDR_SHORT,
|
|
TEST_UINT8,
|
|
dst_pan.u8[0], dst_pan.u8[1],
|
|
dst.u8[1], dst.u8[0],
|
|
src_pan.u8[0], src_pan.u8[1],
|
|
src.u8[1], src.u8[0] };
|
|
uint8_t res[sizeof(exp)];
|
|
const uint8_t flags = IEEE802154_FCF_TYPE_DATA;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp),
|
|
ieee802154_set_frame_hdr(res, src.u8, sizeof(src),
|
|
dst.u8, sizeof(dst),
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp, res, sizeof(exp)));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_dst2_src2_pancomp(void)
|
|
{
|
|
const network_uint16_t src = byteorder_htons(TEST_UINT16);
|
|
const le_uint16_t src_pan = byteorder_htols(TEST_UINT16 + 1);
|
|
const network_uint16_t dst = byteorder_htons(TEST_UINT16 + 2);
|
|
const le_uint16_t dst_pan = byteorder_htols(TEST_UINT16 + 3);
|
|
/* IEEE 802.15.4 is little endian! */
|
|
const uint8_t exp[] = { IEEE802154_FCF_TYPE_DATA | IEEE802154_FCF_PAN_COMP,
|
|
IEEE802154_FCF_VERS_V1 |
|
|
IEEE802154_FCF_DST_ADDR_SHORT |
|
|
IEEE802154_FCF_SRC_ADDR_SHORT,
|
|
TEST_UINT8,
|
|
dst_pan.u8[0], dst_pan.u8[1],
|
|
dst.u8[1], dst.u8[0],
|
|
/* src_pan compressed (and assumed equal to dst_pan) */
|
|
src.u8[1], src.u8[0] };
|
|
uint8_t res[sizeof(exp)];
|
|
const uint8_t flags = IEEE802154_FCF_TYPE_DATA | IEEE802154_FCF_PAN_COMP;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp),
|
|
ieee802154_set_frame_hdr(res, src.u8, sizeof(src),
|
|
dst.u8, sizeof(dst),
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp, res, sizeof(exp)));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_dst2_src8(void)
|
|
{
|
|
const network_uint64_t src = byteorder_htonll(TEST_UINT64);
|
|
const le_uint16_t src_pan = byteorder_htols(TEST_UINT16);
|
|
const network_uint16_t dst = byteorder_htons(TEST_UINT16 + 1);
|
|
const le_uint16_t dst_pan = byteorder_htols(TEST_UINT16 + 2);
|
|
/* IEEE 802.15.4 is little endian! */
|
|
const uint8_t exp[] = { IEEE802154_FCF_TYPE_DATA,
|
|
IEEE802154_FCF_VERS_V1 |
|
|
IEEE802154_FCF_DST_ADDR_SHORT |
|
|
IEEE802154_FCF_SRC_ADDR_LONG,
|
|
TEST_UINT8,
|
|
dst_pan.u8[0], dst_pan.u8[1],
|
|
dst.u8[1], dst.u8[0],
|
|
src_pan.u8[0], src_pan.u8[1],
|
|
src.u8[7], src.u8[6], src.u8[5], src.u8[4],
|
|
src.u8[3], src.u8[2], src.u8[1], src.u8[0] };
|
|
uint8_t res[sizeof(exp)];
|
|
const uint8_t flags = IEEE802154_FCF_TYPE_DATA;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp),
|
|
ieee802154_set_frame_hdr(res, src.u8, sizeof(src),
|
|
dst.u8, sizeof(dst),
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp, res, sizeof(exp)));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_dst2_src8_pancomp(void)
|
|
{
|
|
const network_uint64_t src = byteorder_htonll(TEST_UINT64);
|
|
const le_uint16_t src_pan = byteorder_htols(TEST_UINT16);
|
|
const network_uint16_t dst = byteorder_htons(TEST_UINT16 + 1);
|
|
const le_uint16_t dst_pan = byteorder_htols(TEST_UINT16 + 2);
|
|
/* IEEE 802.15.4 is little endian! */
|
|
const uint8_t exp[] = { IEEE802154_FCF_TYPE_DATA | IEEE802154_FCF_PAN_COMP,
|
|
IEEE802154_FCF_VERS_V1 |
|
|
IEEE802154_FCF_DST_ADDR_SHORT |
|
|
IEEE802154_FCF_SRC_ADDR_LONG,
|
|
TEST_UINT8,
|
|
dst_pan.u8[0], dst_pan.u8[1],
|
|
dst.u8[1], dst.u8[0],
|
|
/* src_pan compressed (and assumed equal to dst_pan) */
|
|
src.u8[7], src.u8[6], src.u8[5], src.u8[4],
|
|
src.u8[3], src.u8[2], src.u8[1], src.u8[0] };
|
|
uint8_t res[sizeof(exp)];
|
|
const uint8_t flags = IEEE802154_FCF_TYPE_DATA | IEEE802154_FCF_PAN_COMP;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp),
|
|
ieee802154_set_frame_hdr(res, src.u8, sizeof(src),
|
|
dst.u8, sizeof(dst),
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp, res, sizeof(exp)));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_dst8_src0(void)
|
|
{
|
|
const network_uint64_t dst = byteorder_htonll(TEST_UINT64);
|
|
const le_uint16_t src_pan = byteorder_htols(0);
|
|
const le_uint16_t dst_pan = byteorder_htols(TEST_UINT16);
|
|
/* IEEE 802.15.4 is little endian! */
|
|
const uint8_t exp[] = { IEEE802154_FCF_TYPE_BEACON,
|
|
IEEE802154_FCF_VERS_V1 |
|
|
IEEE802154_FCF_DST_ADDR_LONG |
|
|
IEEE802154_FCF_SRC_ADDR_VOID,
|
|
TEST_UINT8,
|
|
dst_pan.u8[0], dst_pan.u8[1],
|
|
dst.u8[7], dst.u8[6], dst.u8[5], dst.u8[4],
|
|
dst.u8[3], dst.u8[2], dst.u8[1], dst.u8[0] };
|
|
uint8_t res[sizeof(exp)];
|
|
const uint8_t flags = IEEE802154_FCF_TYPE_BEACON;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp),
|
|
ieee802154_set_frame_hdr(res, NULL, 0,
|
|
dst.u8, sizeof(dst),
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp, res, sizeof(exp)));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_dst8_src0_pancomp(void)
|
|
{
|
|
const network_uint64_t dst = byteorder_htonll(TEST_UINT64);
|
|
const le_uint16_t src_pan = byteorder_htols(0);
|
|
const le_uint16_t dst_pan = byteorder_htols(TEST_UINT16);
|
|
uint8_t res;
|
|
const uint8_t flags = IEEE802154_FCF_PAN_COMP;
|
|
|
|
TEST_ASSERT_EQUAL_INT(0,
|
|
ieee802154_set_frame_hdr(&res, NULL, 0,
|
|
dst.u8, sizeof(dst),
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_dst8_src2(void)
|
|
{
|
|
const network_uint16_t src = byteorder_htons(TEST_UINT16);
|
|
const le_uint16_t src_pan = byteorder_htols(TEST_UINT16 + 1);
|
|
const network_uint64_t dst = byteorder_htonll(TEST_UINT64);
|
|
const le_uint16_t dst_pan = byteorder_htols(TEST_UINT16 + 2);
|
|
/* IEEE 802.15.4 is little endian! */
|
|
const uint8_t exp[] = { IEEE802154_FCF_TYPE_BEACON,
|
|
IEEE802154_FCF_VERS_V1 |
|
|
IEEE802154_FCF_DST_ADDR_LONG |
|
|
IEEE802154_FCF_SRC_ADDR_SHORT,
|
|
TEST_UINT8,
|
|
dst_pan.u8[0], dst_pan.u8[1],
|
|
dst.u8[7], dst.u8[6], dst.u8[5], dst.u8[4],
|
|
dst.u8[3], dst.u8[2], dst.u8[1], dst.u8[0],
|
|
src_pan.u8[0], src_pan.u8[1],
|
|
src.u8[1], src.u8[0] };
|
|
uint8_t res[sizeof(exp)];
|
|
const uint8_t flags = IEEE802154_FCF_TYPE_BEACON;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp),
|
|
ieee802154_set_frame_hdr(res, src.u8, sizeof(src),
|
|
dst.u8, sizeof(dst),
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp, res, sizeof(exp)));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_dst8_src2_pancomp(void)
|
|
{
|
|
const network_uint16_t src = byteorder_htons(TEST_UINT16);
|
|
const le_uint16_t src_pan = byteorder_htols(TEST_UINT16 + 1);
|
|
const network_uint64_t dst = byteorder_htonll(TEST_UINT64);
|
|
const le_uint16_t dst_pan = byteorder_htols(TEST_UINT16 + 2);
|
|
/* IEEE 802.15.4 is little endian! */
|
|
const uint8_t exp[] = { IEEE802154_FCF_TYPE_BEACON | IEEE802154_FCF_PAN_COMP,
|
|
IEEE802154_FCF_VERS_V1 |
|
|
IEEE802154_FCF_DST_ADDR_LONG |
|
|
IEEE802154_FCF_SRC_ADDR_SHORT,
|
|
TEST_UINT8,
|
|
dst_pan.u8[0], dst_pan.u8[1],
|
|
dst.u8[7], dst.u8[6], dst.u8[5], dst.u8[4],
|
|
dst.u8[3], dst.u8[2], dst.u8[1], dst.u8[0],
|
|
/* src_pan compressed (and assumed equal to dst_pan) */
|
|
src.u8[1], src.u8[0] };
|
|
uint8_t res[sizeof(exp)];
|
|
const uint8_t flags = IEEE802154_FCF_TYPE_BEACON | IEEE802154_FCF_PAN_COMP;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp),
|
|
ieee802154_set_frame_hdr(res, src.u8, sizeof(src),
|
|
dst.u8, sizeof(dst),
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp, res, sizeof(exp)));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_dst8_src8(void)
|
|
{
|
|
const network_uint64_t src = byteorder_htonll(TEST_UINT64);
|
|
const le_uint16_t src_pan = byteorder_htols(TEST_UINT16);
|
|
const network_uint64_t dst = byteorder_htonll(TEST_UINT64);
|
|
const le_uint16_t dst_pan = byteorder_htols(TEST_UINT16 + 1);
|
|
/* IEEE 802.15.4 is little endian! */
|
|
const uint8_t exp[] = { IEEE802154_FCF_TYPE_BEACON,
|
|
IEEE802154_FCF_VERS_V1 |
|
|
IEEE802154_FCF_DST_ADDR_LONG |
|
|
IEEE802154_FCF_SRC_ADDR_LONG,
|
|
TEST_UINT8,
|
|
dst_pan.u8[0], dst_pan.u8[1],
|
|
dst.u8[7], dst.u8[6], dst.u8[5], dst.u8[4],
|
|
dst.u8[3], dst.u8[2], dst.u8[1], dst.u8[0],
|
|
src_pan.u8[0], src_pan.u8[1],
|
|
src.u8[7], src.u8[6], src.u8[5], src.u8[4],
|
|
src.u8[3], src.u8[2], src.u8[1], src.u8[0] };
|
|
uint8_t res[sizeof(exp)];
|
|
const uint8_t flags = IEEE802154_FCF_TYPE_BEACON;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp),
|
|
ieee802154_set_frame_hdr(res, src.u8, sizeof(src),
|
|
dst.u8, sizeof(dst),
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp, res, sizeof(exp)));
|
|
}
|
|
|
|
static void test_ieee802154_set_frame_hdr_dst8_src8_pancomp(void)
|
|
{
|
|
const network_uint64_t src = byteorder_htonll(TEST_UINT64);
|
|
const le_uint16_t src_pan = byteorder_htols(TEST_UINT16);
|
|
const network_uint64_t dst = byteorder_htonll(TEST_UINT64);
|
|
const le_uint16_t dst_pan = byteorder_htols(TEST_UINT16 + 1);
|
|
/* IEEE 802.15.4 is little endian! */
|
|
const uint8_t exp[] = { IEEE802154_FCF_TYPE_BEACON | IEEE802154_FCF_PAN_COMP,
|
|
IEEE802154_FCF_VERS_V1 |
|
|
IEEE802154_FCF_DST_ADDR_LONG |
|
|
IEEE802154_FCF_SRC_ADDR_LONG,
|
|
TEST_UINT8,
|
|
dst_pan.u8[0], dst_pan.u8[1],
|
|
dst.u8[7], dst.u8[6], dst.u8[5], dst.u8[4],
|
|
dst.u8[3], dst.u8[2], dst.u8[1], dst.u8[0],
|
|
/* src_pan compressed (and assumed equal to dst_pan) */
|
|
src.u8[7], src.u8[6], src.u8[5], src.u8[4],
|
|
src.u8[3], src.u8[2], src.u8[1], src.u8[0] };
|
|
uint8_t res[sizeof(exp)];
|
|
const uint8_t flags = IEEE802154_FCF_TYPE_BEACON | IEEE802154_FCF_PAN_COMP;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp),
|
|
ieee802154_set_frame_hdr(res, src.u8, sizeof(src),
|
|
dst.u8, sizeof(dst),
|
|
src_pan, dst_pan,
|
|
flags, TEST_UINT8));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp, res, sizeof(exp)));
|
|
}
|
|
|
|
static void test_ieee802154_get_frame_hdr_len_dst0_src0(void)
|
|
{
|
|
const uint8_t mhr[] = { 0x00, IEEE802154_FCF_DST_ADDR_VOID |
|
|
IEEE802154_FCF_SRC_ADDR_VOID };
|
|
|
|
TEST_ASSERT_EQUAL_INT(3, ieee802154_get_frame_hdr_len(mhr));
|
|
}
|
|
|
|
static void test_ieee802154_get_frame_hdr_len_dstr(void)
|
|
{
|
|
const uint8_t mhr[] = { 0x00, IEEE802154_FCF_DST_ADDR_RESV };
|
|
|
|
TEST_ASSERT_EQUAL_INT(0, ieee802154_get_frame_hdr_len(mhr));
|
|
}
|
|
|
|
static void test_ieee802154_get_frame_hdr_len_srcr(void)
|
|
{
|
|
const uint8_t mhr[] = { 0x00, IEEE802154_FCF_DST_ADDR_RESV };
|
|
|
|
TEST_ASSERT_EQUAL_INT(0, ieee802154_get_frame_hdr_len(mhr));
|
|
}
|
|
|
|
static void test_ieee802154_get_frame_hdr_len_dst2_src0(void)
|
|
{
|
|
const uint8_t mhr[] = { 0x00, IEEE802154_FCF_DST_ADDR_SHORT |
|
|
IEEE802154_FCF_SRC_ADDR_VOID };
|
|
|
|
TEST_ASSERT_EQUAL_INT(7, ieee802154_get_frame_hdr_len(mhr));
|
|
}
|
|
|
|
static void test_ieee802154_get_frame_hdr_len_dst8_src0(void)
|
|
{
|
|
const uint8_t mhr[] = { 0x00, IEEE802154_FCF_DST_ADDR_LONG };
|
|
|
|
TEST_ASSERT_EQUAL_INT(13, ieee802154_get_frame_hdr_len(mhr));
|
|
}
|
|
|
|
static void test_ieee802154_get_frame_hdr_len_dst0_src2(void)
|
|
{
|
|
const uint8_t mhr[] = { 0x00, IEEE802154_FCF_SRC_ADDR_SHORT };
|
|
|
|
TEST_ASSERT_EQUAL_INT(7, ieee802154_get_frame_hdr_len(mhr));
|
|
}
|
|
|
|
static void test_ieee802154_get_frame_hdr_len_dst0_src2_pancomp(void)
|
|
{
|
|
const uint8_t mhr[] = { IEEE802154_FCF_PAN_COMP, IEEE802154_FCF_SRC_ADDR_SHORT };
|
|
|
|
TEST_ASSERT_EQUAL_INT(0, ieee802154_get_frame_hdr_len(mhr));
|
|
}
|
|
|
|
static void test_ieee802154_get_frame_hdr_len_dst0_src8(void)
|
|
{
|
|
const uint8_t mhr[] = { 0x00, IEEE802154_FCF_SRC_ADDR_LONG };
|
|
|
|
TEST_ASSERT_EQUAL_INT(13, ieee802154_get_frame_hdr_len(mhr));
|
|
}
|
|
|
|
static void test_ieee802154_get_frame_hdr_len_dst0_src8_pancomp(void)
|
|
{
|
|
const uint8_t mhr[] = { IEEE802154_FCF_PAN_COMP, IEEE802154_FCF_SRC_ADDR_LONG };
|
|
|
|
TEST_ASSERT_EQUAL_INT(0, ieee802154_get_frame_hdr_len(mhr));
|
|
}
|
|
|
|
static void test_ieee802154_get_frame_hdr_len_dst2_src2(void)
|
|
{
|
|
const uint8_t mhr[] = { 0x00, IEEE802154_FCF_DST_ADDR_SHORT |
|
|
IEEE802154_FCF_SRC_ADDR_SHORT };
|
|
|
|
TEST_ASSERT_EQUAL_INT(11, ieee802154_get_frame_hdr_len(mhr));
|
|
}
|
|
|
|
static void test_ieee802154_get_frame_hdr_len_dst8_src2(void)
|
|
{
|
|
const uint8_t mhr[] = { 0x00, IEEE802154_FCF_DST_ADDR_LONG |
|
|
IEEE802154_FCF_SRC_ADDR_SHORT };
|
|
|
|
TEST_ASSERT_EQUAL_INT(17, ieee802154_get_frame_hdr_len(mhr));
|
|
}
|
|
|
|
static void test_ieee802154_get_frame_hdr_len_dst8_src8(void)
|
|
{
|
|
const uint8_t mhr[] = { 0x00, IEEE802154_FCF_DST_ADDR_LONG |
|
|
IEEE802154_FCF_SRC_ADDR_LONG };
|
|
|
|
TEST_ASSERT_EQUAL_INT(23, ieee802154_get_frame_hdr_len(mhr));
|
|
}
|
|
|
|
static void test_ieee802154_get_frame_hdr_len_dst2_src2_pancomp(void)
|
|
{
|
|
const uint8_t mhr[] = { IEEE802154_FCF_PAN_COMP, IEEE802154_FCF_DST_ADDR_SHORT |
|
|
IEEE802154_FCF_SRC_ADDR_SHORT };
|
|
|
|
TEST_ASSERT_EQUAL_INT(9, ieee802154_get_frame_hdr_len(mhr));
|
|
}
|
|
|
|
static void test_ieee802154_get_frame_hdr_len_dst8_src8_pancomp(void)
|
|
{
|
|
const uint8_t mhr[] = { IEEE802154_FCF_PAN_COMP, IEEE802154_FCF_DST_ADDR_LONG |
|
|
IEEE802154_FCF_SRC_ADDR_LONG };
|
|
|
|
TEST_ASSERT_EQUAL_INT(21, ieee802154_get_frame_hdr_len(mhr));
|
|
}
|
|
|
|
static void test_ieee802154_get_src_dstr(void)
|
|
{
|
|
const uint8_t mhr[] = { 0x00, IEEE802154_FCF_DST_ADDR_RESV };
|
|
uint8_t res_addr;
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(-EINVAL, ieee802154_get_src(mhr, &res_addr, &res_pan));
|
|
}
|
|
|
|
static void test_ieee802154_get_src_srcr(void)
|
|
{
|
|
const uint8_t mhr[] = { 0x00, IEEE802154_FCF_SRC_ADDR_RESV };
|
|
uint8_t res_addr;
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(-EINVAL, ieee802154_get_src(mhr, &res_addr, &res_pan));
|
|
}
|
|
|
|
static void test_ieee802154_get_src_dst0_pancomp(void)
|
|
{
|
|
const uint8_t mhr[] = { IEEE802154_FCF_PAN_COMP,
|
|
IEEE802154_FCF_DST_ADDR_VOID };
|
|
uint8_t res_addr;
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(-EINVAL, ieee802154_get_src(mhr, &res_addr, &res_pan));
|
|
}
|
|
|
|
static void test_ieee802154_get_src_dst0_src0(void)
|
|
{
|
|
const uint8_t mhr[] = { 0,
|
|
IEEE802154_FCF_DST_ADDR_VOID |
|
|
IEEE802154_FCF_SRC_ADDR_VOID,
|
|
TEST_UINT8 };
|
|
uint8_t res_addr;
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(0,
|
|
ieee802154_get_src(mhr, &res_addr, &res_pan));
|
|
}
|
|
|
|
static void test_ieee802154_get_src_dst0_src2(void)
|
|
{
|
|
const network_uint16_t exp_addr = byteorder_htons(TEST_UINT16);
|
|
const le_uint16_t exp_pan = byteorder_htols(TEST_UINT16 + 1);
|
|
const uint8_t mhr[] = { 0,
|
|
IEEE802154_FCF_DST_ADDR_VOID |
|
|
IEEE802154_FCF_SRC_ADDR_SHORT,
|
|
TEST_UINT8,
|
|
exp_pan.u8[0], exp_pan.u8[1],
|
|
exp_addr.u8[1], exp_addr.u8[0] };
|
|
uint8_t res_addr[sizeof(exp_addr)];
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp_addr),
|
|
ieee802154_get_src(mhr, res_addr, &res_pan));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp_addr.u8, res_addr, sizeof(exp_addr)));
|
|
TEST_ASSERT_EQUAL_INT(exp_pan.u16, res_pan.u16);
|
|
}
|
|
|
|
static void test_ieee802154_get_src_dst0_src8(void)
|
|
{
|
|
const network_uint64_t exp_addr = byteorder_htonll(TEST_UINT64);
|
|
const le_uint16_t exp_pan = byteorder_htols(TEST_UINT16);
|
|
const uint8_t mhr[] = { 0,
|
|
IEEE802154_FCF_DST_ADDR_VOID |
|
|
IEEE802154_FCF_SRC_ADDR_LONG,
|
|
TEST_UINT8,
|
|
exp_pan.u8[0], exp_pan.u8[1],
|
|
exp_addr.u8[7], exp_addr.u8[6],
|
|
exp_addr.u8[5], exp_addr.u8[4],
|
|
exp_addr.u8[3], exp_addr.u8[2],
|
|
exp_addr.u8[1], exp_addr.u8[0] };
|
|
uint8_t res_addr[sizeof(exp_addr)];
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp_addr),
|
|
ieee802154_get_src(mhr, res_addr, &res_pan));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp_addr.u8, res_addr, sizeof(exp_addr)));
|
|
TEST_ASSERT_EQUAL_INT(exp_pan.u16, res_pan.u16);
|
|
}
|
|
|
|
static void test_ieee802154_get_src_dst2_src0(void)
|
|
{
|
|
const uint8_t mhr[] = { 0,
|
|
IEEE802154_FCF_DST_ADDR_SHORT |
|
|
IEEE802154_FCF_SRC_ADDR_VOID,
|
|
TEST_UINT8,
|
|
TEST_UINT8 + 1, TEST_UINT8 + 2,
|
|
TEST_UINT8 + 3, TEST_UINT8 + 4 };
|
|
uint8_t res_addr;
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(0,
|
|
ieee802154_get_src(mhr, &res_addr, &res_pan));
|
|
}
|
|
|
|
static void test_ieee802154_get_src_dst2_src0_pancomp(void)
|
|
{
|
|
const uint8_t mhr[] = { IEEE802154_FCF_PAN_COMP,
|
|
IEEE802154_FCF_DST_ADDR_SHORT |
|
|
IEEE802154_FCF_SRC_ADDR_VOID,
|
|
TEST_UINT8 };
|
|
uint8_t res_addr;
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(0,
|
|
ieee802154_get_src(mhr, &res_addr, &res_pan));
|
|
}
|
|
|
|
static void test_ieee802154_get_src_dst2_src2(void)
|
|
{
|
|
const network_uint16_t exp_addr = byteorder_htons(TEST_UINT16);
|
|
const le_uint16_t exp_pan = byteorder_htols(TEST_UINT16 + 1);
|
|
const uint8_t mhr[] = { 0,
|
|
IEEE802154_FCF_DST_ADDR_SHORT |
|
|
IEEE802154_FCF_SRC_ADDR_SHORT,
|
|
TEST_UINT8,
|
|
TEST_UINT8 + 1, TEST_UINT8 + 2,
|
|
TEST_UINT8 + 3, TEST_UINT8 + 4,
|
|
exp_pan.u8[0], exp_pan.u8[1],
|
|
exp_addr.u8[1], exp_addr.u8[0] };
|
|
uint8_t res_addr[sizeof(exp_addr)];
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp_addr),
|
|
ieee802154_get_src(mhr, res_addr, &res_pan));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp_addr.u8, res_addr, sizeof(exp_addr)));
|
|
TEST_ASSERT_EQUAL_INT(exp_pan.u16, res_pan.u16);
|
|
}
|
|
|
|
static void test_ieee802154_get_src_dst2_src2_pancomp(void)
|
|
{
|
|
const network_uint16_t exp_addr = byteorder_htons(TEST_UINT16);
|
|
const le_uint16_t exp_pan = byteorder_htols(TEST_UINT16 + 1);
|
|
const uint8_t mhr[] = { IEEE802154_FCF_PAN_COMP,
|
|
IEEE802154_FCF_DST_ADDR_SHORT |
|
|
IEEE802154_FCF_SRC_ADDR_SHORT,
|
|
TEST_UINT8,
|
|
/* source PAN is dest. PAN due to compression */
|
|
exp_pan.u8[0], exp_pan.u8[1],
|
|
TEST_UINT8 + 1, TEST_UINT8 + 2,
|
|
exp_addr.u8[1], exp_addr.u8[0] };
|
|
uint8_t res_addr[sizeof(exp_addr)];
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp_addr),
|
|
ieee802154_get_src(mhr, res_addr, &res_pan));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp_addr.u8, res_addr, sizeof(exp_addr)));
|
|
TEST_ASSERT_EQUAL_INT(exp_pan.u16, res_pan.u16);
|
|
}
|
|
|
|
static void test_ieee802154_get_src_dst2_src8(void)
|
|
{
|
|
const network_uint64_t exp_addr = byteorder_htonll(TEST_UINT64);
|
|
const le_uint16_t exp_pan = byteorder_htols(TEST_UINT16);
|
|
const uint8_t mhr[] = { 0,
|
|
IEEE802154_FCF_DST_ADDR_SHORT |
|
|
IEEE802154_FCF_SRC_ADDR_LONG,
|
|
TEST_UINT8,
|
|
TEST_UINT8 + 1, TEST_UINT8 + 2,
|
|
TEST_UINT8 + 3, TEST_UINT8 + 4,
|
|
exp_pan.u8[0], exp_pan.u8[1],
|
|
exp_addr.u8[7], exp_addr.u8[6],
|
|
exp_addr.u8[5], exp_addr.u8[4],
|
|
exp_addr.u8[3], exp_addr.u8[2],
|
|
exp_addr.u8[1], exp_addr.u8[0] };
|
|
uint8_t res_addr[sizeof(exp_addr)];
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp_addr),
|
|
ieee802154_get_src(mhr, res_addr, &res_pan));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp_addr.u8, res_addr, sizeof(exp_addr)));
|
|
TEST_ASSERT_EQUAL_INT(exp_pan.u16, res_pan.u16);
|
|
}
|
|
|
|
static void test_ieee802154_get_src_dst2_src8_pancomp(void)
|
|
{
|
|
const network_uint64_t exp_addr = byteorder_htonll(TEST_UINT64);
|
|
const le_uint16_t exp_pan = byteorder_htols(TEST_UINT16);
|
|
const uint8_t mhr[] = { IEEE802154_FCF_PAN_COMP,
|
|
IEEE802154_FCF_DST_ADDR_SHORT |
|
|
IEEE802154_FCF_SRC_ADDR_LONG,
|
|
TEST_UINT8,
|
|
/* source PAN is dest. PAN due to compression */
|
|
exp_pan.u8[0], exp_pan.u8[1],
|
|
TEST_UINT8 + 1, TEST_UINT8 + 2,
|
|
exp_addr.u8[7], exp_addr.u8[6],
|
|
exp_addr.u8[5], exp_addr.u8[4],
|
|
exp_addr.u8[3], exp_addr.u8[2],
|
|
exp_addr.u8[1], exp_addr.u8[0] };
|
|
uint8_t res_addr[sizeof(exp_addr)];
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp_addr),
|
|
ieee802154_get_src(mhr, res_addr, &res_pan));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp_addr.u8, res_addr, sizeof(exp_addr)));
|
|
TEST_ASSERT_EQUAL_INT(exp_pan.u16, res_pan.u16);
|
|
}
|
|
|
|
static void test_ieee802154_get_src_dst8_src0(void)
|
|
{
|
|
const uint8_t mhr[] = { 0,
|
|
IEEE802154_FCF_DST_ADDR_LONG |
|
|
IEEE802154_FCF_SRC_ADDR_VOID,
|
|
TEST_UINT8,
|
|
TEST_UINT8 + 1, TEST_UINT8 + 2,
|
|
TEST_UINT8 + 3, TEST_UINT8 + 4,
|
|
TEST_UINT8 + 5, TEST_UINT8 + 6,
|
|
TEST_UINT8 + 7, TEST_UINT8 + 8,
|
|
TEST_UINT8 + 9, TEST_UINT8 + 10 };
|
|
uint8_t res_addr;
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(0,
|
|
ieee802154_get_src(mhr, &res_addr, &res_pan));
|
|
}
|
|
|
|
static void test_ieee802154_get_src_dst8_src0_pancomp(void)
|
|
{
|
|
const uint8_t mhr[] = { IEEE802154_FCF_PAN_COMP,
|
|
IEEE802154_FCF_DST_ADDR_LONG |
|
|
IEEE802154_FCF_SRC_ADDR_VOID,
|
|
TEST_UINT8 };
|
|
uint8_t res_addr;
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(0,
|
|
ieee802154_get_src(mhr, &res_addr, &res_pan));
|
|
}
|
|
|
|
static void test_ieee802154_get_src_dst8_src2(void)
|
|
{
|
|
const network_uint16_t exp_addr = byteorder_htons(TEST_UINT16);
|
|
const le_uint16_t exp_pan = byteorder_htols(TEST_UINT16);
|
|
const uint8_t mhr[] = { 0,
|
|
IEEE802154_FCF_DST_ADDR_LONG |
|
|
IEEE802154_FCF_SRC_ADDR_SHORT,
|
|
TEST_UINT8,
|
|
TEST_UINT8 + 1, TEST_UINT8 + 2,
|
|
TEST_UINT8 + 3, TEST_UINT8 + 4,
|
|
TEST_UINT8 + 5, TEST_UINT8 + 6,
|
|
TEST_UINT8 + 7, TEST_UINT8 + 8,
|
|
TEST_UINT8 + 9, TEST_UINT8 + 10,
|
|
exp_pan.u8[0], exp_pan.u8[1],
|
|
exp_addr.u8[1], exp_addr.u8[0] };
|
|
uint8_t res_addr[sizeof(exp_addr)];
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp_addr),
|
|
ieee802154_get_src(mhr, res_addr, &res_pan));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp_addr.u8, res_addr, sizeof(exp_addr)));
|
|
TEST_ASSERT_EQUAL_INT(exp_pan.u16, res_pan.u16);
|
|
}
|
|
|
|
static void test_ieee802154_get_src_dst8_src2_pancomp(void)
|
|
{
|
|
const network_uint16_t exp_addr = byteorder_htons(TEST_UINT16);
|
|
const le_uint16_t exp_pan = byteorder_htols(TEST_UINT16);
|
|
const uint8_t mhr[] = { IEEE802154_FCF_PAN_COMP,
|
|
IEEE802154_FCF_DST_ADDR_LONG |
|
|
IEEE802154_FCF_SRC_ADDR_SHORT,
|
|
TEST_UINT8,
|
|
/* source PAN is dest. PAN due to compression */
|
|
exp_pan.u8[0], exp_pan.u8[1],
|
|
TEST_UINT8 + 1, TEST_UINT8 + 2,
|
|
TEST_UINT8 + 3, TEST_UINT8 + 4,
|
|
TEST_UINT8 + 5, TEST_UINT8 + 6,
|
|
TEST_UINT8 + 7, TEST_UINT8 + 8,
|
|
exp_addr.u8[1], exp_addr.u8[0] };
|
|
uint8_t res_addr[sizeof(exp_addr)];
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp_addr),
|
|
ieee802154_get_src(mhr, res_addr, &res_pan));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp_addr.u8, res_addr, sizeof(exp_addr)));
|
|
TEST_ASSERT_EQUAL_INT(exp_pan.u16, res_pan.u16);
|
|
}
|
|
|
|
static void test_ieee802154_get_src_dst8_src8(void)
|
|
{
|
|
const network_uint64_t exp_addr = byteorder_htonll(TEST_UINT64);
|
|
const le_uint16_t exp_pan = byteorder_htols(TEST_UINT16);
|
|
const uint8_t mhr[] = { 0,
|
|
IEEE802154_FCF_DST_ADDR_LONG |
|
|
IEEE802154_FCF_SRC_ADDR_LONG,
|
|
TEST_UINT8,
|
|
TEST_UINT8 + 1, TEST_UINT8 + 2,
|
|
TEST_UINT8 + 3, TEST_UINT8 + 4,
|
|
TEST_UINT8 + 5, TEST_UINT8 + 6,
|
|
TEST_UINT8 + 7, TEST_UINT8 + 8,
|
|
TEST_UINT8 + 9, TEST_UINT8 + 10,
|
|
exp_pan.u8[0], exp_pan.u8[1],
|
|
exp_addr.u8[7], exp_addr.u8[6],
|
|
exp_addr.u8[5], exp_addr.u8[4],
|
|
exp_addr.u8[3], exp_addr.u8[2],
|
|
exp_addr.u8[1], exp_addr.u8[0] };
|
|
uint8_t res_addr[sizeof(exp_addr)];
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp_addr),
|
|
ieee802154_get_src(mhr, res_addr, &res_pan));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp_addr.u8, res_addr, sizeof(exp_addr)));
|
|
TEST_ASSERT_EQUAL_INT(exp_pan.u16, res_pan.u16);
|
|
}
|
|
|
|
static void test_ieee802154_get_src_dst8_src8_pancomp(void)
|
|
{
|
|
const network_uint64_t exp_addr = byteorder_htonll(TEST_UINT64);
|
|
const le_uint16_t exp_pan = byteorder_htols(TEST_UINT16);
|
|
const uint8_t mhr[] = { IEEE802154_FCF_PAN_COMP,
|
|
IEEE802154_FCF_DST_ADDR_LONG |
|
|
IEEE802154_FCF_SRC_ADDR_LONG,
|
|
TEST_UINT8,
|
|
/* source PAN is dest. PAN due to compression */
|
|
exp_pan.u8[0], exp_pan.u8[1],
|
|
TEST_UINT8 + 1, TEST_UINT8 + 2,
|
|
TEST_UINT8 + 3, TEST_UINT8 + 4,
|
|
TEST_UINT8 + 5, TEST_UINT8 + 6,
|
|
TEST_UINT8 + 7, TEST_UINT8 + 8,
|
|
exp_addr.u8[7], exp_addr.u8[6],
|
|
exp_addr.u8[5], exp_addr.u8[4],
|
|
exp_addr.u8[3], exp_addr.u8[2],
|
|
exp_addr.u8[1], exp_addr.u8[0] };
|
|
uint8_t res_addr[sizeof(exp_addr)];
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp_addr),
|
|
ieee802154_get_src(mhr, res_addr, &res_pan));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp_addr.u8, res_addr, sizeof(exp_addr)));
|
|
TEST_ASSERT_EQUAL_INT(exp_pan.u16, res_pan.u16);
|
|
}
|
|
|
|
static void test_ieee802154_get_dst_dstr(void)
|
|
{
|
|
const uint8_t mhr[] = { 0x00, IEEE802154_FCF_DST_ADDR_RESV,
|
|
TEST_UINT8 };
|
|
uint8_t res_addr;
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(-EINVAL, ieee802154_get_src(mhr, &res_addr, &res_pan));
|
|
}
|
|
|
|
static void test_ieee802154_get_dst_dst0(void)
|
|
{
|
|
const uint8_t mhr[] = { 0,
|
|
IEEE802154_FCF_DST_ADDR_VOID,
|
|
TEST_UINT8 };
|
|
uint8_t res_addr;
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(0,
|
|
ieee802154_get_dst(mhr, &res_addr, &res_pan));
|
|
}
|
|
|
|
static void test_ieee802154_get_dst_dst0_pancomp(void)
|
|
{
|
|
const uint8_t mhr[] = { IEEE802154_FCF_PAN_COMP,
|
|
IEEE802154_FCF_DST_ADDR_VOID,
|
|
TEST_UINT8 };
|
|
uint8_t res_addr;
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(-EINVAL, ieee802154_get_src(mhr, &res_addr, &res_pan));
|
|
}
|
|
|
|
static void test_ieee802154_get_dst_dst2(void)
|
|
{
|
|
const network_uint16_t exp_addr = byteorder_htons(TEST_UINT16);
|
|
const le_uint16_t exp_pan = byteorder_htols(TEST_UINT16 + 1);
|
|
const uint8_t mhr[] = { 0,
|
|
IEEE802154_FCF_DST_ADDR_SHORT,
|
|
TEST_UINT8,
|
|
exp_pan.u8[0], exp_pan.u8[1],
|
|
exp_addr.u8[1], exp_addr.u8[0] };
|
|
uint8_t res_addr[sizeof(exp_addr)];
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp_addr),
|
|
ieee802154_get_dst(mhr, res_addr, &res_pan));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp_addr.u8, res_addr, sizeof(exp_addr)));
|
|
TEST_ASSERT_EQUAL_INT(exp_pan.u16, res_pan.u16);
|
|
}
|
|
|
|
static void test_ieee802154_get_dst_dst2_pancomp(void)
|
|
{
|
|
const network_uint16_t exp_addr = byteorder_htons(TEST_UINT16);
|
|
const le_uint16_t exp_pan = byteorder_htols(TEST_UINT16 + 1);
|
|
const uint8_t mhr[] = { IEEE802154_FCF_PAN_COMP,
|
|
IEEE802154_FCF_DST_ADDR_SHORT,
|
|
TEST_UINT8,
|
|
exp_pan.u8[0], exp_pan.u8[1],
|
|
exp_addr.u8[1], exp_addr.u8[0] };
|
|
uint8_t res_addr[sizeof(exp_addr)];
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp_addr),
|
|
ieee802154_get_dst(mhr, res_addr, &res_pan));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp_addr.u8, res_addr, sizeof(exp_addr)));
|
|
TEST_ASSERT_EQUAL_INT(exp_pan.u16, res_pan.u16);
|
|
}
|
|
|
|
static void test_ieee802154_get_dst_dst8(void)
|
|
{
|
|
const network_uint64_t exp_addr = byteorder_htonll(TEST_UINT64);
|
|
const le_uint16_t exp_pan = byteorder_htols(TEST_UINT16);
|
|
const uint8_t mhr[] = { 0,
|
|
IEEE802154_FCF_DST_ADDR_LONG,
|
|
TEST_UINT8,
|
|
exp_pan.u8[0], exp_pan.u8[1],
|
|
exp_addr.u8[7], exp_addr.u8[6],
|
|
exp_addr.u8[5], exp_addr.u8[4],
|
|
exp_addr.u8[3], exp_addr.u8[2],
|
|
exp_addr.u8[1], exp_addr.u8[0] };
|
|
uint8_t res_addr[sizeof(exp_addr)];
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp_addr),
|
|
ieee802154_get_dst(mhr, res_addr, &res_pan));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp_addr.u8, res_addr, sizeof(exp_addr)));
|
|
TEST_ASSERT_EQUAL_INT(exp_pan.u16, res_pan.u16);
|
|
}
|
|
|
|
static void test_ieee802154_get_dst_dst8_pancomp(void)
|
|
{
|
|
const network_uint64_t exp_addr = byteorder_htonll(TEST_UINT64);
|
|
const le_uint16_t exp_pan = byteorder_htols(TEST_UINT16);
|
|
const uint8_t mhr[] = { IEEE802154_FCF_PAN_COMP,
|
|
IEEE802154_FCF_DST_ADDR_LONG,
|
|
TEST_UINT8,
|
|
exp_pan.u8[0], exp_pan.u8[1],
|
|
exp_addr.u8[7], exp_addr.u8[6],
|
|
exp_addr.u8[5], exp_addr.u8[4],
|
|
exp_addr.u8[3], exp_addr.u8[2],
|
|
exp_addr.u8[1], exp_addr.u8[0] };
|
|
uint8_t res_addr[sizeof(exp_addr)];
|
|
le_uint16_t res_pan;
|
|
|
|
TEST_ASSERT_EQUAL_INT(sizeof(exp_addr),
|
|
ieee802154_get_dst(mhr, res_addr, &res_pan));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp(exp_addr.u8, res_addr, sizeof(exp_addr)));
|
|
TEST_ASSERT_EQUAL_INT(exp_pan.u16, res_pan.u16);
|
|
}
|
|
|
|
static void test_ieee802154_get_seq(void)
|
|
{
|
|
const uint8_t mhr[] = { 0x00, 0x00, TEST_UINT8 };
|
|
|
|
TEST_ASSERT_EQUAL_INT(TEST_UINT8, ieee802154_get_seq(mhr));
|
|
}
|
|
|
|
static void test_ieee802154_get_iid_addr_len_0(void)
|
|
{
|
|
const uint8_t addr[] = { 0x01, 0x23 };
|
|
eui64_t iid;
|
|
|
|
TEST_ASSERT_NULL(ieee802154_get_iid(&iid, addr, 0));
|
|
}
|
|
|
|
static void test_ieee802154_get_iid_addr_len_SIZE_MAX(void)
|
|
{
|
|
const uint8_t addr[] = { 0x01, 0x23 };
|
|
eui64_t iid;
|
|
|
|
TEST_ASSERT_NULL(ieee802154_get_iid(&iid, addr, SIZE_MAX));
|
|
}
|
|
|
|
static void test_ieee802154_get_iid_addr_len_2(void)
|
|
{
|
|
const uint8_t addr[] = { 0x01, 0x23 };
|
|
const uint8_t exp[] = { 0x00, 0x00, 0x00, 0xff, 0xfe, 0x00, 0x01, 0x23 };
|
|
eui64_t iid;
|
|
|
|
TEST_ASSERT_NOT_NULL(ieee802154_get_iid(&iid, addr, sizeof(addr)));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp((const char *)exp, (char *) &iid, sizeof(iid)));
|
|
}
|
|
|
|
static void test_ieee802154_get_iid_addr_len_4(void)
|
|
{
|
|
const uint8_t addr[] = { 0x01, 0x23, 0x45, 0x67 };
|
|
const uint8_t exp[] = { 0x03, 0x23, 0x00, 0xff, 0xfe, 0x00, 0x45, 0x67 };
|
|
eui64_t iid;
|
|
|
|
TEST_ASSERT_NOT_NULL(ieee802154_get_iid(&iid, addr, sizeof(addr)));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp((const char *)exp, (char *) &iid, sizeof(iid)));
|
|
}
|
|
|
|
static void test_ieee802154_get_iid_addr_len_8(void)
|
|
{
|
|
const uint8_t addr[] = { 0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef };
|
|
const uint8_t exp[] = { 0x03, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef };
|
|
eui64_t iid;
|
|
|
|
TEST_ASSERT_NOT_NULL(ieee802154_get_iid(&iid, addr, sizeof(addr)));
|
|
TEST_ASSERT_EQUAL_INT(0, memcmp((const char *)exp, (char *) &iid, sizeof(iid)));
|
|
}
|
|
|
|
Test *tests_ieee802154_tests(void)
|
|
{
|
|
EMB_UNIT_TESTFIXTURES(fixtures) {
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_flags0),
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_flags0_non_beacon_non_ack),
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_bcast_src0),
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_bcast_src2),
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_bcast_dst2_src2),
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_bcast_dst8_src2),
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_bcast_src8),
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_dst0_src2),
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_dst0_src8),
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_dst0_src8_pancomp),
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_dst2_src0),
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_dst2_src0_pancomp),
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_dst2_src2),
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_dst2_src2_pancomp),
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_dst2_src8),
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_dst2_src8_pancomp),
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_dst8_src0),
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_dst8_src0_pancomp),
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_dst8_src2),
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_dst8_src2_pancomp),
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_dst8_src8),
|
|
new_TestFixture(test_ieee802154_set_frame_hdr_dst8_src8_pancomp),
|
|
new_TestFixture(test_ieee802154_get_frame_hdr_len_dst0_src0),
|
|
new_TestFixture(test_ieee802154_get_frame_hdr_len_dstr),
|
|
new_TestFixture(test_ieee802154_get_frame_hdr_len_srcr),
|
|
new_TestFixture(test_ieee802154_get_frame_hdr_len_dst2_src0),
|
|
new_TestFixture(test_ieee802154_get_frame_hdr_len_dst8_src0),
|
|
new_TestFixture(test_ieee802154_get_frame_hdr_len_dst0_src2),
|
|
new_TestFixture(test_ieee802154_get_frame_hdr_len_dst0_src2_pancomp),
|
|
new_TestFixture(test_ieee802154_get_frame_hdr_len_dst0_src8),
|
|
new_TestFixture(test_ieee802154_get_frame_hdr_len_dst0_src8_pancomp),
|
|
new_TestFixture(test_ieee802154_get_frame_hdr_len_dst2_src2),
|
|
new_TestFixture(test_ieee802154_get_frame_hdr_len_dst8_src2),
|
|
new_TestFixture(test_ieee802154_get_frame_hdr_len_dst8_src8),
|
|
new_TestFixture(test_ieee802154_get_frame_hdr_len_dst2_src2_pancomp),
|
|
new_TestFixture(test_ieee802154_get_frame_hdr_len_dst8_src8_pancomp),
|
|
new_TestFixture(test_ieee802154_get_src_dstr),
|
|
new_TestFixture(test_ieee802154_get_src_srcr),
|
|
new_TestFixture(test_ieee802154_get_src_dst0_pancomp),
|
|
new_TestFixture(test_ieee802154_get_src_dst0_src0),
|
|
new_TestFixture(test_ieee802154_get_src_dst0_src2),
|
|
new_TestFixture(test_ieee802154_get_src_dst0_src8),
|
|
new_TestFixture(test_ieee802154_get_src_dst2_src0),
|
|
new_TestFixture(test_ieee802154_get_src_dst2_src0_pancomp),
|
|
new_TestFixture(test_ieee802154_get_src_dst2_src2),
|
|
new_TestFixture(test_ieee802154_get_src_dst2_src2_pancomp),
|
|
new_TestFixture(test_ieee802154_get_src_dst2_src8),
|
|
new_TestFixture(test_ieee802154_get_src_dst2_src8_pancomp),
|
|
new_TestFixture(test_ieee802154_get_src_dst8_src0),
|
|
new_TestFixture(test_ieee802154_get_src_dst8_src0_pancomp),
|
|
new_TestFixture(test_ieee802154_get_src_dst8_src2),
|
|
new_TestFixture(test_ieee802154_get_src_dst8_src2_pancomp),
|
|
new_TestFixture(test_ieee802154_get_src_dst8_src8),
|
|
new_TestFixture(test_ieee802154_get_src_dst8_src8_pancomp),
|
|
new_TestFixture(test_ieee802154_get_dst_dstr),
|
|
new_TestFixture(test_ieee802154_get_dst_dst0),
|
|
new_TestFixture(test_ieee802154_get_dst_dst0_pancomp),
|
|
new_TestFixture(test_ieee802154_get_dst_dst2),
|
|
new_TestFixture(test_ieee802154_get_dst_dst2_pancomp),
|
|
new_TestFixture(test_ieee802154_get_dst_dst8),
|
|
new_TestFixture(test_ieee802154_get_dst_dst8_pancomp),
|
|
new_TestFixture(test_ieee802154_get_seq),
|
|
new_TestFixture(test_ieee802154_get_iid_addr_len_0),
|
|
new_TestFixture(test_ieee802154_get_iid_addr_len_SIZE_MAX),
|
|
new_TestFixture(test_ieee802154_get_iid_addr_len_2),
|
|
new_TestFixture(test_ieee802154_get_iid_addr_len_4),
|
|
new_TestFixture(test_ieee802154_get_iid_addr_len_8),
|
|
};
|
|
|
|
EMB_UNIT_TESTCALLER(ieee802154_tests, NULL, NULL, fixtures);
|
|
|
|
return (Test *)&ieee802154_tests;
|
|
}
|
|
|
|
void tests_ieee802154(void)
|
|
{
|
|
TESTS_RUN(tests_ieee802154_tests());
|
|
}
|
|
/** @} */
|