mirror of
https://github.com/Telecominfraproject/OpenCellular.git
synced 2025-11-24 02:05:01 +00:00
These were macros that were never used, or that were only set to one thing and could be substituted up front. I left in code guarded by the HAVE_ENDIAN_H and HAVE_LITTLE_ENDIAN macros even though those are never defined because they guard a reportedly significantly faster implementation of some functionality, at least according to a comment in the source. It would be a good idea to enable that code path and see if it really does make a big difference before removing it entirely. BUG=None TEST=Built for Link, Daisy, and the host with FEATURES=test. Built depthcharge for Link and booted in normal mode. BRANCH=None Change-Id: I934a4dd0da169ac018ba07350d56924ab88b1acc Signed-off-by: Gabe Black <gabeblack@google.com> Reviewed-on: https://gerrit.chromium.org/gerrit/45687 Reviewed-by: Randall Spangler <rspangler@chromium.org> Commit-Queue: Gabe Black <gabeblack@chromium.org> Tested-by: Gabe Black <gabeblack@chromium.org>
76 lines
2.1 KiB
C
76 lines
2.1 KiB
C
/* Copyright (c) 2011 The Chromium OS Authors. All rights reserved.
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
* found in the LICENSE file.
|
|
*
|
|
* Tests for utility functions
|
|
*/
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
|
|
#define _STUB_IMPLEMENTATION_ /* So we can use memset() ourselves */
|
|
|
|
#include "test_common.h"
|
|
#include "utility.h"
|
|
#include "vboot_common.h"
|
|
|
|
|
|
/* Test utility.h and sysincludes.h macros */
|
|
static void MacrosTest(void) {
|
|
int64_t a = -10, b = -20;
|
|
uint64_t u = (0xABCD00000000ULL);
|
|
uint64_t v = (0xABCD000000ULL);
|
|
|
|
TEST_EQ(CombineUint16Pair(1, 2), 0x00010002, "CombineUint16Pair");
|
|
TEST_EQ(CombineUint16Pair(0xFFFE, 0xFFFF), 0xFFFEFFFF,
|
|
"CombineUint16Pair 2");
|
|
TEST_EQ(CombineUint16Pair(-4, -16), 0xFFFCFFF0,
|
|
"CombineUint16Pair big negative");
|
|
TEST_EQ(CombineUint16Pair(0x10003, 0x10004), 0x00030004,
|
|
"CombineUint16Pair overflow");
|
|
|
|
TEST_EQ(Min(1, 2), 1, "Min 1");
|
|
TEST_EQ(Min(4, 3), 3, "Min 2");
|
|
TEST_EQ(Min(5, 5), 5, "Min 5");
|
|
TEST_EQ(Min(a, b), b, "Min uint64 1");
|
|
TEST_EQ(Min(b, a), b, "Min uint64 2");
|
|
TEST_EQ(Min(b, b), b, "Min uint64 same");
|
|
|
|
TEST_EQ(u >> 8, v, "uint64_t >> 8");
|
|
TEST_EQ(u >> 0, u, "uint64_t >> 0");
|
|
TEST_EQ(u >> 36, (uint64_t)0xABC, "uint64_t >> 36");
|
|
|
|
TEST_EQ(v * (uint32_t)0, 0, "uint64_t * uint32_t 0");
|
|
TEST_EQ(v * (uint32_t)1, v, "uint64_t * uint32_t 1");
|
|
TEST_EQ(v * (uint32_t)256, u, "uint64_t * uint32_t 256");
|
|
}
|
|
|
|
|
|
/* Test SafeMemcmp */
|
|
static void SafeMemcmpTest(void) {
|
|
/* Zero-length strings are equal */
|
|
TEST_EQ(0, SafeMemcmp("APPLE", "TIGER", 0), "SafeMemcmp() size=0");
|
|
|
|
/* Test equal arrays */
|
|
TEST_EQ(0, SafeMemcmp("clonebob", "clonebob", 8), "SafeMemcmp() equal");
|
|
/* Inequality past end of array doesn't affect result */
|
|
TEST_EQ(0, SafeMemcmp("clonebob", "clonedan", 5), "SafeMemcmp() equal2");
|
|
|
|
TEST_EQ(1, SafeMemcmp("APPLE", "TIGER", 5), "SafeMemcmp() unequal");
|
|
TEST_EQ(1, SafeMemcmp("APPLE", "APPLe", 5), "SafeMemcmp() unequal 2");
|
|
}
|
|
|
|
|
|
int main(int argc, char* argv[]) {
|
|
int error_code = 0;
|
|
|
|
MacrosTest();
|
|
SafeMemcmpTest();
|
|
|
|
if (!gTestSuccess)
|
|
error_code = 255;
|
|
|
|
return error_code;
|
|
}
|