/* * VAS_EBOOT -- GRand Unified Bootloader * Copyright (C) 2015 Free Software Foundation, Inc. * * VAS_EBOOT is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * VAS_EBOOT is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with VAS_EBOOT. If not, see . */ #include #include #include VAS_EBOOT_MOD_LICENSE ("GPLv3+"); static VasEBoot_uint64_t vectors[] = { 0xffffffffffffffffULL, 1, 2, 0, 0x0102030405060708ULL }; static void test16 (VasEBoot_uint16_t a) { VasEBoot_uint16_t b, c; VasEBoot_uint8_t *ap, *bp; int i; b = VasEBoot_swap_bytes16 (a); c = VasEBoot_swap_bytes16 (b); VasEBoot_test_assert (a == c, "bswap not idempotent: 0x%llx, 0x%llx, 0x%llx", (long long) a, (long long) b, (long long) c); ap = (VasEBoot_uint8_t *) &a; bp = (VasEBoot_uint8_t *) &b; for (i = 0; i < 2; i++) { VasEBoot_test_assert (ap[i] == bp[1 - i], "bswap bytes wrong: 0x%llx, 0x%llx", (long long) a, (long long) b); } } static void test32 (VasEBoot_uint32_t a) { VasEBoot_uint32_t b, c; VasEBoot_uint8_t *ap, *bp; int i; b = VasEBoot_swap_bytes32 (a); c = VasEBoot_swap_bytes32 (b); VasEBoot_test_assert (a == c, "bswap not idempotent: 0x%llx, 0x%llx, 0x%llx", (long long) a, (long long) b, (long long) c); ap = (VasEBoot_uint8_t *) &a; bp = (VasEBoot_uint8_t *) &b; for (i = 0; i < 4; i++) { VasEBoot_test_assert (ap[i] == bp[3 - i], "bswap bytes wrong: 0x%llx, 0x%llx", (long long) a, (long long) b); } } static void test64 (VasEBoot_uint64_t a) { VasEBoot_uint64_t b, c; VasEBoot_uint8_t *ap, *bp; int i; b = VasEBoot_swap_bytes64 (a); c = VasEBoot_swap_bytes64 (b); VasEBoot_test_assert (a == c, "bswap not idempotent: 0x%llx, 0x%llx, 0x%llx", (long long) a, (long long) b, (long long) c); ap = (VasEBoot_uint8_t *) &a; bp = (VasEBoot_uint8_t *) &b; for (i = 0; i < 4; i++) { VasEBoot_test_assert (ap[i] == bp[7 - i], "bswap bytes wrong: 0x%llx, 0x%llx", (long long) a, (long long) b); } } static void test_all(VasEBoot_uint64_t a) { test64 (a); test32 (a); test16 (a); } static void bswap_test (void) { VasEBoot_uint64_t a = 404, b = 7; VasEBoot_size_t i; for (i = 0; i < ARRAY_SIZE (vectors); i++) { test_all (vectors[i]); } for (i = 0; i < 40000; i++) { a = 17 * a + 13 * b; b = 23 * a + 29 * b; if (b == 0) b = 1; if (a == 0) a = 1; test_all (a); test_all (b); } } /* Register example_test method as a functional test. */ VAS_EBOOT_FUNCTIONAL_TEST (bswap_test, bswap_test);