mirror of
https://github.com/Telecominfraproject/OpenCellular.git
synced 2025-11-23 17:55:01 +00:00
This reduces the number of exported header files to the minimum needed by
the existing userspace utilities and firmware implementations.
BUG=chromium:221544
BRANCH=none
TEST=manual, trybots
CQ-DEPEND=CL:47019,CL:47022,CL:47023
sudo FEATURES=test emerge vboot_reference
FEATURES=test emerge-$BOARD \
vboot_reference \
chromeos-cryptohome \
chromeos-installer \
chromeos-u-boot \
peach-u-boot \
depthcharge
Change-Id: I2946cc2dbaf5459a6c5eca92ca57d546498e6d85
Signed-off-by: Bill Richardson <wfrichar@chromium.org>
Reviewed-on: https://gerrit.chromium.org/gerrit/47021
Reviewed-by: Randall Spangler <rspangler@chromium.org>
75 lines
1.7 KiB
C
75 lines
1.7 KiB
C
/* Copyright (c) 2013 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.
|
|
*
|
|
* Implementations of stateful memory operations.
|
|
*/
|
|
|
|
#include "sysincludes.h"
|
|
|
|
#include "stateful_util.h"
|
|
#include "utility.h"
|
|
|
|
void StatefulInit(MemcpyState *state, void *buf, uint64_t len)
|
|
{
|
|
state->remaining_buf = buf;
|
|
state->remaining_len = len;
|
|
state->overrun = 0;
|
|
}
|
|
|
|
void *StatefulSkip(MemcpyState *state, uint64_t len)
|
|
{
|
|
if (state->overrun)
|
|
return NULL;
|
|
if (len > state->remaining_len) {
|
|
state->overrun = 1;
|
|
return NULL;
|
|
}
|
|
state->remaining_buf += len;
|
|
state->remaining_len -= len;
|
|
return state; /* Must return something non-NULL. */
|
|
}
|
|
|
|
void *StatefulMemcpy(MemcpyState *state, void *dst, uint64_t len)
|
|
{
|
|
if (state->overrun)
|
|
return NULL;
|
|
if (len > state->remaining_len) {
|
|
state->overrun = 1;
|
|
return NULL;
|
|
}
|
|
Memcpy(dst, state->remaining_buf, len);
|
|
state->remaining_buf += len;
|
|
state->remaining_len -= len;
|
|
return dst;
|
|
}
|
|
|
|
const void *StatefulMemcpy_r(MemcpyState *state, const void *src, uint64_t len)
|
|
{
|
|
if (state->overrun)
|
|
return NULL;
|
|
if (len > state->remaining_len) {
|
|
state->overrun = 1;
|
|
return NULL;
|
|
}
|
|
Memcpy(state->remaining_buf, src, len);
|
|
state->remaining_buf += len;
|
|
state->remaining_len -= len;
|
|
return src;
|
|
}
|
|
|
|
const void *StatefulMemset_r(MemcpyState *state, const uint8_t val,
|
|
uint64_t len)
|
|
{
|
|
if (state->overrun)
|
|
return NULL;
|
|
if (len > state->remaining_len) {
|
|
state->overrun = 1;
|
|
return NULL;
|
|
}
|
|
Memset(state->remaining_buf, val, len);
|
|
state->remaining_buf += len;
|
|
state->remaining_len -= len;
|
|
return state; /* Must return something non-NULL. */
|
|
}
|