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/rollback_index.c \
|
||||||
./lib/stateful_util.c \
|
./lib/stateful_util.c \
|
||||||
./lib/tpm_lite/tlcl.c \
|
./lib/tpm_lite/tlcl.c \
|
||||||
|
./lib/utility.c \
|
||||||
./lib/vboot_common.c \
|
./lib/vboot_common.c \
|
||||||
./lib/vboot_firmware.c \
|
./lib/vboot_firmware.c \
|
||||||
./lib/vboot_kernel.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]. */
|
/* Copy [n] bytes from [src] to [dest]. */
|
||||||
void* Memcpy(void* dest, const void* src, uint64_t n);
|
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]. */
|
/* Set [n] bytes starting at [s] to [c]. */
|
||||||
void* Memset(void *dest, const uint8_t c, uint64_t n);
|
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
|
#define memset _do_not_use_standard_memset
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#endif /* VBOOT_REFERENCE_UTILITY_H_ */
|
#endif /* VBOOT_REFERENCE_UTILITY_H_ */
|
||||||
|
|||||||
@@ -2,8 +2,7 @@
|
|||||||
* Use of this source code is governed by a BSD-style license that can be
|
* Use of this source code is governed by a BSD-style license that can be
|
||||||
* found in the LICENSE file.
|
* found in the LICENSE file.
|
||||||
*
|
*
|
||||||
* Stub implementations of utility functions which call their linux-specific
|
* Implementations of stateful memory operations.
|
||||||
* equivalents.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "stateful_util.h"
|
#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) {
|
void* Memcpy(void* dest, const void* src, uint64_t n) {
|
||||||
return memcpy(dest, src, (size_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