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:
Gaurav Shah
2010-08-20 14:30:03 -07:00
parent 33c44fc14f
commit 37dff84dbb
6 changed files with 38 additions and 28 deletions

View File

@@ -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

View File

@@ -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_ */

View File

@@ -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
View 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;
}

View File

@@ -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;
}

View File

@@ -1 +1 @@
char* VbootVersion = "VBOOv=736cf3ee";
char* VbootVersion = "VBOOv=834ce682";