mirror of
https://github.com/Telecominfraproject/OpenCellular.git
synced 2025-11-24 02:05:01 +00:00
Make sure that our version of certain utility function implementations gets used in the firmware.
Reference code drop-in to firmware should make our implementations of Memset() and SafeMemcmp() get used now. BUG=chrome-os-partner:820 TEST=make && make runtests Change-Id: If0c06dfad85b67398a118985cdb751d20b2b65a4 Review URL: http://codereview.chromium.org/3173035
This commit is contained in:
@@ -35,6 +35,7 @@ LIB_SRCS = \
|
||||
./lib/rollback_index.c \
|
||||
./lib/stateful_util.c \
|
||||
./lib/tpm_lite/tlcl.c \
|
||||
./lib/utility.c \
|
||||
./lib/vboot_common.c \
|
||||
./lib/vboot_firmware.c \
|
||||
./lib/vboot_kernel.c
|
||||
|
||||
@@ -54,6 +54,10 @@ int Memcmp(const void* src1, const void* src2, size_t n);
|
||||
/* Copy [n] bytes from [src] to [dest]. */
|
||||
void* Memcpy(void* dest, const void* src, uint64_t n);
|
||||
|
||||
|
||||
/* Implementations of the functions below must be built as part of the firmware
|
||||
* and defined in lib/utility.c */
|
||||
|
||||
/* Set [n] bytes starting at [s] to [c]. */
|
||||
void* Memset(void *dest, const uint8_t c, uint64_t n);
|
||||
|
||||
@@ -72,5 +76,4 @@ int SafeMemcmp(const void* s1, const void* s2, size_t n);
|
||||
#define memset _do_not_use_standard_memset
|
||||
#endif
|
||||
|
||||
|
||||
#endif /* VBOOT_REFERENCE_UTILITY_H_ */
|
||||
|
||||
@@ -2,8 +2,7 @@
|
||||
* Use of this source code is governed by a BSD-style license that can be
|
||||
* found in the LICENSE file.
|
||||
*
|
||||
* Stub implementations of utility functions which call their linux-specific
|
||||
* equivalents.
|
||||
* Implementations of stateful memory operations.
|
||||
*/
|
||||
|
||||
#include "stateful_util.h"
|
||||
|
||||
31
firmware/lib/utility.c
Normal file
31
firmware/lib/utility.c
Normal file
@@ -0,0 +1,31 @@
|
||||
/* Copyright (c) 2010 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.
|
||||
*
|
||||
* Utility functions that need to be built as part of the firmware.
|
||||
*/
|
||||
|
||||
#include "utility.h"
|
||||
|
||||
void* Memset(void* d, const uint8_t c, uint64_t n) {
|
||||
uint8_t* dest = d; /* the only way to keep both cl and gcc happy */
|
||||
while (n--) {
|
||||
*dest++ = c;
|
||||
}
|
||||
return dest;
|
||||
}
|
||||
|
||||
int SafeMemcmp(const void* s1, const void* s2, size_t n) {
|
||||
int result = 0;
|
||||
if (0 == n)
|
||||
return 1;
|
||||
|
||||
const unsigned char* us1 = s1;
|
||||
const unsigned char* us2 = s2;
|
||||
/* Code snippet without data-dependent branch due to
|
||||
* Nate Lawson (nate@root.org) of Root Labs. */
|
||||
while (n--)
|
||||
result |= *us1++ ^ *us2++;
|
||||
|
||||
return result != 0;
|
||||
}
|
||||
@@ -51,27 +51,3 @@ int Memcmp(const void* src1, const void* src2, size_t n) {
|
||||
void* Memcpy(void* dest, const void* src, uint64_t n) {
|
||||
return memcpy(dest, src, (size_t)n);
|
||||
}
|
||||
|
||||
void* Memset(void* d, const uint8_t c, uint64_t n) {
|
||||
uint8_t* dest = d; /* the only way to keep both cl and gcc happy */
|
||||
while (n--) {
|
||||
*dest++ = c;
|
||||
}
|
||||
return dest;
|
||||
}
|
||||
|
||||
|
||||
int SafeMemcmp(const void* s1, const void* s2, size_t n) {
|
||||
int result = 0;
|
||||
if (0 == n)
|
||||
return 1;
|
||||
|
||||
const unsigned char* us1 = s1;
|
||||
const unsigned char* us2 = s2;
|
||||
/* Code snippet without data-dependent branch due to
|
||||
* Nate Lawson (nate@root.org) of Root Labs. */
|
||||
while (n--)
|
||||
result |= *us1++ ^ *us2++;
|
||||
|
||||
return result != 0;
|
||||
}
|
||||
|
||||
@@ -1 +1 @@
|
||||
char* VbootVersion = "VBOOv=736cf3ee";
|
||||
char* VbootVersion = "VBOOv=834ce682";
|
||||
|
||||
Reference in New Issue
Block a user