/* * 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 #include #include #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()); } /** @} */