Commit cb242ede authored by Ben L. Titzer's avatar Ben L. Titzer Committed by Commit Bot

[iwyu] Extract src/memcopy.h from src/utils.h

This CL moves a number of memory-related methods out of utils into its
own header, since utils.h is included in many places that do not need
these methods.

R=clemensh@chromium.org,mstarzinger@chromium.org

Change-Id: I5155baf329844784286413408c05c7108b789020
Reviewed-on: https://chromium-review.googlesource.com/c/1354889
Commit-Queue: Ben Titzer <titzer@chromium.org>
Reviewed-by: 's avatarMichael Starzinger <mstarzinger@chromium.org>
Reviewed-by: 's avatarClemens Hammacher <clemensh@chromium.org>
Reviewed-by: 's avatarMarja Hölttä <marja@chromium.org>
Cr-Commit-Position: refs/heads/master@{#57948}
parent 3d2bc5d0
...@@ -2252,6 +2252,8 @@ v8_source_set("v8_base") { ...@@ -2252,6 +2252,8 @@ v8_source_set("v8_base") {
"src/math-random.h", "src/math-random.h",
"src/maybe-handles-inl.h", "src/maybe-handles-inl.h",
"src/maybe-handles.h", "src/maybe-handles.h",
"src/memcopy.cc",
"src/memcopy.h",
"src/message-template.h", "src/message-template.h",
"src/messages.cc", "src/messages.cc",
"src/messages.h", "src/messages.h",
......
...@@ -11,8 +11,9 @@ ...@@ -11,8 +11,9 @@
#include "src/base/lsan-page-allocator.h" #include "src/base/lsan-page-allocator.h"
#include "src/base/page-allocator.h" #include "src/base/page-allocator.h"
#include "src/base/platform/platform.h" #include "src/base/platform/platform.h"
#include "src/utils.h" #include "src/memcopy.h"
#include "src/v8.h" #include "src/v8.h"
#include "src/vector.h"
#if V8_LIBC_BIONIC #if V8_LIBC_BIONIC
#include <malloc.h> // NOLINT #include <malloc.h> // NOLINT
......
...@@ -35,7 +35,6 @@ ...@@ -35,7 +35,6 @@
#include "src/globals.h" #include "src/globals.h"
#include "src/heap/factory.h" #include "src/heap/factory.h"
#include "src/isolate.h" #include "src/isolate.h"
#include "src/utils.h"
// Ast(Raw|Cons)String and AstValueFactory are for storing strings and // Ast(Raw|Cons)String and AstValueFactory are for storing strings and
// values independent of the V8 heap and internalizing them later. During // values independent of the V8 heap and internalizing them later. During
......
...@@ -20,9 +20,9 @@ ...@@ -20,9 +20,9 @@
#include "src/lsan.h" #include "src/lsan.h"
#include "src/machine-type.h" #include "src/machine-type.h"
#include "src/macro-assembler.h" #include "src/macro-assembler.h"
#include "src/memcopy.h"
#include "src/objects-inl.h" #include "src/objects-inl.h"
#include "src/objects/smi.h" #include "src/objects/smi.h"
#include "src/utils.h"
#include "src/zone/zone.h" #include "src/zone/zone.h"
namespace v8 { namespace v8 {
......
...@@ -13,8 +13,8 @@ ...@@ -13,8 +13,8 @@
#include "src/assembler.h" #include "src/assembler.h"
#include "src/base/functional.h" #include "src/base/functional.h"
#include "src/base/platform/platform.h" #include "src/base/platform/platform.h"
#include "src/memcopy.h"
#include "src/ostreams.h" #include "src/ostreams.h"
#include "src/utils.h"
#include "src/wasm/wasm-limits.h" #include "src/wasm/wasm-limits.h"
namespace v8 { namespace v8 {
......
...@@ -15,13 +15,13 @@ ...@@ -15,13 +15,13 @@
#include "src/heap/heap-inl.h" #include "src/heap/heap-inl.h"
#include "src/heap/mark-compact.h" #include "src/heap/mark-compact.h"
#include "src/isolate.h" #include "src/isolate.h"
#include "src/memcopy.h"
#include "src/objects/compilation-cache-inl.h" #include "src/objects/compilation-cache-inl.h"
#include "src/objects/heap-object.h" #include "src/objects/heap-object.h"
#include "src/objects/js-collection-inl.h" #include "src/objects/js-collection-inl.h"
#include "src/objects/literal-objects-inl.h" #include "src/objects/literal-objects-inl.h"
#include "src/objects/slots.h" #include "src/objects/slots.h"
#include "src/objects/templates.h" #include "src/objects/templates.h"
#include "src/utils.h"
namespace v8 { namespace v8 {
namespace internal { namespace internal {
......
...@@ -21,6 +21,7 @@ ...@@ -21,6 +21,7 @@
#include "src/libsampler/sampler.h" #include "src/libsampler/sampler.h"
#include "src/log-inl.h" #include "src/log-inl.h"
#include "src/macro-assembler.h" #include "src/macro-assembler.h"
#include "src/memcopy.h"
#include "src/objects/api-callbacks.h" #include "src/objects/api-callbacks.h"
#include "src/perf-jit.h" #include "src/perf-jit.h"
#include "src/profiler/tick-sample.h" #include "src/profiler/tick-sample.h"
...@@ -34,7 +35,6 @@ ...@@ -34,7 +35,6 @@
#include "src/wasm/wasm-code-manager.h" #include "src/wasm/wasm-code-manager.h"
#include "src/wasm/wasm-objects-inl.h" #include "src/wasm/wasm-objects-inl.h"
#include "src/utils.h"
#include "src/version.h" #include "src/version.h"
namespace v8 { namespace v8 {
......
// Copyright 2018 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "src/memcopy.h"
namespace v8 {
namespace internal {
#if V8_TARGET_ARCH_IA32
static void MemMoveWrapper(void* dest, const void* src, size_t size) {
memmove(dest, src, size);
}
// Initialize to library version so we can call this at any time during startup.
static MemMoveFunction memmove_function = &MemMoveWrapper;
// Defined in codegen-ia32.cc.
MemMoveFunction CreateMemMoveFunction();
// Copy memory area to disjoint memory area.
V8_EXPORT_PRIVATE void MemMove(void* dest, const void* src, size_t size) {
if (size == 0) return;
// Note: here we rely on dependent reads being ordered. This is true
// on all architectures we currently support.
(*memmove_function)(dest, src, size);
}
#elif V8_OS_POSIX && V8_HOST_ARCH_ARM
void MemCopyUint16Uint8Wrapper(uint16_t* dest, const uint8_t* src,
size_t chars) {
uint16_t* limit = dest + chars;
while (dest < limit) {
*dest++ = static_cast<uint16_t>(*src++);
}
}
V8_EXPORT_PRIVATE MemCopyUint8Function memcopy_uint8_function =
&MemCopyUint8Wrapper;
MemCopyUint16Uint8Function memcopy_uint16_uint8_function =
&MemCopyUint16Uint8Wrapper;
// Defined in codegen-arm.cc.
MemCopyUint8Function CreateMemCopyUint8Function(MemCopyUint8Function stub);
MemCopyUint16Uint8Function CreateMemCopyUint16Uint8Function(
MemCopyUint16Uint8Function stub);
#elif V8_OS_POSIX && V8_HOST_ARCH_MIPS
V8_EXPORT_PRIVATE MemCopyUint8Function memcopy_uint8_function =
&MemCopyUint8Wrapper;
// Defined in codegen-mips.cc.
MemCopyUint8Function CreateMemCopyUint8Function(MemCopyUint8Function stub);
#endif
static bool g_memcopy_functions_initialized = false;
void init_memcopy_functions() {
if (g_memcopy_functions_initialized) return;
g_memcopy_functions_initialized = true;
#if V8_TARGET_ARCH_IA32
MemMoveFunction generated_memmove = CreateMemMoveFunction();
if (generated_memmove != nullptr) {
memmove_function = generated_memmove;
}
#elif V8_OS_POSIX && V8_HOST_ARCH_ARM
memcopy_uint8_function = CreateMemCopyUint8Function(&MemCopyUint8Wrapper);
memcopy_uint16_uint8_function =
CreateMemCopyUint16Uint8Function(&MemCopyUint16Uint8Wrapper);
#elif V8_OS_POSIX && V8_HOST_ARCH_MIPS
memcopy_uint8_function = CreateMemCopyUint8Function(&MemCopyUint8Wrapper);
#endif
}
} // namespace internal
} // namespace v8
This diff is collapsed.
...@@ -8,6 +8,7 @@ ...@@ -8,6 +8,7 @@
#include "src/objects/slots.h" #include "src/objects/slots.h"
#include "src/base/atomic-utils.h" #include "src/base/atomic-utils.h"
#include "src/memcopy.h"
#include "src/objects.h" #include "src/objects.h"
#include "src/objects/heap-object.h" #include "src/objects/heap-object.h"
#include "src/objects/maybe-object.h" #include "src/objects/maybe-object.h"
...@@ -88,6 +89,10 @@ void HeapObjectSlot::store(HeapObjectReference value) const { ...@@ -88,6 +89,10 @@ void HeapObjectSlot::store(HeapObjectReference value) const {
*location() = value.ptr(); *location() = value.ptr();
} }
inline void MemsetPointer(ObjectSlot start, Object* value, size_t counter) {
MemsetPointer(start.location(), reinterpret_cast<Address>(value), counter);
}
} // namespace internal } // namespace internal
} // namespace v8 } // namespace v8
......
...@@ -7,7 +7,6 @@ ...@@ -7,7 +7,6 @@
#include "src/allocation.h" #include "src/allocation.h"
#include "src/assert-scope.h" #include "src/assert-scope.h"
#include "src/utils.h"
#include "src/v8memory.h" #include "src/v8memory.h"
#include "src/zone/zone-chunk-list.h" #include "src/zone/zone-chunk-list.h"
#include "src/zone/zone.h" #include "src/zone/zone.h"
......
...@@ -8,8 +8,8 @@ ...@@ -8,8 +8,8 @@
#include <sys/types.h> #include <sys/types.h>
#include <algorithm> #include <algorithm>
#include "src/globals.h" #include "src/globals.h"
#include "src/memcopy.h"
#include "src/unicode.h" #include "src/unicode.h"
#include "src/utils.h"
#include "src/vector.h" #include "src/vector.h"
namespace unibrow { namespace unibrow {
......
...@@ -11,6 +11,7 @@ ...@@ -11,6 +11,7 @@
#include "src/base/functional.h" #include "src/base/functional.h"
#include "src/base/logging.h" #include "src/base/logging.h"
#include "src/base/platform/platform.h" #include "src/base/platform/platform.h"
#include "src/memcopy.h"
namespace v8 { namespace v8 {
namespace internal { namespace internal {
...@@ -335,71 +336,6 @@ void StringBuilder::AddFormattedList(const char* format, va_list list) { ...@@ -335,71 +336,6 @@ void StringBuilder::AddFormattedList(const char* format, va_list list) {
} }
} }
#if V8_TARGET_ARCH_IA32
static void MemMoveWrapper(void* dest, const void* src, size_t size) {
memmove(dest, src, size);
}
// Initialize to library version so we can call this at any time during startup.
static MemMoveFunction memmove_function = &MemMoveWrapper;
// Defined in codegen-ia32.cc.
MemMoveFunction CreateMemMoveFunction();
// Copy memory area to disjoint memory area.
void MemMove(void* dest, const void* src, size_t size) {
if (size == 0) return;
// Note: here we rely on dependent reads being ordered. This is true
// on all architectures we currently support.
(*memmove_function)(dest, src, size);
}
#elif V8_OS_POSIX && V8_HOST_ARCH_ARM
void MemCopyUint16Uint8Wrapper(uint16_t* dest, const uint8_t* src,
size_t chars) {
uint16_t* limit = dest + chars;
while (dest < limit) {
*dest++ = static_cast<uint16_t>(*src++);
}
}
V8_EXPORT_PRIVATE MemCopyUint8Function memcopy_uint8_function =
&MemCopyUint8Wrapper;
MemCopyUint16Uint8Function memcopy_uint16_uint8_function =
&MemCopyUint16Uint8Wrapper;
// Defined in codegen-arm.cc.
MemCopyUint8Function CreateMemCopyUint8Function(MemCopyUint8Function stub);
MemCopyUint16Uint8Function CreateMemCopyUint16Uint8Function(
MemCopyUint16Uint8Function stub);
#elif V8_OS_POSIX && V8_HOST_ARCH_MIPS
V8_EXPORT_PRIVATE MemCopyUint8Function memcopy_uint8_function =
&MemCopyUint8Wrapper;
// Defined in codegen-mips.cc.
MemCopyUint8Function CreateMemCopyUint8Function(MemCopyUint8Function stub);
#endif
static bool g_memcopy_functions_initialized = false;
void init_memcopy_functions() {
if (g_memcopy_functions_initialized) return;
g_memcopy_functions_initialized = true;
#if V8_TARGET_ARCH_IA32
MemMoveFunction generated_memmove = CreateMemMoveFunction();
if (generated_memmove != nullptr) {
memmove_function = generated_memmove;
}
#elif V8_OS_POSIX && V8_HOST_ARCH_ARM
memcopy_uint8_function = CreateMemCopyUint8Function(&MemCopyUint8Wrapper);
memcopy_uint16_uint8_function =
CreateMemCopyUint16Uint8Function(&MemCopyUint16Uint8Wrapper);
#elif V8_OS_POSIX && V8_HOST_ARCH_MIPS
memcopy_uint8_function = CreateMemCopyUint8Function(&MemCopyUint8Wrapper);
#endif
}
// Returns false iff d is NaN, +0, or -0. // Returns false iff d is NaN, +0, or -0.
bool DoubleToBoolean(double d) { bool DoubleToBoolean(double d) {
IeeeDoubleArchType u; IeeeDoubleArchType u;
......
This diff is collapsed.
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
#include "src/base/iterator.h" #include "src/base/iterator.h"
#include "src/globals.h" #include "src/globals.h"
#include "src/utils.h" #include "src/memcopy.h"
#include "src/zone/zone.h" #include "src/zone/zone.h"
#ifndef V8_ZONE_ZONE_CHUNK_LIST_H_ #ifndef V8_ZONE_ZONE_CHUNK_LIST_H_
......
...@@ -9,7 +9,7 @@ ...@@ -9,7 +9,7 @@
#include "src/base/macros.h" #include "src/base/macros.h"
#include "src/base/platform/platform.h" #include "src/base/platform/platform.h"
#include "src/utils.h" #include "src/memcopy.h"
namespace v8 { namespace v8 {
namespace internal { namespace internal {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment