From 84f3877c15bc7f8956d21614da4311337525a3c8 Mon Sep 17 00:00:00 2001 From: Dan Elphick Date: Fri, 15 Nov 2019 11:58:57 +0000 Subject: [PATCH] [cleanup] Split out bit-field.h and bounds.h from utils/utils.h utils.h itself is fairly large and contains lots of unrelated functions as well as having a fair number of dependencies itself, so this splits bounds checking and bit field operations into their own headers in base and replaces uses of utils.h with the more appropriate header where possible. (Also fixes some cases where other headers were previously brought in transitively). Bug: v8:9810, v8:8912 Change-Id: I76c53f953848a57e2c5bfad6ce45abcd6d2a4f1b Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1916604 Reviewed-by: Clemens Backes Reviewed-by: Ross McIlroy Commit-Queue: Dan Elphick Cr-Commit-Position: refs/heads/master@{#64983} --- BUILD.gn | 6 +- src/asmjs/asm-scanner.cc | 3 +- src/ast/ast.h | 4 +- src/ast/variables.h | 2 +- src/base/bit-field.h | 159 ++++++++++++++++ src/base/bounds.h | 54 ++++++ src/builtins/accessors.h | 1 + src/builtins/builtins-array.cc | 8 +- src/codegen/handler-table.h | 6 +- src/codegen/ia32/assembler-ia32.h | 4 +- src/codegen/reloc-info.h | 4 +- src/codegen/source-position-table.cc | 4 +- src/codegen/source-position-table.h | 1 + src/codegen/source-position.h | 12 +- src/codegen/x64/macro-assembler-x64.cc | 8 +- src/common/assert-scope.cc | 2 +- src/compiler/allocation-builder-inl.h | 3 +- .../arm64/instruction-selector-arm64.cc | 8 +- src/compiler/backend/instruction-codes.h | 12 +- src/compiler/backend/instruction.h | 42 ++--- src/compiler/backend/register-allocator.h | 28 +-- src/compiler/js-operator.h | 16 +- src/compiler/linkage.h | 2 +- src/compiler/node.h | 10 +- src/compiler/wasm-compiler.cc | 2 +- src/date/dateparser.h | 1 + src/handles/global-handles.cc | 4 +- src/heap/slot-set.h | 5 +- src/heap/spaces.h | 5 +- src/ic/handler-configuration.h | 4 +- src/interpreter/bytecode-flags.h | 11 +- src/interpreter/bytecode-operands.h | 9 +- src/json/json-parser.cc | 10 +- src/objects/allocation-site.h | 10 +- src/objects/api-callbacks.h | 1 + src/objects/bigint.h | 2 +- src/objects/code.h | 7 +- src/objects/debug-objects.h | 1 + src/objects/descriptor-array.h | 1 + src/objects/elements-kind.h | 48 ++--- src/objects/feedback-vector.h | 9 +- src/objects/field-index.h | 2 +- src/objects/function-kind.h | 65 +++---- src/objects/instance-type-inl.h | 2 +- src/objects/js-array-buffer.h | 1 + src/objects/js-date-time-format.cc | 10 +- src/objects/js-date-time-format.h | 1 + src/objects/js-list-format.h | 1 + src/objects/js-number-format.cc | 4 +- src/objects/js-number-format.h | 1 + src/objects/js-plural-rules.h | 1 + src/objects/js-promise.h | 2 +- src/objects/js-relative-time-format.h | 1 + src/objects/js-segment-iterator.h | 1 + src/objects/js-segmenter.h | 1 + src/objects/js-weak-refs.h | 2 +- src/objects/literal-objects.h | 1 + src/objects/map.h | 1 + src/objects/name.h | 7 +- src/objects/objects.cc | 9 +- src/objects/property-array.h | 6 +- src/objects/property-descriptor-object.h | 1 + src/objects/property-details.h | 4 +- src/objects/scope-info.h | 4 +- src/objects/shared-function-info.h | 1 + src/objects/templates.h | 2 +- src/parsing/expression-scope.h | 23 +-- src/parsing/keywords-gen.h | 2 +- src/parsing/parser-base.h | 8 +- src/parsing/preparse-data.cc | 8 +- src/parsing/preparser.h | 8 +- src/parsing/scanner-inl.h | 1 + src/parsing/scanner.cc | 4 +- src/parsing/scanner.h | 12 +- src/parsing/token.h | 53 +++--- src/profiler/heap-snapshot-generator.h | 4 +- src/profiler/profile-generator.h | 8 +- src/runtime/runtime.h | 7 +- src/snapshot/embedded/embedded-data.h | 2 +- src/snapshot/references.h | 4 +- src/snapshot/serializer-common.h | 16 +- src/strings/char-predicates-inl.h | 30 +-- src/strings/string-builder-inl.h | 6 +- src/strings/unicode.h | 6 +- src/utils/utils.h | 178 ------------------ src/wasm/baseline/liftoff-compiler.cc | 2 +- src/wasm/module-compiler.cc | 6 +- src/wasm/module-instantiate.cc | 17 +- src/wasm/wasm-interpreter.cc | 8 +- src/wasm/wasm-objects.cc | 4 +- src/wasm/wasm-objects.h | 1 + test/cctest/test-code-stub-assembler.cc | 2 +- test/cctest/test-conversions.cc | 12 +- test/cctest/test-utils.cc | 5 +- test/unittests/utils/utils-unittest.cc | 5 +- 95 files changed, 597 insertions(+), 505 deletions(-) create mode 100644 src/base/bit-field.h create mode 100644 src/base/bounds.h diff --git a/BUILD.gn b/BUILD.gn index 08c4758cac..b6e5a84ab6 100644 --- a/BUILD.gn +++ b/BUILD.gn @@ -1398,7 +1398,9 @@ v8_source_set("v8_snapshot") { # Do not publicize any header to remove build dependency. public = [] - sources = [ "src/init/setup-isolate-deserialize.cc" ] + sources = [ + "src/init/setup-isolate-deserialize.cc", + ] if (emit_builtins_as_inline_asm) { deps += [ ":asm_to_inline_asm_default" ] sources += [ "$target_gen_dir/embedded.cc" ] @@ -3422,10 +3424,12 @@ v8_component("v8_libbase") { "src/base/atomicops_internals_portable.h", "src/base/atomicops_internals_std.h", "src/base/base-export.h", + "src/base/bit-field.h", "src/base/bits.cc", "src/base/bits.h", "src/base/bounded-page-allocator.cc", "src/base/bounded-page-allocator.h", + "src/base/bounds.h", "src/base/build_config.h", "src/base/compiler-specific.h", "src/base/cpu.cc", diff --git a/src/asmjs/asm-scanner.cc b/src/asmjs/asm-scanner.cc index a9e9c2ca56..eaff042d31 100644 --- a/src/asmjs/asm-scanner.cc +++ b/src/asmjs/asm-scanner.cc @@ -424,7 +424,8 @@ void AsmJsScanner::ConsumeCompareOrShift(uc32 ch) { } bool AsmJsScanner::IsIdentifierStart(uc32 ch) { - return IsInRange(AsciiAlphaToLower(ch), 'a', 'z') || ch == '_' || ch == '$'; + return base::IsInRange(AsciiAlphaToLower(ch), 'a', 'z') || ch == '_' || + ch == '$'; } bool AsmJsScanner::IsIdentifierPart(uc32 ch) { return IsAsciiIdentifier(ch); } diff --git a/src/ast/ast.h b/src/ast/ast.h index d706dbc37f..e58e6e8d08 100644 --- a/src/ast/ast.h +++ b/src/ast/ast.h @@ -170,7 +170,7 @@ class AstNode: public ZoneObject { void* operator new(size_t size); int position_; - using NodeTypeField = BitField; + using NodeTypeField = base::BitField; protected: uint32_t bit_field_; @@ -259,7 +259,7 @@ class Expression : public AstNode { bool IsPattern() { STATIC_ASSERT(kObjectLiteral + 1 == kArrayLiteral); - return IsInRange(node_type(), kObjectLiteral, kArrayLiteral); + return base::IsInRange(node_type(), kObjectLiteral, kArrayLiteral); } bool is_parenthesized() const { diff --git a/src/ast/variables.h b/src/ast/variables.h index 6939f9a36b..0f1df98834 100644 --- a/src/ast/variables.h +++ b/src/ast/variables.h @@ -261,7 +261,7 @@ class Variable final : public ZoneObject { bit_field_ = MaybeAssignedFlagField::update(bit_field_, kMaybeAssigned); } - using VariableModeField = BitField16; + using VariableModeField = base::BitField16; using VariableKindField = VariableModeField::Next; using LocationField = VariableKindField::Next; using ForceContextAllocationField = LocationField::Next; diff --git a/src/base/bit-field.h b/src/base/bit-field.h new file mode 100644 index 0000000000..9cebac32de --- /dev/null +++ b/src/base/bit-field.h @@ -0,0 +1,159 @@ +// Copyright 2019 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. + +#ifndef V8_BASE_BIT_FIELD_H_ +#define V8_BASE_BIT_FIELD_H_ + +#include + +#include "src/base/macros.h" + +namespace v8 { +namespace base { + +// ---------------------------------------------------------------------------- +// BitField is a help template for encoding and decode bitfield with +// unsigned content. +// Instantiate them via 'using', which is cheaper than deriving a new class: +// using MyBitField = base::BitField; +// The BitField class is final to enforce this style over derivation. + +template +class BitField final { + public: + STATIC_ASSERT(std::is_unsigned::value); + STATIC_ASSERT(shift < 8 * sizeof(U)); // Otherwise shifts by {shift} are UB. + STATIC_ASSERT(size < 8 * sizeof(U)); // Otherwise shifts by {size} are UB. + STATIC_ASSERT(shift + size <= 8 * sizeof(U)); + STATIC_ASSERT(size > 0); + + using FieldType = T; + + // A type U mask of bit field. To use all bits of a type U of x bits + // in a bitfield without compiler warnings we have to compute 2^x + // without using a shift count of x in the computation. + static constexpr int kShift = shift; + static constexpr int kSize = size; + static constexpr U kMask = ((U{1} << kShift) << kSize) - (U{1} << kShift); + static constexpr int kLastUsedBit = kShift + kSize - 1; + static constexpr U kNumValues = U{1} << kSize; + + // Value for the field with all bits set. + static constexpr T kMax = static_cast(kNumValues - 1); + + template + using Next = BitField; + + // Tells whether the provided value fits into the bit field. + static constexpr bool is_valid(T value) { + return (static_cast(value) & ~static_cast(kMax)) == 0; + } + + // Returns a type U with the bit field value encoded. + static constexpr U encode(T value) { +#if V8_HAS_CXX14_CONSTEXPR + DCHECK(is_valid(value)); +#endif + return static_cast(value) << kShift; + } + + // Returns a type U with the bit field value updated. + static constexpr U update(U previous, T value) { + return (previous & ~kMask) | encode(value); + } + + // Extracts the bit field from the value. + static constexpr T decode(U value) { + return static_cast((value & kMask) >> kShift); + } +}; + +template +using BitField8 = BitField; + +template +using BitField16 = BitField; + +template +using BitField64 = BitField; + +// Helper macros for defining a contiguous sequence of bit fields. Example: +// (backslashes at the ends of respective lines of this multi-line macro +// definition are omitted here to please the compiler) +// +// #define MAP_BIT_FIELD1(V, _) +// V(IsAbcBit, bool, 1, _) +// V(IsBcdBit, bool, 1, _) +// V(CdeBits, int, 5, _) +// V(DefBits, MutableMode, 1, _) +// +// DEFINE_BIT_FIELDS(MAP_BIT_FIELD1) +// or +// DEFINE_BIT_FIELDS_64(MAP_BIT_FIELD1) +// +#define DEFINE_BIT_FIELD_RANGE_TYPE(Name, Type, Size, _) \ + k##Name##Start, k##Name##End = k##Name##Start + Size - 1, + +#define DEFINE_BIT_RANGES(LIST_MACRO) \ + struct LIST_MACRO##_Ranges { \ + enum { LIST_MACRO(DEFINE_BIT_FIELD_RANGE_TYPE, _) kBitsCount }; \ + }; + +#define DEFINE_BIT_FIELD_TYPE(Name, Type, Size, RangesName) \ + using Name = base::BitField; + +#define DEFINE_BIT_FIELD_64_TYPE(Name, Type, Size, RangesName) \ + using Name = base::BitField64; + +#define DEFINE_BIT_FIELDS(LIST_MACRO) \ + DEFINE_BIT_RANGES(LIST_MACRO) \ + LIST_MACRO(DEFINE_BIT_FIELD_TYPE, LIST_MACRO##_Ranges) + +#define DEFINE_BIT_FIELDS_64(LIST_MACRO) \ + DEFINE_BIT_RANGES(LIST_MACRO) \ + LIST_MACRO(DEFINE_BIT_FIELD_64_TYPE, LIST_MACRO##_Ranges) + +// ---------------------------------------------------------------------------- +// BitSetComputer is a help template for encoding and decoding information for +// a variable number of items in an array. +// +// To encode boolean data in a smi array you would use: +// using BoolComputer = BitSetComputer; +// +template +class BitSetComputer { + public: + static const int kItemsPerWord = kBitsPerWord / kBitsPerItem; + static const int kMask = (1 << kBitsPerItem) - 1; + + // The number of array elements required to embed T information for each item. + static int word_count(int items) { + if (items == 0) return 0; + return (items - 1) / kItemsPerWord + 1; + } + + // The array index to look at for item. + static int index(int base_index, int item) { + return base_index + item / kItemsPerWord; + } + + // Extract T data for a given item from data. + static T decode(U data, int item) { + return static_cast((data >> shift(item)) & kMask); + } + + // Return the encoding for a store of value for item in previous. + static U encode(U previous, int item, T value) { + int shift_value = shift(item); + int set_bits = (static_cast(value) << shift_value); + return (previous & ~(kMask << shift_value)) | set_bits; + } + + static int shift(int item) { return (item % kItemsPerWord) * kBitsPerItem; } +}; + +} // namespace base +} // namespace v8 + +#endif // V8_BASE_BIT_FIELD_H_ diff --git a/src/base/bounds.h b/src/base/bounds.h new file mode 100644 index 0000000000..236e29b7cc --- /dev/null +++ b/src/base/bounds.h @@ -0,0 +1,54 @@ +// Copyright 2019 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. + +#ifndef V8_BASE_BOUNDS_H_ +#define V8_BASE_BOUNDS_H_ + +#include "include/v8config.h" +#include "src/base/macros.h" + +namespace v8 { +namespace base { + +// Checks if value is in range [lower_limit, higher_limit] using a single +// branch. +template +inline constexpr bool IsInRange(T value, U lower_limit, U higher_limit) { +#if V8_HAS_CXX14_CONSTEXPR + DCHECK_LE(lower_limit, higher_limit); +#endif + STATIC_ASSERT(sizeof(U) <= sizeof(T)); + using unsigned_T = typename std::make_unsigned::type; + // Use static_cast to support enum classes. + return static_cast(static_cast(value) - + static_cast(lower_limit)) <= + static_cast(static_cast(higher_limit) - + static_cast(lower_limit)); +} + +// Checks if [index, index+length) is in range [0, max). Note that this check +// works even if {index+length} would wrap around. +inline constexpr bool IsInBounds(size_t index, size_t length, size_t max) { + return length <= max && index <= (max - length); +} + +// Checks if [index, index+length) is in range [0, max). If not, {length} is +// clamped to its valid range. Note that this check works even if +// {index+length} would wrap around. +template +inline bool ClampToBounds(T index, T* length, T max) { + if (index > max) { + *length = 0; + return false; + } + T avail = max - index; + bool oob = *length > avail; + if (oob) *length = avail; + return !oob; +} + +} // namespace base +} // namespace v8 + +#endif // V8_BASE_BOUNDS_H_ diff --git a/src/builtins/accessors.h b/src/builtins/accessors.h index b6a8e65446..faee0d9b67 100644 --- a/src/builtins/accessors.h +++ b/src/builtins/accessors.h @@ -6,6 +6,7 @@ #define V8_BUILTINS_ACCESSORS_H_ #include "include/v8.h" +#include "src/base/bit-field.h" #include "src/common/globals.h" #include "src/objects/property-details.h" #include "src/utils/allocation.h" diff --git a/src/builtins/builtins-array.cc b/src/builtins/builtins-array.cc index d25fa48a55..b86e3863be 100644 --- a/src/builtins/builtins-array.cc +++ b/src/builtins/builtins-array.cc @@ -783,10 +783,10 @@ class ArrayConcatVisitor { storage_ = isolate_->global_handles()->Create(storage); } - using FastElementsField = BitField; - using ExceedsLimitField = BitField; - using IsFixedArrayField = BitField; - using HasSimpleElementsField = BitField; + using FastElementsField = base::BitField; + using ExceedsLimitField = base::BitField; + using IsFixedArrayField = base::BitField; + using HasSimpleElementsField = base::BitField; bool fast_elements() const { return FastElementsField::decode(bit_field_); } void set_fast_elements(bool fast) { diff --git a/src/codegen/handler-table.h b/src/codegen/handler-table.h index 1aa6b81203..ee0bea4061 100644 --- a/src/codegen/handler-table.h +++ b/src/codegen/handler-table.h @@ -5,9 +5,9 @@ #ifndef V8_CODEGEN_HANDLER_TABLE_H_ #define V8_CODEGEN_HANDLER_TABLE_H_ +#include "src/base/bit-field.h" #include "src/common/assert-scope.h" #include "src/common/globals.h" -#include "src/utils/utils.h" namespace v8 { namespace internal { @@ -129,8 +129,8 @@ class V8_EXPORT_PRIVATE HandlerTable { static const int kReturnEntrySize = 2; // Encoding of the {handler} field. - using HandlerPredictionField = BitField; - using HandlerOffsetField = BitField; + using HandlerPredictionField = base::BitField; + using HandlerOffsetField = base::BitField; }; } // namespace internal diff --git a/src/codegen/ia32/assembler-ia32.h b/src/codegen/ia32/assembler-ia32.h index 638b359665..75b3b15fca 100644 --- a/src/codegen/ia32/assembler-ia32.h +++ b/src/codegen/ia32/assembler-ia32.h @@ -343,8 +343,8 @@ class Displacement { private: int data_; - using TypeField = BitField; - using NextField = BitField; + using TypeField = base::BitField; + using NextField = base::BitField; void init(Label* L, Type type); }; diff --git a/src/codegen/reloc-info.h b/src/codegen/reloc-info.h index 6e72e84f40..50ce001103 100644 --- a/src/codegen/reloc-info.h +++ b/src/codegen/reloc-info.h @@ -142,8 +142,8 @@ class RelocInfo { return COMPRESS_POINTERS_BOOL && mode == COMPRESSED_EMBEDDED_OBJECT; } static constexpr bool IsEmbeddedObjectMode(Mode mode) { - return IsInRange(mode, FIRST_EMBEDDED_OBJECT_RELOC_MODE, - LAST_EMBEDDED_OBJECT_RELOC_MODE); + return base::IsInRange(mode, FIRST_EMBEDDED_OBJECT_RELOC_MODE, + LAST_EMBEDDED_OBJECT_RELOC_MODE); } static constexpr bool IsRuntimeEntry(Mode mode) { return mode == RUNTIME_ENTRY; diff --git a/src/codegen/source-position-table.cc b/src/codegen/source-position-table.cc index ba8e5981f0..b0c9d95456 100644 --- a/src/codegen/source-position-table.cc +++ b/src/codegen/source-position-table.cc @@ -27,8 +27,8 @@ namespace internal { namespace { // Each byte is encoded as MoreBit | ValueBits. -using MoreBit = BitField8; -using ValueBits = BitField8; +using MoreBit = base::BitField8; +using ValueBits = base::BitField8; // Helper: Add the offsets from 'other' to 'value'. Also set is_statement. void AddAndSetEntry(PositionTableEntry* value, diff --git a/src/codegen/source-position-table.h b/src/codegen/source-position-table.h index e4e506a114..b3bba3bc8a 100644 --- a/src/codegen/source-position-table.h +++ b/src/codegen/source-position-table.h @@ -9,6 +9,7 @@ #include "src/common/assert-scope.h" #include "src/common/checks.h" #include "src/common/globals.h" +#include "src/utils/vector.h" #include "src/zone/zone-containers.h" namespace v8 { diff --git a/src/codegen/source-position.h b/src/codegen/source-position.h index ad0132b827..0db12aea22 100644 --- a/src/codegen/source-position.h +++ b/src/codegen/source-position.h @@ -7,10 +7,10 @@ #include +#include "src/base/bit-field.h" #include "src/common/globals.h" #include "src/flags/flags.h" #include "src/handles/handles.h" -#include "src/utils/utils.h" namespace v8 { namespace internal { @@ -142,18 +142,18 @@ class SourcePosition final { void Print(std::ostream& out, SharedFunctionInfo function) const; - using IsExternalField = BitField64; + using IsExternalField = base::BitField64; // The two below are only used if IsExternal() is true. - using ExternalLineField = BitField64; - using ExternalFileIdField = BitField64; + using ExternalLineField = base::BitField64; + using ExternalFileIdField = base::BitField64; // ScriptOffsetField is only used if IsExternal() is false. - using ScriptOffsetField = BitField64; + using ScriptOffsetField = base::BitField64; // InliningId is in the high bits for better compression in // SourcePositionTable. - using InliningIdField = BitField64; + using InliningIdField = base::BitField64; // Leaving the highest bit untouched to allow for signed conversion. uint64_t value_; diff --git a/src/codegen/x64/macro-assembler-x64.cc b/src/codegen/x64/macro-assembler-x64.cc index 8f29ed9f71..a1d6f0e1ac 100644 --- a/src/codegen/x64/macro-assembler-x64.cc +++ b/src/codegen/x64/macro-assembler-x64.cc @@ -181,8 +181,8 @@ void MacroAssembler::PushRoot(RootIndex index) { void TurboAssembler::CompareRoot(Register with, RootIndex index) { DCHECK(root_array_available_); - if (IsInRange(index, RootIndex::kFirstStrongOrReadOnlyRoot, - RootIndex::kLastStrongOrReadOnlyRoot)) { + if (base::IsInRange(index, RootIndex::kFirstStrongOrReadOnlyRoot, + RootIndex::kLastStrongOrReadOnlyRoot)) { cmp_tagged(with, Operand(kRootRegister, RootRegisterOffsetForRootIndex(index))); } else { @@ -195,8 +195,8 @@ void TurboAssembler::CompareRoot(Operand with, RootIndex index) { DCHECK(root_array_available_); DCHECK(!with.AddressUsesRegister(kScratchRegister)); LoadRoot(kScratchRegister, index); - if (IsInRange(index, RootIndex::kFirstStrongOrReadOnlyRoot, - RootIndex::kLastStrongOrReadOnlyRoot)) { + if (base::IsInRange(index, RootIndex::kFirstStrongOrReadOnlyRoot, + RootIndex::kLastStrongOrReadOnlyRoot)) { cmp_tagged(with, kScratchRegister); } else { // Some smi roots contain system pointer size values like stack limits. diff --git a/src/common/assert-scope.cc b/src/common/assert-scope.cc index 5138ce7122..ba9a6f0875 100644 --- a/src/common/assert-scope.cc +++ b/src/common/assert-scope.cc @@ -94,7 +94,7 @@ bool PerThreadAssertScope::IsAllowed() { namespace { template -using DataBit = BitField; +using DataBit = base::BitField; } template diff --git a/src/compiler/allocation-builder-inl.h b/src/compiler/allocation-builder-inl.h index 4cab0a7e6e..26fbe503c3 100644 --- a/src/compiler/allocation-builder-inl.h +++ b/src/compiler/allocation-builder-inl.h @@ -15,7 +15,8 @@ namespace internal { namespace compiler { void AllocationBuilder::AllocateContext(int variadic_part_length, MapRef map) { - DCHECK(IsInRange(map.instance_type(), FIRST_CONTEXT_TYPE, LAST_CONTEXT_TYPE)); + DCHECK(base::IsInRange(map.instance_type(), FIRST_CONTEXT_TYPE, + LAST_CONTEXT_TYPE)); DCHECK_NE(NATIVE_CONTEXT_TYPE, map.instance_type()); int size = Context::SizeFor(variadic_part_length); Allocate(size, AllocationType::kYoung, Type::OtherInternal()); diff --git a/src/compiler/backend/arm64/instruction-selector-arm64.cc b/src/compiler/backend/arm64/instruction-selector-arm64.cc index d103f43c95..ab1adfdb2d 100644 --- a/src/compiler/backend/arm64/instruction-selector-arm64.cc +++ b/src/compiler/backend/arm64/instruction-selector-arm64.cc @@ -354,15 +354,15 @@ bool TryMatchLoadStoreShift(Arm64OperandGenerator* g, // Bitfields describing binary operator properties: // CanCommuteField is true if we can switch the two operands, potentially // requiring commuting the flags continuation condition. -using CanCommuteField = BitField8; +using CanCommuteField = base::BitField8; // MustCommuteCondField is true when we need to commute the flags continuation // condition in order to switch the operands. -using MustCommuteCondField = BitField8; +using MustCommuteCondField = base::BitField8; // IsComparisonField is true when the operation is a comparison and has no other // result other than the condition. -using IsComparisonField = BitField8; +using IsComparisonField = base::BitField8; // IsAddSubField is true when an instruction is encoded as ADD or SUB. -using IsAddSubField = BitField8; +using IsAddSubField = base::BitField8; // Get properties of a binary operator. uint8_t GetBinopProperties(InstructionCode opcode) { diff --git a/src/compiler/backend/instruction-codes.h b/src/compiler/backend/instruction-codes.h index 9975f1ed9d..b244bbf06c 100644 --- a/src/compiler/backend/instruction-codes.h +++ b/src/compiler/backend/instruction-codes.h @@ -27,8 +27,8 @@ #define TARGET_ARCH_OPCODE_LIST(V) #define TARGET_ADDRESSING_MODE_LIST(V) #endif +#include "src/base/bit-field.h" #include "src/compiler/write-barrier-kind.h" -#include "src/utils/utils.h" namespace v8 { namespace internal { @@ -267,11 +267,11 @@ using InstructionCode = uint32_t; // for code generation. We encode the instruction, addressing mode, and flags // continuation into a single InstructionCode which is stored as part of // the instruction. -using ArchOpcodeField = BitField; -using AddressingModeField = BitField; -using FlagsModeField = BitField; -using FlagsConditionField = BitField; -using MiscField = BitField; +using ArchOpcodeField = base::BitField; +using AddressingModeField = base::BitField; +using FlagsModeField = base::BitField; +using FlagsConditionField = base::BitField; +using MiscField = base::BitField; } // namespace compiler } // namespace internal diff --git a/src/compiler/backend/instruction.h b/src/compiler/backend/instruction.h index 4bd4e64083..cc2a18bf36 100644 --- a/src/compiler/backend/instruction.h +++ b/src/compiler/backend/instruction.h @@ -125,7 +125,7 @@ class V8_EXPORT_PRIVATE InstructionOperand { inline uint64_t GetCanonicalizedValue() const; - using KindField = BitField64; + using KindField = base::BitField64; uint64_t value_; }; @@ -322,24 +322,24 @@ class UnallocatedOperand final : public InstructionOperand { // P ... Policy // // The slot index is a signed value which requires us to decode it manually - // instead of using the BitField utility class. + // instead of using the base::BitField utility class. STATIC_ASSERT(KindField::kSize == 3); - using VirtualRegisterField = BitField64; + using VirtualRegisterField = base::BitField64; - // BitFields for all unallocated operands. - using BasicPolicyField = BitField64; + // base::BitFields for all unallocated operands. + using BasicPolicyField = base::BitField64; // BitFields specific to BasicPolicy::FIXED_SLOT. - using FixedSlotIndexField = BitField64; + using FixedSlotIndexField = base::BitField64; // BitFields specific to BasicPolicy::EXTENDED_POLICY. - using ExtendedPolicyField = BitField64; - using LifetimeField = BitField64; - using HasSecondaryStorageField = BitField64; - using FixedRegisterField = BitField64; - using SecondaryStorageField = BitField64; + using ExtendedPolicyField = base::BitField64; + using LifetimeField = base::BitField64; + using HasSecondaryStorageField = base::BitField64; + using FixedRegisterField = base::BitField64; + using SecondaryStorageField = base::BitField64; private: explicit UnallocatedOperand(int virtual_register) @@ -368,7 +368,7 @@ class ConstantOperand : public InstructionOperand { INSTRUCTION_OPERAND_CASTS(ConstantOperand, CONSTANT) STATIC_ASSERT(KindField::kSize == 3); - using VirtualRegisterField = BitField64; + using VirtualRegisterField = base::BitField64; }; class ImmediateOperand : public InstructionOperand { @@ -401,8 +401,8 @@ class ImmediateOperand : public InstructionOperand { INSTRUCTION_OPERAND_CASTS(ImmediateOperand, IMMEDIATE) STATIC_ASSERT(KindField::kSize == 3); - using TypeField = BitField64; - using ValueField = BitField64; + using TypeField = base::BitField64; + using ValueField = base::BitField64; }; class LocationOperand : public InstructionOperand { @@ -503,9 +503,9 @@ class LocationOperand : public InstructionOperand { } STATIC_ASSERT(KindField::kSize == 3); - using LocationKindField = BitField64; - using RepresentationField = BitField64; - using IndexField = BitField64; + using LocationKindField = base::BitField64; + using RepresentationField = base::BitField64; + using IndexField = base::BitField64; }; class AllocatedOperand : public LocationOperand { @@ -909,9 +909,9 @@ class V8_EXPORT_PRIVATE Instruction final { // APIs to aid debugging. For general-stream APIs, use operator<<. void Print() const; - using OutputCountField = BitField; - using InputCountField = BitField; - using TempCountField = BitField; + using OutputCountField = base::BitField; + using InputCountField = base::BitField; + using TempCountField = base::BitField; static const size_t kMaxOutputCount = OutputCountField::kMax; static const size_t kMaxInputCount = InputCountField::kMax; @@ -925,7 +925,7 @@ class V8_EXPORT_PRIVATE Instruction final { InstructionOperand* inputs, size_t temp_count, InstructionOperand* temps); - using IsCallField = BitField; + using IsCallField = base::BitField; InstructionCode opcode_; uint32_t bit_field_; diff --git a/src/compiler/backend/register-allocator.h b/src/compiler/backend/register-allocator.h index 583e89bbbf..1cfb6e59b1 100644 --- a/src/compiler/backend/register-allocator.h +++ b/src/compiler/backend/register-allocator.h @@ -487,10 +487,10 @@ class V8_EXPORT_PRIVATE UsePosition final static UsePositionHintType HintTypeForOperand(const InstructionOperand& op); private: - using TypeField = BitField; - using HintTypeField = BitField; - using RegisterBeneficialField = BitField; - using AssignedRegisterField = BitField; + using TypeField = base::BitField; + using HintTypeField = base::BitField; + using RegisterBeneficialField = base::BitField; + using AssignedRegisterField = base::BitField; InstructionOperand* const operand_; void* hint_; @@ -671,12 +671,12 @@ class V8_EXPORT_PRIVATE LiveRange : public NON_EXPORTED_BASE(ZoneObject) { void VerifyPositions() const; void VerifyIntervals() const; - using SpilledField = BitField; + using SpilledField = base::BitField; // Bits (1,7[ are used by TopLevelLiveRange. - using AssignedRegisterField = BitField; - using RepresentationField = BitField; - using RecombineField = BitField; - using ControlFlowRegisterHint = BitField; + using AssignedRegisterField = base::BitField; + using RepresentationField = base::BitField; + using RecombineField = base::BitField; + using ControlFlowRegisterHint = base::BitField; // Bit 28 is used by TopLevelLiveRange. // Unique among children and splinters of the same virtual register. @@ -987,11 +987,11 @@ class V8_EXPORT_PRIVATE TopLevelLiveRange final : public LiveRange { friend class LiveRange; void SetSplinteredFrom(TopLevelLiveRange* splinter_parent); - using HasSlotUseField = BitField; - using IsPhiField = BitField; - using IsNonLoopPhiField = BitField; - using SpillTypeField = BitField; - using DeferredFixedField = BitField; + using HasSlotUseField = base::BitField; + using IsPhiField = base::BitField; + using IsNonLoopPhiField = base::BitField; + using SpillTypeField = base::BitField; + using DeferredFixedField = base::BitField; int vreg_; int last_child_id_; diff --git a/src/compiler/js-operator.h b/src/compiler/js-operator.h index e4cb144463..1f9230d22b 100644 --- a/src/compiler/js-operator.h +++ b/src/compiler/js-operator.h @@ -85,8 +85,8 @@ class ConstructForwardVarargsParameters final { return p.bit_field_; } - using ArityField = BitField; - using StartIndexField = BitField; + using ArityField = base::BitField; + using StartIndexField = base::BitField; uint32_t const bit_field_; }; @@ -147,8 +147,8 @@ class CallForwardVarargsParameters final { return p.bit_field_; } - using ArityField = BitField; - using StartIndexField = BitField; + using ArityField = base::BitField; + using StartIndexField = base::BitField; uint32_t const bit_field_; }; @@ -209,10 +209,10 @@ class CallParameters final { feedback_hash(p.feedback_)); } - using ArityField = BitField; - using CallFeedbackRelationField = BitField; - using SpeculationModeField = BitField; - using ConvertReceiverModeField = BitField; + using ArityField = base::BitField; + using CallFeedbackRelationField = base::BitField; + using SpeculationModeField = base::BitField; + using ConvertReceiverModeField = base::BitField; uint32_t const bit_field_; CallFrequency const frequency_; diff --git a/src/compiler/linkage.h b/src/compiler/linkage.h index b579c532eb..17a419bab3 100644 --- a/src/compiler/linkage.h +++ b/src/compiler/linkage.h @@ -157,7 +157,7 @@ class LinkageLocation { private: enum LocationType { REGISTER, STACK_SLOT }; - using TypeField = BitField; + using TypeField = base::BitField; using LocationField = TypeField::Next; static constexpr int32_t ANY_REGISTER = -1; diff --git a/src/compiler/node.h b/src/compiler/node.h index b4ff5f7185..9bcb272752 100644 --- a/src/compiler/node.h +++ b/src/compiler/node.h @@ -200,8 +200,8 @@ class V8_EXPORT_PRIVATE Node final { : reinterpret_cast(start)->node_; } - using InlineField = BitField; - using InputIndexField = BitField; + using InlineField = base::BitField; + using InputIndexField = base::BitField; }; //============================================================================ @@ -285,9 +285,9 @@ class V8_EXPORT_PRIVATE Node final { void ClearInputs(int start, int count); - using IdField = BitField; - using InlineCountField = BitField; - using InlineCapacityField = BitField; + using IdField = base::BitField; + using InlineCountField = base::BitField; + using InlineCapacityField = base::BitField; static const int kOutlineMarker = InlineCountField::kMax; static const int kMaxInlineCapacity = InlineCapacityField::kMax - 1; diff --git a/src/compiler/wasm-compiler.cc b/src/compiler/wasm-compiler.cc index a441e1db19..5762bc8b4e 100644 --- a/src/compiler/wasm-compiler.cc +++ b/src/compiler/wasm-compiler.cc @@ -3530,7 +3530,7 @@ Node* WasmGraphBuilder::BoundsCheckMem(uint8_t access_size, Node* index, return index; } - if (!IsInBounds(offset, access_size, env_->max_memory_size)) { + if (!base::IsInBounds(offset, access_size, env_->max_memory_size)) { // The access will be out of bounds, even for the largest memory. TrapIfEq32(wasm::kTrapMemOutOfBounds, Int32Constant(0), 0, position); return mcgraph()->IntPtrConstant(0); diff --git a/src/date/dateparser.h b/src/date/dateparser.h index a32db8f9c8..c74a663e1e 100644 --- a/src/date/dateparser.h +++ b/src/date/dateparser.h @@ -7,6 +7,7 @@ #include "src/strings/char-predicates.h" #include "src/utils/allocation.h" +#include "src/utils/vector.h" namespace v8 { namespace internal { diff --git a/src/handles/global-handles.cc b/src/handles/global-handles.cc index 416c65fabd..dce1a280fe 100644 --- a/src/handles/global-handles.cc +++ b/src/handles/global-handles.cc @@ -600,7 +600,7 @@ class GlobalHandles::Node final : public NodeBase { // This stores three flags (independent, partially_dependent and // in_young_list) and a State. - using NodeState = BitField8; + using NodeState = base::BitField8; using IsInYoungList = NodeState::Next; using NodeWeaknessType = IsInYoungList::Next; @@ -674,7 +674,7 @@ class GlobalHandles::TracedNode final } protected: - using NodeState = BitField8; + using NodeState = base::BitField8; using IsInYoungList = NodeState::Next; using IsRoot = IsInYoungList::Next; using HasDestructor = IsRoot::Next; diff --git a/src/heap/slot-set.h b/src/heap/slot-set.h index 28ed256e8f..98cb2da786 100644 --- a/src/heap/slot-set.h +++ b/src/heap/slot-set.h @@ -10,6 +10,7 @@ #include #include "src/base/atomic-utils.h" +#include "src/base/bit-field.h" #include "src/base/bits.h" #include "src/heap/worklist.h" #include "src/objects/compressed-slots.h" @@ -543,8 +544,8 @@ class V8_EXPORT_PRIVATE TypedSlots { void Merge(TypedSlots* other); protected: - using OffsetField = BitField; - using TypeField = BitField; + using OffsetField = base::BitField; + using TypeField = base::BitField; struct TypedSlot { uint32_t type_and_offset; }; diff --git a/src/heap/spaces.h b/src/heap/spaces.h index 53a718fffb..22edd84a75 100644 --- a/src/heap/spaces.h +++ b/src/heap/spaces.h @@ -2460,8 +2460,9 @@ class V8_EXPORT_PRIVATE PagedSpace bool is_local_space() { return local_space_kind_ != LocalSpaceKind::kNone; } bool is_compaction_space() { - return IsInRange(local_space_kind_, LocalSpaceKind::kFirstCompactionSpace, - LocalSpaceKind::kLastCompactionSpace); + return base::IsInRange(local_space_kind_, + LocalSpaceKind::kFirstCompactionSpace, + LocalSpaceKind::kLastCompactionSpace); } LocalSpaceKind local_space_kind() { return local_space_kind_; } diff --git a/src/ic/handler-configuration.h b/src/ic/handler-configuration.h index fd0cee2920..57cdd0894f 100644 --- a/src/ic/handler-configuration.h +++ b/src/ic/handler-configuration.h @@ -48,7 +48,7 @@ class LoadHandler final : public DataHandler { kNonExistent, kModuleExport }; - using KindBits = BitField; + using KindBits = base::BitField; // Defines whether access rights check should be done on receiver object. // Applicable to named property kinds only when loading value from prototype @@ -206,7 +206,7 @@ class StoreHandler final : public DataHandler { kProxy, kKindsNumber // Keep last }; - using KindBits = BitField; + using KindBits = base::BitField; // Applicable to kGlobalProxy, kProxy kinds. diff --git a/src/interpreter/bytecode-flags.h b/src/interpreter/bytecode-flags.h index 40ee88d6eb..e2b590645a 100644 --- a/src/interpreter/bytecode-flags.h +++ b/src/interpreter/bytecode-flags.h @@ -5,7 +5,8 @@ #ifndef V8_INTERPRETER_BYTECODE_FLAGS_H_ #define V8_INTERPRETER_BYTECODE_FLAGS_H_ -#include "src/utils/utils.h" +#include "src/base/bit-field.h" +#include "src/common/globals.h" namespace v8 { namespace internal { @@ -18,7 +19,7 @@ namespace interpreter { class CreateArrayLiteralFlags { public: - using FlagsBits = BitField8; + using FlagsBits = base::BitField8; using FastCloneSupportedBit = FlagsBits::Next; static uint8_t Encode(bool use_fast_shallow_clone, int runtime_flags); @@ -29,7 +30,7 @@ class CreateArrayLiteralFlags { class CreateObjectLiteralFlags { public: - using FlagsBits = BitField8; + using FlagsBits = base::BitField8; using FastCloneSupportedBit = FlagsBits::Next; static uint8_t Encode(int runtime_flags, bool fast_clone_supported); @@ -40,7 +41,7 @@ class CreateObjectLiteralFlags { class CreateClosureFlags { public: - using PretenuredBit = BitField8; + using PretenuredBit = base::BitField8; using FastNewClosureBit = PretenuredBit::Next; static uint8_t Encode(bool pretenure, bool is_function_scope, @@ -80,7 +81,7 @@ class TestTypeOfFlags { class StoreLookupSlotFlags { public: - using LanguageModeBit = BitField8; + using LanguageModeBit = base::BitField8; using LookupHoistingModeBit = LanguageModeBit::Next; STATIC_ASSERT(LanguageModeSize <= LanguageModeBit::kNumValues); diff --git a/src/interpreter/bytecode-operands.h b/src/interpreter/bytecode-operands.h index 0f58e59f3d..a5d2e6e50a 100644 --- a/src/interpreter/bytecode-operands.h +++ b/src/interpreter/bytecode-operands.h @@ -5,8 +5,8 @@ #ifndef V8_INTERPRETER_BYTECODE_OPERANDS_H_ #define V8_INTERPRETER_BYTECODE_OPERANDS_H_ +#include "src/base/bounds.h" #include "src/common/globals.h" -#include "src/utils/utils.h" namespace v8 { namespace internal { @@ -182,13 +182,14 @@ class BytecodeOperands : public AllStatic { // Returns true if |operand_type| is a scalable signed byte. static constexpr bool IsScalableSignedByte(OperandType operand_type) { - return IsInRange(operand_type, OperandType::kImm, - OperandType::kRegOutTriple); + return base::IsInRange(operand_type, OperandType::kImm, + OperandType::kRegOutTriple); } // Returns true if |operand_type| is a scalable unsigned byte. static constexpr bool IsScalableUnsignedByte(OperandType operand_type) { - return IsInRange(operand_type, OperandType::kIdx, OperandType::kRegCount); + return base::IsInRange(operand_type, OperandType::kIdx, + OperandType::kRegCount); } }; diff --git a/src/json/json-parser.cc b/src/json/json-parser.cc index 3a790c210d..6c2ee1baef 100644 --- a/src/json/json-parser.cc +++ b/src/json/json-parser.cc @@ -64,7 +64,7 @@ enum class EscapeKind : uint8_t { kUnicode }; -using EscapeKindField = BitField8; +using EscapeKindField = base::BitField8; using MayTerminateStringField = EscapeKindField::Next; using NumberPartField = MayTerminateStringField::Next; @@ -906,7 +906,8 @@ Handle JsonParser::ParseJsonNumber() { // Prefix zero is only allowed if it's the only digit before // a decimal point or exponent. c = NextCharacter(); - if (IsInRange(c, 0, static_cast(unibrow::Latin1::kMaxChar)) && + if (base::IsInRange(c, 0, + static_cast(unibrow::Latin1::kMaxChar)) && IsNumberPart(character_json_scan_flags[c])) { if (V8_UNLIKELY(IsDecimalDigit(c))) { AllowHeapAllocation allow_before_exception; @@ -929,7 +930,8 @@ Handle JsonParser::ParseJsonNumber() { STATIC_ASSERT(Smi::IsValid(999999999)); const int kMaxSmiLength = 9; if ((cursor_ - smi_start) <= kMaxSmiLength && - (!IsInRange(c, 0, static_cast(unibrow::Latin1::kMaxChar)) || + (!base::IsInRange(c, 0, + static_cast(unibrow::Latin1::kMaxChar)) || !IsNumberPart(character_json_scan_flags[c]))) { // Smi. int32_t i = 0; @@ -1149,7 +1151,7 @@ JsonString JsonParser::ScanJsonString(bool needs_internalization) { if (*cursor_ == '\\') { has_escape = true; uc32 c = NextCharacter(); - if (V8_UNLIKELY(!IsInRange( + if (V8_UNLIKELY(!base::IsInRange( c, 0, static_cast(unibrow::Latin1::kMaxChar)))) { AllowHeapAllocation allow_before_exception; ReportUnexpectedCharacter(c); diff --git a/src/objects/allocation-site.h b/src/objects/allocation-site.h index c1b6417ae1..fde9b7d602 100644 --- a/src/objects/allocation-site.h +++ b/src/objects/allocation-site.h @@ -66,14 +66,14 @@ class AllocationSite : public Struct { bool IsNested(); // transition_info bitfields, for constructed array transition info. - using ElementsKindBits = BitField; - using DoNotInlineBit = BitField; + using ElementsKindBits = base::BitField; + using DoNotInlineBit = base::BitField; // Unused bits 6-30. // Bitfields for pretenure_data - using MementoFoundCountBits = BitField; - using PretenureDecisionBits = BitField; - using DeoptDependentCodeBit = BitField; + using MementoFoundCountBits = base::BitField; + using PretenureDecisionBits = base::BitField; + using DeoptDependentCodeBit = base::BitField; STATIC_ASSERT(PretenureDecisionBits::kMax >= kLastPretenureDecisionValue); // Increments the mementos found counter and returns true when the first diff --git a/src/objects/api-callbacks.h b/src/objects/api-callbacks.h index 72be5deb8f..2bf1a26b9a 100644 --- a/src/objects/api-callbacks.h +++ b/src/objects/api-callbacks.h @@ -5,6 +5,7 @@ #ifndef V8_OBJECTS_API_CALLBACKS_H_ #define V8_OBJECTS_API_CALLBACKS_H_ +#include "src/base/bit-field.h" #include "src/objects/struct.h" #include "torque-generated/class-definitions-tq.h" diff --git a/src/objects/bigint.h b/src/objects/bigint.h index 9cda9d6a15..2247c157a8 100644 --- a/src/objects/bigint.h +++ b/src/objects/bigint.h @@ -53,7 +53,7 @@ class BigIntBase : public PrimitiveHeapObject { // able to read the length concurrently, the getters and setters are atomic. static const int kLengthFieldBits = 30; STATIC_ASSERT(kMaxLength <= ((1 << kLengthFieldBits) - 1)); - using SignBits = BitField; + using SignBits = base::BitField; using LengthBits = SignBits::Next; STATIC_ASSERT(LengthBits::kLastUsedBit < 32); diff --git a/src/objects/code.h b/src/objects/code.h index a171dc65fd..d4776c8b3d 100644 --- a/src/objects/code.h +++ b/src/objects/code.h @@ -5,6 +5,7 @@ #ifndef V8_OBJECTS_CODE_H_ #define V8_OBJECTS_CODE_H_ +#include "src/base/bit-field.h" #include "src/codegen/handler-table.h" #include "src/objects/contexts.h" #include "src/objects/fixed-array.h" @@ -434,7 +435,7 @@ class Code : public HeapObject { class BodyDescriptor; - // Flags layout. BitField. + // Flags layout. base::BitField. #define CODE_FLAGS_BIT_FIELDS(V, _) \ V(HasUnwindingInfoField, bool, 1, _) \ V(KindField, Kind, 5, _) \ @@ -712,8 +713,8 @@ class DependentCode : public WeakFixedArray { inline int flags(); inline void set_flags(int flags); - using GroupField = BitField; - using CountField = BitField; + using GroupField = base::BitField; + using CountField = base::BitField; STATIC_ASSERT(kGroupCount <= GroupField::kMax + 1); OBJECT_CONSTRUCTORS(DependentCode, WeakFixedArray); diff --git a/src/objects/debug-objects.h b/src/objects/debug-objects.h index 39f42c1168..1392d43e6d 100644 --- a/src/objects/debug-objects.h +++ b/src/objects/debug-objects.h @@ -7,6 +7,7 @@ #include +#include "src/base/bit-field.h" #include "src/objects/fixed-array.h" #include "src/objects/objects.h" #include "src/objects/struct.h" diff --git a/src/objects/descriptor-array.h b/src/objects/descriptor-array.h index 73b94b7cfa..141864afa4 100644 --- a/src/objects/descriptor-array.h +++ b/src/objects/descriptor-array.h @@ -7,6 +7,7 @@ #include "src/objects/fixed-array.h" // TODO(jkummerow): Consider forward-declaring instead. +#include "src/base/bit-field.h" #include "src/objects/internal-index.h" #include "src/objects/objects.h" #include "src/objects/struct.h" diff --git a/src/objects/elements-kind.h b/src/objects/elements-kind.h index e1335fa3c0..fd5c60d5d4 100644 --- a/src/objects/elements-kind.h +++ b/src/objects/elements-kind.h @@ -5,10 +5,10 @@ #ifndef V8_OBJECTS_ELEMENTS_KIND_H_ #define V8_OBJECTS_ELEMENTS_KIND_H_ +#include "src/base/bounds.h" #include "src/base/macros.h" #include "src/common/checks.h" #include "src/flags/flags.h" -#include "src/utils/utils.h" namespace v8 { namespace internal { @@ -119,18 +119,18 @@ inline bool IsDictionaryElementsKind(ElementsKind kind) { } inline bool IsSloppyArgumentsElementsKind(ElementsKind kind) { - return IsInRange(kind, FAST_SLOPPY_ARGUMENTS_ELEMENTS, - SLOW_SLOPPY_ARGUMENTS_ELEMENTS); + return base::IsInRange(kind, FAST_SLOPPY_ARGUMENTS_ELEMENTS, + SLOW_SLOPPY_ARGUMENTS_ELEMENTS); } inline bool IsStringWrapperElementsKind(ElementsKind kind) { - return IsInRange(kind, FAST_STRING_WRAPPER_ELEMENTS, - SLOW_STRING_WRAPPER_ELEMENTS); + return base::IsInRange(kind, FAST_STRING_WRAPPER_ELEMENTS, + SLOW_STRING_WRAPPER_ELEMENTS); } inline bool IsTypedArrayElementsKind(ElementsKind kind) { - return IsInRange(kind, FIRST_FIXED_TYPED_ARRAY_ELEMENTS_KIND, - LAST_FIXED_TYPED_ARRAY_ELEMENTS_KIND); + return base::IsInRange(kind, FIRST_FIXED_TYPED_ARRAY_ELEMENTS_KIND, + LAST_FIXED_TYPED_ARRAY_ELEMENTS_KIND); } inline bool IsTerminalElementsKind(ElementsKind kind) { @@ -149,7 +149,7 @@ inline bool IsTransitionElementsKind(ElementsKind kind) { } inline bool IsDoubleElementsKind(ElementsKind kind) { - return IsInRange(kind, PACKED_DOUBLE_ELEMENTS, HOLEY_DOUBLE_ELEMENTS); + return base::IsInRange(kind, PACKED_DOUBLE_ELEMENTS, HOLEY_DOUBLE_ELEMENTS); } inline bool IsFixedFloatElementsKind(ElementsKind kind) { @@ -162,8 +162,8 @@ inline bool IsDoubleOrFloatElementsKind(ElementsKind kind) { // This predicate is used for disabling respective functionality in builtins. inline bool IsAnyNonextensibleElementsKindUnchecked(ElementsKind kind) { - return IsInRange(kind, FIRST_ANY_NONEXTENSIBLE_ELEMENTS_KIND, - LAST_ANY_NONEXTENSIBLE_ELEMENTS_KIND); + return base::IsInRange(kind, FIRST_ANY_NONEXTENSIBLE_ELEMENTS_KIND, + LAST_ANY_NONEXTENSIBLE_ELEMENTS_KIND); } inline bool IsAnyNonextensibleElementsKind(ElementsKind kind) { @@ -173,31 +173,33 @@ inline bool IsAnyNonextensibleElementsKind(ElementsKind kind) { } inline bool IsNonextensibleElementsKind(ElementsKind kind) { - DCHECK_IMPLIES(IsInRange(kind, PACKED_NONEXTENSIBLE_ELEMENTS, - HOLEY_NONEXTENSIBLE_ELEMENTS), + DCHECK_IMPLIES(base::IsInRange(kind, PACKED_NONEXTENSIBLE_ELEMENTS, + HOLEY_NONEXTENSIBLE_ELEMENTS), FLAG_enable_sealed_frozen_elements_kind); - return IsInRange(kind, PACKED_NONEXTENSIBLE_ELEMENTS, - HOLEY_NONEXTENSIBLE_ELEMENTS); + return base::IsInRange(kind, PACKED_NONEXTENSIBLE_ELEMENTS, + HOLEY_NONEXTENSIBLE_ELEMENTS); } inline bool IsSealedElementsKind(ElementsKind kind) { - DCHECK_IMPLIES(IsInRange(kind, PACKED_SEALED_ELEMENTS, HOLEY_SEALED_ELEMENTS), - FLAG_enable_sealed_frozen_elements_kind); - return IsInRange(kind, PACKED_SEALED_ELEMENTS, HOLEY_SEALED_ELEMENTS); + DCHECK_IMPLIES( + base::IsInRange(kind, PACKED_SEALED_ELEMENTS, HOLEY_SEALED_ELEMENTS), + FLAG_enable_sealed_frozen_elements_kind); + return base::IsInRange(kind, PACKED_SEALED_ELEMENTS, HOLEY_SEALED_ELEMENTS); } inline bool IsFrozenElementsKind(ElementsKind kind) { - DCHECK_IMPLIES(IsInRange(kind, PACKED_FROZEN_ELEMENTS, HOLEY_FROZEN_ELEMENTS), - FLAG_enable_sealed_frozen_elements_kind); - return IsInRange(kind, PACKED_FROZEN_ELEMENTS, HOLEY_FROZEN_ELEMENTS); + DCHECK_IMPLIES( + base::IsInRange(kind, PACKED_FROZEN_ELEMENTS, HOLEY_FROZEN_ELEMENTS), + FLAG_enable_sealed_frozen_elements_kind); + return base::IsInRange(kind, PACKED_FROZEN_ELEMENTS, HOLEY_FROZEN_ELEMENTS); } inline bool IsSmiOrObjectElementsKind(ElementsKind kind) { - return IsInRange(kind, PACKED_SMI_ELEMENTS, HOLEY_ELEMENTS); + return base::IsInRange(kind, PACKED_SMI_ELEMENTS, HOLEY_ELEMENTS); } inline bool IsSmiElementsKind(ElementsKind kind) { - return IsInRange(kind, PACKED_SMI_ELEMENTS, HOLEY_SMI_ELEMENTS); + return base::IsInRange(kind, PACKED_SMI_ELEMENTS, HOLEY_SMI_ELEMENTS); } inline bool IsFastNumberElementsKind(ElementsKind kind) { @@ -205,7 +207,7 @@ inline bool IsFastNumberElementsKind(ElementsKind kind) { } inline bool IsObjectElementsKind(ElementsKind kind) { - return IsInRange(kind, PACKED_ELEMENTS, HOLEY_ELEMENTS); + return base::IsInRange(kind, PACKED_ELEMENTS, HOLEY_ELEMENTS); } inline bool IsAnyHoleyNonextensibleElementsKind(ElementsKind kind) { diff --git a/src/objects/feedback-vector.h b/src/objects/feedback-vector.h index 1c34266dc8..72046efc16 100644 --- a/src/objects/feedback-vector.h +++ b/src/objects/feedback-vector.h @@ -7,6 +7,7 @@ #include +#include "src/base/bit-field.h" #include "src/base/logging.h" #include "src/base/macros.h" #include "src/common/globals.h" @@ -554,8 +555,8 @@ class FeedbackMetadata : public HeapObject { void SetKind(FeedbackSlot slot, FeedbackSlotKind kind); using VectorICComputer = - BitSetComputer; + base::BitSetComputer; OBJECT_CONSTRUCTORS(FeedbackMetadata, HeapObject); }; @@ -699,8 +700,8 @@ class V8_EXPORT_PRIVATE FeedbackNexus final { // count (taken from the type feedback vector). float ComputeCallFrequency(); - using SpeculationModeField = BitField; - using CallCountField = BitField; + using SpeculationModeField = base::BitField; + using CallCountField = base::BitField; // For InstanceOf ICs. MaybeHandle GetConstructorFeedback() const; diff --git a/src/objects/field-index.h b/src/objects/field-index.h index fbde0bc609..8741d553ba 100644 --- a/src/objects/field-index.h +++ b/src/objects/field-index.h @@ -110,7 +110,7 @@ class FieldIndex final { (kDescriptorIndexBitCount + 1 + kTaggedSizeLog2); // Index from beginning of object. - using OffsetBits = BitField64; + using OffsetBits = base::BitField64; using IsInObjectBits = OffsetBits::Next; using EncodingBits = IsInObjectBits::Next; // Number of inobject properties. diff --git a/src/objects/function-kind.h b/src/objects/function-kind.h index 9b0de76126..dda576fd8a 100644 --- a/src/objects/function-kind.h +++ b/src/objects/function-kind.h @@ -5,7 +5,7 @@ #ifndef V8_OBJECTS_FUNCTION_KIND_H_ #define V8_OBJECTS_FUNCTION_KIND_H_ -#include "src/utils/utils.h" +#include "src/base/bounds.h" namespace v8 { namespace internal { @@ -57,12 +57,13 @@ enum FunctionKind : uint8_t { }; inline bool IsArrowFunction(FunctionKind kind) { - return IsInRange(kind, FunctionKind::kArrowFunction, - FunctionKind::kAsyncArrowFunction); + return base::IsInRange(kind, FunctionKind::kArrowFunction, + FunctionKind::kAsyncArrowFunction); } inline bool IsModule(FunctionKind kind) { - return IsInRange(kind, FunctionKind::kModule, FunctionKind::kAsyncModule); + return base::IsInRange(kind, FunctionKind::kModule, + FunctionKind::kAsyncModule); } inline bool IsAsyncModule(FunctionKind kind) { @@ -70,18 +71,18 @@ inline bool IsAsyncModule(FunctionKind kind) { } inline bool IsAsyncGeneratorFunction(FunctionKind kind) { - return IsInRange(kind, FunctionKind::kAsyncConciseGeneratorMethod, - FunctionKind::kAsyncGeneratorFunction); + return base::IsInRange(kind, FunctionKind::kAsyncConciseGeneratorMethod, + FunctionKind::kAsyncGeneratorFunction); } inline bool IsGeneratorFunction(FunctionKind kind) { - return IsInRange(kind, FunctionKind::kAsyncConciseGeneratorMethod, - FunctionKind::kConciseGeneratorMethod); + return base::IsInRange(kind, FunctionKind::kAsyncConciseGeneratorMethod, + FunctionKind::kConciseGeneratorMethod); } inline bool IsAsyncFunction(FunctionKind kind) { - return IsInRange(kind, FunctionKind::kAsyncArrowFunction, - FunctionKind::kAsyncGeneratorFunction); + return base::IsInRange(kind, FunctionKind::kAsyncArrowFunction, + FunctionKind::kAsyncGeneratorFunction); } inline bool IsResumableFunction(FunctionKind kind) { @@ -89,19 +90,19 @@ inline bool IsResumableFunction(FunctionKind kind) { } inline bool IsConciseMethod(FunctionKind kind) { - return IsInRange(kind, FunctionKind::kAsyncConciseMethod, - FunctionKind::kAsyncConciseGeneratorMethod) || - IsInRange(kind, FunctionKind::kConciseGeneratorMethod, - FunctionKind::kClassMembersInitializerFunction); + return base::IsInRange(kind, FunctionKind::kAsyncConciseMethod, + FunctionKind::kAsyncConciseGeneratorMethod) || + base::IsInRange(kind, FunctionKind::kConciseGeneratorMethod, + FunctionKind::kClassMembersInitializerFunction); } inline bool IsStrictFunctionWithoutPrototype(FunctionKind kind) { - return IsInRange(kind, FunctionKind::kGetterFunction, - FunctionKind::kAsyncArrowFunction) || - IsInRange(kind, FunctionKind::kAsyncConciseMethod, - FunctionKind::kAsyncConciseGeneratorMethod) || - IsInRange(kind, FunctionKind::kConciseGeneratorMethod, - FunctionKind::kClassMembersInitializerFunction); + return base::IsInRange(kind, FunctionKind::kGetterFunction, + FunctionKind::kAsyncArrowFunction) || + base::IsInRange(kind, FunctionKind::kAsyncConciseMethod, + FunctionKind::kAsyncConciseGeneratorMethod) || + base::IsInRange(kind, FunctionKind::kConciseGeneratorMethod, + FunctionKind::kClassMembersInitializerFunction); } inline bool IsGetterFunction(FunctionKind kind) { @@ -113,28 +114,28 @@ inline bool IsSetterFunction(FunctionKind kind) { } inline bool IsAccessorFunction(FunctionKind kind) { - return IsInRange(kind, FunctionKind::kGetterFunction, - FunctionKind::kSetterFunction); + return base::IsInRange(kind, FunctionKind::kGetterFunction, + FunctionKind::kSetterFunction); } inline bool IsDefaultConstructor(FunctionKind kind) { - return IsInRange(kind, FunctionKind::kDefaultBaseConstructor, - FunctionKind::kDefaultDerivedConstructor); + return base::IsInRange(kind, FunctionKind::kDefaultBaseConstructor, + FunctionKind::kDefaultDerivedConstructor); } inline bool IsBaseConstructor(FunctionKind kind) { - return IsInRange(kind, FunctionKind::kBaseConstructor, - FunctionKind::kDefaultBaseConstructor); + return base::IsInRange(kind, FunctionKind::kBaseConstructor, + FunctionKind::kDefaultBaseConstructor); } inline bool IsDerivedConstructor(FunctionKind kind) { - return IsInRange(kind, FunctionKind::kDefaultDerivedConstructor, - FunctionKind::kDerivedConstructor); + return base::IsInRange(kind, FunctionKind::kDefaultDerivedConstructor, + FunctionKind::kDerivedConstructor); } inline bool IsClassConstructor(FunctionKind kind) { - return IsInRange(kind, FunctionKind::kBaseConstructor, - FunctionKind::kDerivedConstructor); + return base::IsInRange(kind, FunctionKind::kBaseConstructor, + FunctionKind::kDerivedConstructor); } inline bool IsClassMembersInitializerFunction(FunctionKind kind) { @@ -142,8 +143,8 @@ inline bool IsClassMembersInitializerFunction(FunctionKind kind) { } inline bool IsConstructable(FunctionKind kind) { - return IsInRange(kind, FunctionKind::kNormalFunction, - FunctionKind::kDerivedConstructor); + return base::IsInRange(kind, FunctionKind::kNormalFunction, + FunctionKind::kDerivedConstructor); } inline const char* FunctionKind2String(FunctionKind kind) { diff --git a/src/objects/instance-type-inl.h b/src/objects/instance-type-inl.h index f182b68121..25a76db6c9 100644 --- a/src/objects/instance-type-inl.h +++ b/src/objects/instance-type-inl.h @@ -24,7 +24,7 @@ INSTANCE_TYPE_CHECKERS_SINGLE(INSTANCE_TYPE_CHECKER) template struct InstanceRangeChecker { static constexpr bool Check(InstanceType value) { - return IsInRange(value, lower_limit, upper_limit); + return base::IsInRange(value, lower_limit, upper_limit); } }; template diff --git a/src/objects/js-array-buffer.h b/src/objects/js-array-buffer.h index 71adb42ae8..41becd2499 100644 --- a/src/objects/js-array-buffer.h +++ b/src/objects/js-array-buffer.h @@ -5,6 +5,7 @@ #ifndef V8_OBJECTS_JS_ARRAY_BUFFER_H_ #define V8_OBJECTS_JS_ARRAY_BUFFER_H_ +#include "src/base/bit-field.h" #include "src/objects/backing-store.h" #include "src/objects/js-objects.h" diff --git a/src/objects/js-date-time-format.cc b/src/objects/js-date-time-format.cc index 1109bef142..06925c68d2 100644 --- a/src/objects/js-date-time-format.cc +++ b/src/objects/js-date-time-format.cc @@ -250,13 +250,13 @@ std::string GetGMTTzID(Isolate* isolate, const std::string& input) { break; case 9: if ((input[7] == '+' || input[7] == '-') && - IsInRange(input[8], '0', '9')) { + base::IsInRange(input[8], '0', '9')) { return ret + input[7] + input[8]; } break; case 10: if ((input[7] == '+' || input[7] == '-') && (input[8] == '1') && - IsInRange(input[9], '0', '4')) { + base::IsInRange(input[9], '0', '4')) { return ret + input[7] + input[8] + input[9]; } break; @@ -267,18 +267,18 @@ std::string GetGMTTzID(Isolate* isolate, const std::string& input) { // Locale independenty version of isalpha for ascii range. This will return // false if the ch is alpha but not in ascii range. bool IsAsciiAlpha(char ch) { - return IsInRange(ch, 'A', 'Z') || IsInRange(ch, 'a', 'z'); + return base::IsInRange(ch, 'A', 'Z') || base::IsInRange(ch, 'a', 'z'); } // Locale independent toupper for ascii range. This will not return İ (dotted I) // for i under Turkish locale while std::toupper may. char LocaleIndependentAsciiToUpper(char ch) { - return (IsInRange(ch, 'a', 'z')) ? (ch - 'a' + 'A') : ch; + return (base::IsInRange(ch, 'a', 'z')) ? (ch - 'a' + 'A') : ch; } // Locale independent tolower for ascii range. char LocaleIndependentAsciiToLower(char ch) { - return (IsInRange(ch, 'A', 'Z')) ? (ch - 'A' + 'a') : ch; + return (base::IsInRange(ch, 'A', 'Z')) ? (ch - 'A' + 'a') : ch; } // Returns titlecased location, bueNos_airES -> Buenos_Aires diff --git a/src/objects/js-date-time-format.h b/src/objects/js-date-time-format.h index f02b50f63e..ae3783f246 100644 --- a/src/objects/js-date-time-format.h +++ b/src/objects/js-date-time-format.h @@ -12,6 +12,7 @@ #include #include +#include "src/base/bit-field.h" #include "src/execution/isolate.h" #include "src/objects/intl-objects.h" #include "src/objects/managed.h" diff --git a/src/objects/js-list-format.h b/src/objects/js-list-format.h index 1ff76790f9..c2392969d3 100644 --- a/src/objects/js-list-format.h +++ b/src/objects/js-list-format.h @@ -12,6 +12,7 @@ #include #include +#include "src/base/bit-field.h" #include "src/execution/isolate.h" #include "src/heap/factory.h" #include "src/objects/managed.h" diff --git a/src/objects/js-number-format.cc b/src/objects/js-number-format.cc index 56cf1b8ed6..92d3e2fb82 100644 --- a/src/objects/js-number-format.cc +++ b/src/objects/js-number-format.cc @@ -282,7 +282,9 @@ int CurrencyDigits(const icu::UnicodeString& currency) { return U_SUCCESS(status) ? fraction_digits : 2; } -bool IsAToZ(char ch) { return IsInRange(AsciiAlphaToLower(ch), 'a', 'z'); } +bool IsAToZ(char ch) { + return base::IsInRange(AsciiAlphaToLower(ch), 'a', 'z'); +} // ecma402/#sec-iswellformedcurrencycode bool IsWellFormedCurrencyCode(const std::string& currency) { diff --git a/src/objects/js-number-format.h b/src/objects/js-number-format.h index b99eb6f16a..dd11564188 100644 --- a/src/objects/js-number-format.h +++ b/src/objects/js-number-format.h @@ -12,6 +12,7 @@ #include #include +#include "src/base/bit-field.h" #include "src/execution/isolate.h" #include "src/heap/factory.h" #include "src/objects/intl-objects.h" diff --git a/src/objects/js-plural-rules.h b/src/objects/js-plural-rules.h index 0303266894..0b2b91ef2b 100644 --- a/src/objects/js-plural-rules.h +++ b/src/objects/js-plural-rules.h @@ -12,6 +12,7 @@ #include #include +#include "src/base/bit-field.h" #include "src/execution/isolate.h" #include "src/heap/factory.h" #include "src/objects/intl-objects.h" diff --git a/src/objects/js-promise.h b/src/objects/js-promise.h index 0ca0e5c5a6..1c5174a409 100644 --- a/src/objects/js-promise.h +++ b/src/objects/js-promise.h @@ -70,7 +70,7 @@ class JSPromise : public TorqueGeneratedJSPromise { static const int kStatusBits = 2; static const int kHasHandlerBit = 2; static const int kHandledHintBit = 3; - using AsyncTaskIdField = BitField; + using AsyncTaskIdField = base::BitField; static const int kStatusShift = 0; static const int kStatusMask = 0x3; diff --git a/src/objects/js-relative-time-format.h b/src/objects/js-relative-time-format.h index fd3cd3733e..99d09e5c3c 100644 --- a/src/objects/js-relative-time-format.h +++ b/src/objects/js-relative-time-format.h @@ -12,6 +12,7 @@ #include #include +#include "src/base/bit-field.h" #include "src/execution/isolate.h" #include "src/heap/factory.h" #include "src/objects/managed.h" diff --git a/src/objects/js-segment-iterator.h b/src/objects/js-segment-iterator.h index 1c71af8864..01fc268298 100644 --- a/src/objects/js-segment-iterator.h +++ b/src/objects/js-segment-iterator.h @@ -9,6 +9,7 @@ #ifndef V8_OBJECTS_JS_SEGMENT_ITERATOR_H_ #define V8_OBJECTS_JS_SEGMENT_ITERATOR_H_ +#include "src/base/bit-field.h" #include "src/execution/isolate.h" #include "src/heap/factory.h" #include "src/objects/js-segmenter.h" diff --git a/src/objects/js-segmenter.h b/src/objects/js-segmenter.h index 209c4682b3..b683e95bf1 100644 --- a/src/objects/js-segmenter.h +++ b/src/objects/js-segmenter.h @@ -12,6 +12,7 @@ #include #include +#include "src/base/bit-field.h" #include "src/execution/isolate.h" #include "src/heap/factory.h" #include "src/objects/managed.h" diff --git a/src/objects/js-weak-refs.h b/src/objects/js-weak-refs.h index 8d61b125a1..56f4307fc2 100644 --- a/src/objects/js-weak-refs.h +++ b/src/objects/js-weak-refs.h @@ -69,7 +69,7 @@ class JSFinalizationGroup : public JSObject { TORQUE_GENERATED_JS_FINALIZATION_GROUP_FIELDS) // Bitfields in flags. - using ScheduledForCleanupField = BitField; + using ScheduledForCleanupField = base::BitField; OBJECT_CONSTRUCTORS(JSFinalizationGroup, JSObject); }; diff --git a/src/objects/literal-objects.h b/src/objects/literal-objects.h index cf551ea576..7038c09999 100644 --- a/src/objects/literal-objects.h +++ b/src/objects/literal-objects.h @@ -5,6 +5,7 @@ #ifndef V8_OBJECTS_LITERAL_OBJECTS_H_ #define V8_OBJECTS_LITERAL_OBJECTS_H_ +#include "src/base/bit-field.h" #include "src/objects/fixed-array.h" #include "src/objects/struct.h" diff --git a/src/objects/map.h b/src/objects/map.h index f91c1e9fbb..460fc5afe6 100644 --- a/src/objects/map.h +++ b/src/objects/map.h @@ -5,6 +5,7 @@ #ifndef V8_OBJECTS_MAP_H_ #define V8_OBJECTS_MAP_H_ +#include "src/base/bit-field.h" #include "src/common/globals.h" #include "src/objects/code.h" #include "src/objects/heap-object.h" diff --git a/src/objects/name.h b/src/objects/name.h index dd42e00f6c..3243626a08 100644 --- a/src/objects/name.h +++ b/src/objects/name.h @@ -5,6 +5,7 @@ #ifndef V8_OBJECTS_NAME_H_ #define V8_OBJECTS_NAME_H_ +#include "src/base/bit-field.h" #include "src/objects/objects.h" #include "src/objects/primitive-heap-object.h" @@ -114,10 +115,10 @@ class Name : public TorqueGeneratedName { STATIC_ASSERT(kMaxArrayIndexSize < (1 << kArrayIndexLengthBits)); using ArrayIndexValueBits = - BitField; + base::BitField; using ArrayIndexLengthBits = - BitField; + base::BitField; // Check that kMaxCachedArrayIndexLength + 1 is a power of two so we // could use a mask to test if the length of string is less than or equal to diff --git a/src/objects/objects.cc b/src/objects/objects.cc index 7fea2594a0..547d8c0256 100644 --- a/src/objects/objects.cc +++ b/src/objects/objects.cc @@ -2186,11 +2186,12 @@ int HeapObject::SizeFromMap(Map map) const { if (instance_size != kVariableSizeSentinel) return instance_size; // Only inline the most frequent cases. InstanceType instance_type = map.instance_type(); - if (IsInRange(instance_type, FIRST_FIXED_ARRAY_TYPE, LAST_FIXED_ARRAY_TYPE)) { + if (base::IsInRange(instance_type, FIRST_FIXED_ARRAY_TYPE, + LAST_FIXED_ARRAY_TYPE)) { return FixedArray::SizeFor( FixedArray::unchecked_cast(*this).synchronized_length()); } - if (IsInRange(instance_type, FIRST_CONTEXT_TYPE, LAST_CONTEXT_TYPE)) { + if (base::IsInRange(instance_type, FIRST_CONTEXT_TYPE, LAST_CONTEXT_TYPE)) { if (instance_type == NATIVE_CONTEXT_TYPE) return NativeContext::kSize; return Context::SizeFor(Context::unchecked_cast(*this).length()); } @@ -2231,8 +2232,8 @@ int HeapObject::SizeFromMap(Map map) const { return DescriptorArray::SizeFor( DescriptorArray::unchecked_cast(*this).number_of_all_descriptors()); } - if (IsInRange(instance_type, FIRST_WEAK_FIXED_ARRAY_TYPE, - LAST_WEAK_FIXED_ARRAY_TYPE)) { + if (base::IsInRange(instance_type, FIRST_WEAK_FIXED_ARRAY_TYPE, + LAST_WEAK_FIXED_ARRAY_TYPE)) { return WeakFixedArray::SizeFor( WeakFixedArray::unchecked_cast(*this).synchronized_length()); } diff --git a/src/objects/property-array.h b/src/objects/property-array.h index 62a472aa90..58e474e5d3 100644 --- a/src/objects/property-array.h +++ b/src/objects/property-array.h @@ -61,10 +61,10 @@ class PropertyArray : public HeapObject { using BodyDescriptor = FlexibleBodyDescriptor; static const int kLengthFieldSize = 10; - using LengthField = BitField; + using LengthField = base::BitField; static const int kMaxLength = LengthField::kMax; - using HashField = - BitField; + using HashField = base::BitField; static const int kNoHashSentinel = 0; diff --git a/src/objects/property-descriptor-object.h b/src/objects/property-descriptor-object.h index f4930c4a31..380f738738 100644 --- a/src/objects/property-descriptor-object.h +++ b/src/objects/property-descriptor-object.h @@ -5,6 +5,7 @@ #ifndef V8_OBJECTS_PROPERTY_DESCRIPTOR_OBJECT_H_ #define V8_OBJECTS_PROPERTY_DESCRIPTOR_OBJECT_H_ +#include "src/base/bit-field.h" #include "src/objects/fixed-array.h" #include "src/objects/objects.h" diff --git a/src/objects/property-details.h b/src/objects/property-details.h index 51318f475a..a23a1e3a0e 100644 --- a/src/objects/property-details.h +++ b/src/objects/property-details.h @@ -8,8 +8,8 @@ #include "include/v8.h" #include "src/utils/allocation.h" // TODO(bmeurer): Remove once FLAG_modify_field_representation_inplace is gone. +#include "src/base/bit-field.h" #include "src/flags/flags.h" -#include "src/utils/utils.h" namespace v8 { namespace internal { @@ -322,7 +322,7 @@ class PropertyDetails { // Bit fields in value_ (type, shift, size). Must be public so the // constants can be embedded in generated code. - using KindField = BitField; + using KindField = base::BitField; using LocationField = KindField::Next; using ConstnessField = LocationField::Next; using AttributesField = ConstnessField::Next; diff --git a/src/objects/scope-info.h b/src/objects/scope-info.h index da4a0b5a87..e44ae4879d 100644 --- a/src/objects/scope-info.h +++ b/src/objects/scope-info.h @@ -248,7 +248,7 @@ class ScopeInfo : public FixedArray { enum VariableAllocationInfo { NONE, STACK, CONTEXT, UNUSED }; // Properties of scopes. - using ScopeTypeField = BitField; + using ScopeTypeField = base::BitField; using SloppyEvalCanExtendVarsField = ScopeTypeField::Next; STATIC_ASSERT(LanguageModeSize == 2); using LanguageModeField = SloppyEvalCanExtendVarsField::Next; @@ -347,7 +347,7 @@ class ScopeInfo : public FixedArray { static const int kPositionInfoEntries = 2; // Properties of variables. - using VariableModeField = BitField; + using VariableModeField = base::BitField; using InitFlagField = VariableModeField::Next; using MaybeAssignedFlagField = InitFlagField::Next; using ParameterNumberField = MaybeAssignedFlagField::Next; diff --git a/src/objects/shared-function-info.h b/src/objects/shared-function-info.h index fe0fdd3cbc..1917f95153 100644 --- a/src/objects/shared-function-info.h +++ b/src/objects/shared-function-info.h @@ -7,6 +7,7 @@ #include +#include "src/base/bit-field.h" #include "src/codegen/bailout-reason.h" #include "src/objects/compressed-slots.h" #include "src/objects/function-kind.h" diff --git a/src/objects/templates.h b/src/objects/templates.h index 29671db83c..c2cc0855a7 100644 --- a/src/objects/templates.h +++ b/src/objects/templates.h @@ -166,7 +166,7 @@ class ObjectTemplateInfo inline ObjectTemplateInfo GetParent(Isolate* isolate); private: - using IsImmutablePrototype = BitField; + using IsImmutablePrototype = base::BitField; using EmbedderFieldCount = IsImmutablePrototype::Next; TQ_OBJECT_CONSTRUCTORS(ObjectTemplateInfo) diff --git a/src/parsing/expression-scope.h b/src/parsing/expression-scope.h index 0d32b584a7..9079f1e7c1 100644 --- a/src/parsing/expression-scope.h +++ b/src/parsing/expression-scope.h @@ -196,7 +196,7 @@ class ExpressionScope { } bool IsCertainlyDeclaration() const { - return IsInRange(type_, kParameterDeclaration, kLexicalDeclaration); + return base::IsInRange(type_, kParameterDeclaration, kLexicalDeclaration); } int SetInitializers(int variable_index, int peek_position) { @@ -263,14 +263,15 @@ class ExpressionScope { #endif bool CanBeExpression() const { - return IsInRange(type_, kExpression, kMaybeAsyncArrowParameterDeclaration); + return base::IsInRange(type_, kExpression, + kMaybeAsyncArrowParameterDeclaration); } bool CanBeDeclaration() const { - return IsInRange(type_, kMaybeArrowParameterDeclaration, - kLexicalDeclaration); + return base::IsInRange(type_, kMaybeArrowParameterDeclaration, + kLexicalDeclaration); } bool IsVariableDeclaration() const { - return IsInRange(type_, kVarDeclaration, kLexicalDeclaration); + return base::IsInRange(type_, kVarDeclaration, kLexicalDeclaration); } bool IsLexicalDeclaration() const { return type_ == kLexicalDeclaration; } bool IsAsyncArrowHeadParsingScope() const { @@ -299,17 +300,17 @@ class ExpressionScope { } bool IsArrowHeadParsingScope() const { - return IsInRange(type_, kMaybeArrowParameterDeclaration, - kMaybeAsyncArrowParameterDeclaration); + return base::IsInRange(type_, kMaybeArrowParameterDeclaration, + kMaybeAsyncArrowParameterDeclaration); } bool IsCertainlyPattern() const { return IsCertainlyDeclaration(); } bool CanBeParameterDeclaration() const { - return IsInRange(type_, kMaybeArrowParameterDeclaration, - kParameterDeclaration); + return base::IsInRange(type_, kMaybeArrowParameterDeclaration, + kParameterDeclaration); } bool CanBeArrowParameterDeclaration() const { - return IsInRange(type_, kMaybeArrowParameterDeclaration, - kMaybeAsyncArrowParameterDeclaration); + return base::IsInRange(type_, kMaybeArrowParameterDeclaration, + kMaybeAsyncArrowParameterDeclaration); } bool IsCertainlyParameterDeclaration() const { return type_ == kParameterDeclaration; diff --git a/src/parsing/keywords-gen.h b/src/parsing/keywords-gen.h index b256187c96..3a8101b6c5 100644 --- a/src/parsing/keywords-gen.h +++ b/src/parsing/keywords-gen.h @@ -154,7 +154,7 @@ static const struct PerfectKeywordHashTableEntry kPerfectKeywordHashTable[64] = {"", Token::IDENTIFIER}}; inline Token::Value PerfectKeywordHash::GetToken(const char* str, int len) { - if (IsInRange(len, MIN_WORD_LENGTH, MAX_WORD_LENGTH)) { + if (base::IsInRange(len, MIN_WORD_LENGTH, MAX_WORD_LENGTH)) { unsigned int key = Hash(str, len) & 0x3f; DCHECK_LT(key, arraysize(kPerfectKeywordLengthTable)); diff --git a/src/parsing/parser-base.h b/src/parsing/parser-base.h index 3418107e7e..a0eaff54f2 100644 --- a/src/parsing/parser-base.h +++ b/src/parsing/parser-base.h @@ -1051,8 +1051,8 @@ class ParserBase { ExpressionT ParseArrayLiteral(); inline static bool IsAccessor(ParsePropertyKind kind) { - return IsInRange(kind, ParsePropertyKind::kAccessorGetter, - ParsePropertyKind::kAccessorSetter); + return base::IsInRange(kind, ParsePropertyKind::kAccessorGetter, + ParsePropertyKind::kAccessorSetter); } ExpressionT ParseProperty(ParsePropertyInfo* prop_info); @@ -1503,7 +1503,7 @@ template typename ParserBase::IdentifierT ParserBase::ParseAndClassifyIdentifier(Token::Value next) { DCHECK_EQ(scanner()->current_token(), next); - if (V8_LIKELY(IsInRange(next, Token::IDENTIFIER, Token::ASYNC))) { + if (V8_LIKELY(base::IsInRange(next, Token::IDENTIFIER, Token::ASYNC))) { IdentifierT name = impl()->GetIdentifier(); if (V8_UNLIKELY(impl()->IsArguments(name) && scope()->ShouldBanArguments())) { @@ -2013,7 +2013,7 @@ typename ParserBase::ExpressionT ParserBase::ParseProperty( } if (prop_info->kind == ParsePropertyKind::kNotSet && - IsInRange(peek(), Token::GET, Token::SET)) { + base::IsInRange(peek(), Token::GET, Token::SET)) { Token::Value token = Next(); if (prop_info->ParsePropertyKindFromToken(peek())) { prop_info->name = impl()->GetIdentifier(); diff --git a/src/parsing/preparse-data.cc b/src/parsing/preparse-data.cc index 460ae65a30..e9db791909 100644 --- a/src/parsing/preparse-data.cc +++ b/src/parsing/preparse-data.cc @@ -21,7 +21,7 @@ namespace internal { namespace { -using ScopeSloppyEvalCanExtendVarsField = BitField8; +using ScopeSloppyEvalCanExtendVarsField = base::BitField8; using InnerScopeCallsEvalField = ScopeSloppyEvalCanExtendVarsField::Next; using NeedsPrivateNameContextChainRecalcField = @@ -29,14 +29,14 @@ using NeedsPrivateNameContextChainRecalcField = using ShouldSaveClassVariableIndexField = NeedsPrivateNameContextChainRecalcField::Next; -using VariableMaybeAssignedField = BitField8; +using VariableMaybeAssignedField = base::BitField8; using VariableContextAllocatedField = VariableMaybeAssignedField::Next; -using HasDataField = BitField; +using HasDataField = base::BitField; using LengthEqualsParametersField = HasDataField::Next; using NumberOfParametersField = LengthEqualsParametersField::Next; -using LanguageField = BitField8; +using LanguageField = base::BitField8; using UsesSuperField = LanguageField::Next; STATIC_ASSERT(LanguageModeSize <= LanguageField::kNumValues); diff --git a/src/parsing/preparser.h b/src/parsing/preparser.h index adc3d09cac..291abd0558 100644 --- a/src/parsing/preparser.h +++ b/src/parsing/preparser.h @@ -61,7 +61,7 @@ class PreParserIdentifier { bool IsArguments() const { return type_ == kArgumentsIdentifier; } bool IsEvalOrArguments() const { STATIC_ASSERT(kEvalIdentifier + 1 == kArgumentsIdentifier); - return IsInRange(type_, kEvalIdentifier, kArgumentsIdentifier); + return base::IsInRange(type_, kEvalIdentifier, kArgumentsIdentifier); } bool IsConstructor() const { return type_ == kConstructorIdentifier; } bool IsAwait() const { return type_ == kAwaitIdentifier; } @@ -226,8 +226,8 @@ class PreParserExpression { bool IsPattern() const { STATIC_ASSERT(kObjectLiteralExpression + 1 == kArrayLiteralExpression); - return IsInRange(TypeField::decode(code_), kObjectLiteralExpression, - kArrayLiteralExpression); + return base::IsInRange(TypeField::decode(code_), kObjectLiteralExpression, + kArrayLiteralExpression); } bool IsStringLiteral() const { @@ -345,7 +345,7 @@ class PreParserExpression { : code_(expression_code) {} // The first three bits are for the Type. - using TypeField = BitField; + using TypeField = base::BitField; // The high order bit applies only to nodes which would inherit from the // Expression ASTNode --- This is by necessity, due to the fact that diff --git a/src/parsing/scanner-inl.h b/src/parsing/scanner-inl.h index b76076d92f..ff75997ad6 100644 --- a/src/parsing/scanner-inl.h +++ b/src/parsing/scanner-inl.h @@ -8,6 +8,7 @@ #include "src/parsing/keywords-gen.h" #include "src/parsing/scanner.h" #include "src/strings/char-predicates-inl.h" +#include "src/utils/utils.h" namespace v8 { namespace internal { diff --git a/src/parsing/scanner.cc b/src/parsing/scanner.cc index 28e4374787..70d278556c 100644 --- a/src/parsing/scanner.cc +++ b/src/parsing/scanner.cc @@ -913,7 +913,7 @@ Token::Value Scanner::ScanIdentifierOrKeywordInnerSlow(bool escaped, Vector chars = next().literal_chars.one_byte_literal(); Token::Value token = KeywordOrIdentifierToken(chars.begin(), chars.length()); - if (IsInRange(token, Token::IDENTIFIER, Token::YIELD)) return token; + if (base::IsInRange(token, Token::IDENTIFIER, Token::YIELD)) return token; if (token == Token::FUTURE_STRICT_RESERVED_WORD) { if (escaped) return Token::ESCAPED_STRICT_RESERVED_WORD; @@ -923,7 +923,7 @@ Token::Value Scanner::ScanIdentifierOrKeywordInnerSlow(bool escaped, if (!escaped) return token; STATIC_ASSERT(Token::LET + 1 == Token::STATIC); - if (IsInRange(token, Token::LET, Token::STATIC)) { + if (base::IsInRange(token, Token::LET, Token::STATIC)) { return Token::ESCAPED_STRICT_RESERVED_WORD; } return Token::ESCAPED_KEYWORD; diff --git a/src/parsing/scanner.h b/src/parsing/scanner.h index a7386050d6..4b858a33b6 100644 --- a/src/parsing/scanner.h +++ b/src/parsing/scanner.h @@ -257,7 +257,7 @@ class V8_EXPORT_PRIVATE Scanner { Location() : beg_pos(0), end_pos(0) { } int length() const { return end_pos - beg_pos; } - bool IsValid() const { return IsInRange(beg_pos, 0, end_pos); } + bool IsValid() const { return base::IsInRange(beg_pos, 0, end_pos); } static Location invalid() { return Location(-1, 0); } @@ -447,13 +447,13 @@ class V8_EXPORT_PRIVATE Scanner { return token == Token::PRIVATE_NAME || token == Token::ILLEGAL || token == Token::ESCAPED_KEYWORD || token == Token::UNINITIALIZED || token == Token::REGEXP_LITERAL || - IsInRange(token, Token::NUMBER, Token::STRING) || + base::IsInRange(token, Token::NUMBER, Token::STRING) || Token::IsAnyIdentifier(token) || Token::IsKeyword(token) || - IsInRange(token, Token::TEMPLATE_SPAN, Token::TEMPLATE_TAIL); + base::IsInRange(token, Token::TEMPLATE_SPAN, Token::TEMPLATE_TAIL); } bool CanAccessRawLiteral() const { return token == Token::ILLEGAL || token == Token::UNINITIALIZED || - IsInRange(token, Token::TEMPLATE_SPAN, Token::TEMPLATE_TAIL); + base::IsInRange(token, Token::TEMPLATE_SPAN, Token::TEMPLATE_TAIL); } #endif // DEBUG }; @@ -468,11 +468,11 @@ class V8_EXPORT_PRIVATE Scanner { }; inline bool IsValidBigIntKind(NumberKind kind) { - return IsInRange(kind, BINARY, DECIMAL); + return base::IsInRange(kind, BINARY, DECIMAL); } inline bool IsDecimalNumberKind(NumberKind kind) { - return IsInRange(kind, DECIMAL, DECIMAL_WITH_LEADING_ZERO); + return base::IsInRange(kind, DECIMAL, DECIMAL_WITH_LEADING_ZERO); } static const int kCharacterLookaheadBufferSize = 1; diff --git a/src/parsing/token.h b/src/parsing/token.h index 3f2e0ec870..4749945ebd 100644 --- a/src/parsing/token.h +++ b/src/parsing/token.h @@ -5,9 +5,10 @@ #ifndef V8_PARSING_TOKEN_H_ #define V8_PARSING_TOKEN_H_ +#include "src/base/bit-field.h" +#include "src/base/bounds.h" #include "src/base/logging.h" #include "src/common/globals.h" -#include "src/utils/utils.h" namespace v8 { namespace internal { @@ -217,7 +218,7 @@ class V8_EXPORT_PRIVATE Token { return name_[token]; } - using IsKeywordBits = BitField8; + using IsKeywordBits = base::BitField8; using IsPropertyNameBits = IsKeywordBits::Next; // Predicates @@ -233,81 +234,85 @@ class V8_EXPORT_PRIVATE Token { LanguageMode language_mode, bool is_generator, bool disallow_await) { - if (V8_LIKELY(IsInRange(token, IDENTIFIER, ASYNC))) return true; + if (V8_LIKELY(base::IsInRange(token, IDENTIFIER, ASYNC))) return true; if (token == AWAIT) return !disallow_await; if (token == YIELD) return !is_generator && is_sloppy(language_mode); return IsStrictReservedWord(token) && is_sloppy(language_mode); } static bool IsCallable(Value token) { - return IsInRange(token, SUPER, ESCAPED_STRICT_RESERVED_WORD); + return base::IsInRange(token, SUPER, ESCAPED_STRICT_RESERVED_WORD); } static bool IsAutoSemicolon(Value token) { - return IsInRange(token, SEMICOLON, EOS); + return base::IsInRange(token, SEMICOLON, EOS); } static bool IsAnyIdentifier(Value token) { - return IsInRange(token, IDENTIFIER, ESCAPED_STRICT_RESERVED_WORD); + return base::IsInRange(token, IDENTIFIER, ESCAPED_STRICT_RESERVED_WORD); } static bool IsStrictReservedWord(Value token) { - return IsInRange(token, YIELD, ESCAPED_STRICT_RESERVED_WORD); + return base::IsInRange(token, YIELD, ESCAPED_STRICT_RESERVED_WORD); } static bool IsLiteral(Value token) { - return IsInRange(token, NULL_LITERAL, STRING); + return base::IsInRange(token, NULL_LITERAL, STRING); } static bool IsTemplate(Value token) { - return IsInRange(token, TEMPLATE_SPAN, TEMPLATE_TAIL); + return base::IsInRange(token, TEMPLATE_SPAN, TEMPLATE_TAIL); } static bool IsMember(Value token) { - return IsInRange(token, TEMPLATE_SPAN, LBRACK); + return base::IsInRange(token, TEMPLATE_SPAN, LBRACK); } static bool IsProperty(Value token) { - return IsInRange(token, PERIOD, LBRACK); + return base::IsInRange(token, PERIOD, LBRACK); } static bool IsPropertyOrCall(Value token) { - return IsInRange(token, TEMPLATE_SPAN, LPAREN); + return base::IsInRange(token, TEMPLATE_SPAN, LPAREN); } static bool IsArrowOrAssignmentOp(Value token) { - return IsInRange(token, ARROW, ASSIGN_SUB); + return base::IsInRange(token, ARROW, ASSIGN_SUB); } static bool IsAssignmentOp(Value token) { - return IsInRange(token, INIT, ASSIGN_SUB); + return base::IsInRange(token, INIT, ASSIGN_SUB); } - static bool IsBinaryOp(Value op) { return IsInRange(op, COMMA, SUB); } + static bool IsBinaryOp(Value op) { return base::IsInRange(op, COMMA, SUB); } - static bool IsCompareOp(Value op) { return IsInRange(op, EQ, IN); } + static bool IsCompareOp(Value op) { return base::IsInRange(op, EQ, IN); } static bool IsOrderedRelationalCompareOp(Value op) { - return IsInRange(op, LT, GTE); + return base::IsInRange(op, LT, GTE); } - static bool IsEqualityOp(Value op) { return IsInRange(op, EQ, EQ_STRICT); } + static bool IsEqualityOp(Value op) { + return base::IsInRange(op, EQ, EQ_STRICT); + } static Value BinaryOpForAssignment(Value op) { - DCHECK(IsInRange(op, ASSIGN_BIT_OR, ASSIGN_SUB)); + DCHECK(base::IsInRange(op, ASSIGN_BIT_OR, ASSIGN_SUB)); Value result = static_cast(op - ASSIGN_BIT_OR + BIT_OR); DCHECK(IsBinaryOp(result)); return result; } static bool IsBitOp(Value op) { - return IsInRange(op, BIT_OR, SHR) || op == BIT_NOT; + return base::IsInRange(op, BIT_OR, SHR) || op == BIT_NOT; } - static bool IsUnaryOp(Value op) { return IsInRange(op, ADD, VOID); } - static bool IsCountOp(Value op) { return IsInRange(op, INC, DEC); } - static bool IsUnaryOrCountOp(Value op) { return IsInRange(op, ADD, DEC); } - static bool IsShiftOp(Value op) { return IsInRange(op, SHL, SHR); } + static bool IsUnaryOp(Value op) { return base::IsInRange(op, ADD, VOID); } + static bool IsCountOp(Value op) { return base::IsInRange(op, INC, DEC); } + static bool IsUnaryOrCountOp(Value op) { + return base::IsInRange(op, ADD, DEC); + } + static bool IsShiftOp(Value op) { return base::IsInRange(op, SHL, SHR); } // Returns a string corresponding to the JS token string // (.e., "<" for the token LT) or nullptr if the token doesn't diff --git a/src/profiler/heap-snapshot-generator.h b/src/profiler/heap-snapshot-generator.h index e6c72ffcf9..b094e6d1da 100644 --- a/src/profiler/heap-snapshot-generator.h +++ b/src/profiler/heap-snapshot-generator.h @@ -83,8 +83,8 @@ class HeapGraphEdge { V8_INLINE HeapSnapshot* snapshot() const; int from_index() const { return FromIndexField::decode(bit_field_); } - using TypeField = BitField; - using FromIndexField = BitField; + using TypeField = base::BitField; + using FromIndexField = base::BitField; uint32_t bit_field_; HeapEntry* to_entry_; union { diff --git a/src/profiler/profile-generator.h b/src/profiler/profile-generator.h index 2f7273a086..bccb0fb803 100644 --- a/src/profiler/profile-generator.h +++ b/src/profiler/profile-generator.h @@ -208,12 +208,12 @@ class CodeEntry { V8_EXPORT_PRIVATE static base::LazyDynamicInstance< CodeEntry, RootEntryCreateTrait>::type kRootEntry; - using TagField = BitField; - using BuiltinIdField = BitField; + using TagField = base::BitField; + using BuiltinIdField = base::BitField; static_assert(Builtins::builtin_count <= BuiltinIdField::kNumValues, "builtin_count exceeds size of bitfield"); - using UsedField = BitField; - using SharedCrossOriginField = BitField; + using UsedField = base::BitField; + using SharedCrossOriginField = base::BitField; uint32_t bit_field_; const char* name_; diff --git a/src/runtime/runtime.h b/src/runtime/runtime.h index 0e15898f73..2b2e146fe3 100644 --- a/src/runtime/runtime.h +++ b/src/runtime/runtime.h @@ -8,6 +8,7 @@ #include #include "include/v8.h" +#include "src/base/bit-field.h" #include "src/base/platform/time.h" #include "src/common/globals.h" #include "src/objects/elements-kind.h" @@ -786,11 +787,11 @@ V8_EXPORT_PRIVATE std::ostream& operator<<(std::ostream&, Runtime::FunctionId); //--------------------------------------------------------------------------- // Constants used by interface to runtime functions. -using AllocateDoubleAlignFlag = BitField; +using AllocateDoubleAlignFlag = base::BitField; -using AllowLargeObjectAllocationFlag = BitField; +using AllowLargeObjectAllocationFlag = base::BitField; -using DeclareGlobalsEvalFlag = BitField; +using DeclareGlobalsEvalFlag = base::BitField; // A set of bits returned by Runtime_GetOptimizationStatus. // These bits must be in sync with bits defined in test/mjsunit/mjsunit.js diff --git a/src/snapshot/embedded/embedded-data.h b/src/snapshot/embedded/embedded-data.h index 58905668f2..9da860ab6c 100644 --- a/src/snapshot/embedded/embedded-data.h +++ b/src/snapshot/embedded/embedded-data.h @@ -64,7 +64,7 @@ class EmbeddedData final { uint32_t AddressForHashing(Address addr) { Address start = reinterpret_cast
(data_); - DCHECK(IsInRange(addr, start, start + size_)); + DCHECK(base::IsInRange(addr, start, start + size_)); return static_cast(addr - start); } diff --git a/src/snapshot/references.h b/src/snapshot/references.h index 215db9d9a5..84cf30f980 100644 --- a/src/snapshot/references.h +++ b/src/snapshot/references.h @@ -5,9 +5,9 @@ #ifndef V8_SNAPSHOT_REFERENCES_H_ #define V8_SNAPSHOT_REFERENCES_H_ +#include "src/base/bit-field.h" #include "src/base/hashmap.h" #include "src/common/assert-scope.h" -#include "src/utils/utils.h" namespace v8 { namespace internal { @@ -154,7 +154,7 @@ class SerializerReference { } private: - using SpaceBits = BitField; + using SpaceBits = base::BitField; using ChunkIndexBits = SpaceBits::Next; using SpecialValueTypeBits = SpaceBits::Next; diff --git a/src/snapshot/serializer-common.h b/src/snapshot/serializer-common.h index 2a30fefe33..9f0085a462 100644 --- a/src/snapshot/serializer-common.h +++ b/src/snapshot/serializer-common.h @@ -34,8 +34,8 @@ class ExternalReferenceEncoder { uint32_t index() const { return Index::decode(value_); } private: - using Index = BitField; - using IsFromAPI = BitField; + using Index = base::BitField; + using IsFromAPI = base::BitField; uint32_t value_; }; @@ -266,15 +266,15 @@ class SerializerDeserializer : public RootVisitor { // Encodes repeat count into a fixed repeat bytecode. static int EncodeFixedRepeat(int repeat_count) { - DCHECK(IsInRange(repeat_count, kFirstEncodableRepeatCount, - kLastEncodableFixedRepeatCount)); + DCHECK(base::IsInRange(repeat_count, kFirstEncodableRepeatCount, + kLastEncodableFixedRepeatCount)); return kFixedRepeat + repeat_count - kFirstEncodableRepeatCount; } // Decodes repeat count from a fixed repeat bytecode. static int DecodeFixedRepeatCount(int bytecode) { - DCHECK(IsInRange(bytecode, kFixedRepeat + 0, - kFixedRepeat + kNumberOfFixedRepeat)); + DCHECK(base::IsInRange(bytecode, kFixedRepeat + 0, + kFixedRepeat + kNumberOfFixedRepeat)); return bytecode - kFixedRepeat + kFirstEncodableRepeatCount; } @@ -328,8 +328,8 @@ class SerializedData { uint32_t GetMagicNumber() const { return GetHeaderValue(kMagicNumberOffset); } - using ChunkSizeBits = BitField; - using IsLastChunkBits = BitField; + using ChunkSizeBits = base::BitField; + using IsLastChunkBits = base::BitField; static constexpr uint32_t kMagicNumberOffset = 0; static constexpr uint32_t kMagicNumber = diff --git a/src/strings/char-predicates-inl.h b/src/strings/char-predicates-inl.h index 8ff9f0d21f..bb2cd55d9f 100644 --- a/src/strings/char-predicates-inl.h +++ b/src/strings/char-predicates-inl.h @@ -5,7 +5,9 @@ #ifndef V8_STRINGS_CHAR_PREDICATES_INL_H_ #define V8_STRINGS_CHAR_PREDICATES_INL_H_ +#include "src/base/bounds.h" #include "src/strings/char-predicates.h" +#include "src/utils/utils.h" namespace v8 { namespace internal { @@ -24,26 +26,26 @@ inline constexpr bool IsAsciiIdentifier(uc32 c) { } inline constexpr bool IsAlphaNumeric(uc32 c) { - return IsInRange(AsciiAlphaToLower(c), 'a', 'z') || IsDecimalDigit(c); + return base::IsInRange(AsciiAlphaToLower(c), 'a', 'z') || IsDecimalDigit(c); } inline constexpr bool IsDecimalDigit(uc32 c) { // ECMA-262, 3rd, 7.8.3 (p 16) - return IsInRange(c, '0', '9'); + return base::IsInRange(c, '0', '9'); } inline constexpr bool IsHexDigit(uc32 c) { // ECMA-262, 3rd, 7.6 (p 15) - return IsDecimalDigit(c) || IsInRange(AsciiAlphaToLower(c), 'a', 'f'); + return IsDecimalDigit(c) || base::IsInRange(AsciiAlphaToLower(c), 'a', 'f'); } inline constexpr bool IsOctalDigit(uc32 c) { // ECMA-262, 6th, 7.8.3 - return IsInRange(c, '0', '7'); + return base::IsInRange(c, '0', '7'); } inline constexpr bool IsNonOctalDecimalDigit(uc32 c) { - return IsInRange(c, '8', '9'); + return base::IsInRange(c, '8', '9'); } inline constexpr bool IsBinaryDigit(uc32 c) { @@ -51,9 +53,13 @@ inline constexpr bool IsBinaryDigit(uc32 c) { return c == '0' || c == '1'; } -inline constexpr bool IsAsciiLower(uc32 c) { return IsInRange(c, 'a', 'z'); } +inline constexpr bool IsAsciiLower(uc32 c) { + return base::IsInRange(c, 'a', 'z'); +} -inline constexpr bool IsAsciiUpper(uc32 c) { return IsInRange(c, 'A', 'Z'); } +inline constexpr bool IsAsciiUpper(uc32 c) { + return base::IsInRange(c, 'A', 'Z'); +} inline constexpr uc32 ToAsciiUpper(uc32 c) { return c & ~(IsAsciiLower(c) << 5); @@ -64,7 +70,7 @@ inline constexpr uc32 ToAsciiLower(uc32 c) { } inline constexpr bool IsRegExpWord(uc16 c) { - return IsInRange(AsciiAlphaToLower(c), 'a', 'z') || IsDecimalDigit(c) || + return base::IsInRange(AsciiAlphaToLower(c), 'a', 'z') || IsDecimalDigit(c) || (c == '_'); } @@ -97,28 +103,28 @@ const constexpr uint8_t kAsciiCharFlags[128] = { }; bool IsIdentifierStart(uc32 c) { - if (!IsInRange(c, 0, 127)) return IsIdentifierStartSlow(c); + if (!base::IsInRange(c, 0, 127)) return IsIdentifierStartSlow(c); DCHECK_EQ(IsIdentifierStartSlow(c), static_cast(kAsciiCharFlags[c] & kIsIdentifierStart)); return kAsciiCharFlags[c] & kIsIdentifierStart; } bool IsIdentifierPart(uc32 c) { - if (!IsInRange(c, 0, 127)) return IsIdentifierPartSlow(c); + if (!base::IsInRange(c, 0, 127)) return IsIdentifierPartSlow(c); DCHECK_EQ(IsIdentifierPartSlow(c), static_cast(kAsciiCharFlags[c] & kIsIdentifierPart)); return kAsciiCharFlags[c] & kIsIdentifierPart; } bool IsWhiteSpace(uc32 c) { - if (!IsInRange(c, 0, 127)) return IsWhiteSpaceSlow(c); + if (!base::IsInRange(c, 0, 127)) return IsWhiteSpaceSlow(c); DCHECK_EQ(IsWhiteSpaceSlow(c), static_cast(kAsciiCharFlags[c] & kIsWhiteSpace)); return kAsciiCharFlags[c] & kIsWhiteSpace; } bool IsWhiteSpaceOrLineTerminator(uc32 c) { - if (!IsInRange(c, 0, 127)) return IsWhiteSpaceOrLineTerminatorSlow(c); + if (!base::IsInRange(c, 0, 127)) return IsWhiteSpaceOrLineTerminatorSlow(c); DCHECK_EQ( IsWhiteSpaceOrLineTerminatorSlow(c), static_cast(kAsciiCharFlags[c] & kIsWhiteSpaceOrLineTerminator)); diff --git a/src/strings/string-builder-inl.h b/src/strings/string-builder-inl.h index 9f78884a60..630b66ab20 100644 --- a/src/strings/string-builder-inl.h +++ b/src/strings/string-builder-inl.h @@ -21,10 +21,10 @@ const int kStringBuilderConcatHelperLengthBits = 11; const int kStringBuilderConcatHelperPositionBits = 19; using StringBuilderSubstringLength = - BitField; + base::BitField; using StringBuilderSubstringPosition = - BitField; + base::BitField; template void StringBuilderConcatHelper(String special, sinkchar* sink, diff --git a/src/strings/unicode.h b/src/strings/unicode.h index df77707beb..a050a27dc9 100644 --- a/src/strings/unicode.h +++ b/src/strings/unicode.h @@ -6,9 +6,9 @@ #define V8_STRINGS_UNICODE_H_ #include +#include "src/base/bit-field.h" #include "src/common/globals.h" #include "src/third_party/utf8-decoder/utf8-decoder.h" -#include "src/utils/utils.h" /** * \file * Definitions and convenience functions for working with unicode. @@ -51,8 +51,8 @@ class Predicate { bool value() const { return ValueField::decode(bit_field_); } private: - using CodePointField = v8::internal::BitField; - using ValueField = v8::internal::BitField; + using CodePointField = v8::base::BitField; + using ValueField = v8::base::BitField; uint32_t bit_field_; }; diff --git a/src/utils/utils.h b/src/utils/utils.h index 8ba4e6bef7..869a122b3e 100644 --- a/src/utils/utils.h +++ b/src/utils/utils.h @@ -52,43 +52,6 @@ inline char HexCharOfValue(int value) { return value - 10 + 'A'; } -// Checks if value is in range [lower_limit, higher_limit] using a single -// branch. -template -inline constexpr bool IsInRange(T value, U lower_limit, U higher_limit) { -#if V8_HAS_CXX14_CONSTEXPR - DCHECK_LE(lower_limit, higher_limit); -#endif - STATIC_ASSERT(sizeof(U) <= sizeof(T)); - using unsigned_T = typename std::make_unsigned::type; - // Use static_cast to support enum classes. - return static_cast(static_cast(value) - - static_cast(lower_limit)) <= - static_cast(static_cast(higher_limit) - - static_cast(lower_limit)); -} - -// Checks if [index, index+length) is in range [0, max). Note that this check -// works even if {index+length} would wrap around. -inline constexpr bool IsInBounds(size_t index, size_t length, size_t max) { - return length <= max && index <= (max - length); -} - -// Checks if [index, index+length) is in range [0, max). If not, {length} is -// clamped to its valid range. Note that this check works even if -// {index+length} would wrap around. -template -inline bool ClampToBounds(T index, T* length, T max) { - if (index > max) { - *length = 0; - return false; - } - T avail = max - index; - bool oob = *length > avail; - if (oob) *length = avail; - return !oob; -} - template static T ArithmeticShiftRight(T x, int shift) { DCHECK_LE(0, shift); @@ -213,147 +176,6 @@ T SaturateSub(T a, T b) { return a - b; } -// ---------------------------------------------------------------------------- -// BitField is a help template for encoding and decode bitfield with -// unsigned content. -// Instantiate them via 'using', which is cheaper than deriving a new class: -// using MyBitField = BitField; -// The BitField class is final to enforce this style over derivation. - -template -class BitField final { - public: - STATIC_ASSERT(std::is_unsigned::value); - STATIC_ASSERT(shift < 8 * sizeof(U)); // Otherwise shifts by {shift} are UB. - STATIC_ASSERT(size < 8 * sizeof(U)); // Otherwise shifts by {size} are UB. - STATIC_ASSERT(shift + size <= 8 * sizeof(U)); - STATIC_ASSERT(size > 0); - - using FieldType = T; - - // A type U mask of bit field. To use all bits of a type U of x bits - // in a bitfield without compiler warnings we have to compute 2^x - // without using a shift count of x in the computation. - static constexpr int kShift = shift; - static constexpr int kSize = size; - static constexpr U kMask = ((U{1} << kShift) << kSize) - (U{1} << kShift); - static constexpr int kLastUsedBit = kShift + kSize - 1; - static constexpr U kNumValues = U{1} << kSize; - - // Value for the field with all bits set. - static constexpr T kMax = static_cast(kNumValues - 1); - - template - using Next = BitField; - - // Tells whether the provided value fits into the bit field. - static constexpr bool is_valid(T value) { - return (static_cast(value) & ~static_cast(kMax)) == 0; - } - - // Returns a type U with the bit field value encoded. - static constexpr U encode(T value) { -#if V8_HAS_CXX14_CONSTEXPR - DCHECK(is_valid(value)); -#endif - return static_cast(value) << kShift; - } - - // Returns a type U with the bit field value updated. - static constexpr U update(U previous, T value) { - return (previous & ~kMask) | encode(value); - } - - // Extracts the bit field from the value. - static constexpr T decode(U value) { - return static_cast((value & kMask) >> kShift); - } -}; - -template -using BitField8 = BitField; - -template -using BitField16 = BitField; - -template -using BitField64 = BitField; - -// Helper macros for defining a contiguous sequence of bit fields. Example: -// (backslashes at the ends of respective lines of this multi-line macro -// definition are omitted here to please the compiler) -// -// #define MAP_BIT_FIELD1(V, _) -// V(IsAbcBit, bool, 1, _) -// V(IsBcdBit, bool, 1, _) -// V(CdeBits, int, 5, _) -// V(DefBits, MutableMode, 1, _) -// -// DEFINE_BIT_FIELDS(MAP_BIT_FIELD1) -// or -// DEFINE_BIT_FIELDS_64(MAP_BIT_FIELD1) -// -#define DEFINE_BIT_FIELD_RANGE_TYPE(Name, Type, Size, _) \ - k##Name##Start, k##Name##End = k##Name##Start + Size - 1, - -#define DEFINE_BIT_RANGES(LIST_MACRO) \ - struct LIST_MACRO##_Ranges { \ - enum { LIST_MACRO(DEFINE_BIT_FIELD_RANGE_TYPE, _) kBitsCount }; \ - }; - -#define DEFINE_BIT_FIELD_TYPE(Name, Type, Size, RangesName) \ - using Name = BitField; - -#define DEFINE_BIT_FIELD_64_TYPE(Name, Type, Size, RangesName) \ - using Name = BitField64; - -#define DEFINE_BIT_FIELDS(LIST_MACRO) \ - DEFINE_BIT_RANGES(LIST_MACRO) \ - LIST_MACRO(DEFINE_BIT_FIELD_TYPE, LIST_MACRO##_Ranges) - -#define DEFINE_BIT_FIELDS_64(LIST_MACRO) \ - DEFINE_BIT_RANGES(LIST_MACRO) \ - LIST_MACRO(DEFINE_BIT_FIELD_64_TYPE, LIST_MACRO##_Ranges) - -// ---------------------------------------------------------------------------- -// BitSetComputer is a help template for encoding and decoding information for -// a variable number of items in an array. -// -// To encode boolean data in a smi array you would use: -// using BoolComputer = BitSetComputer; -// -template -class BitSetComputer { - public: - static const int kItemsPerWord = kBitsPerWord / kBitsPerItem; - static const int kMask = (1 << kBitsPerItem) - 1; - - // The number of array elements required to embed T information for each item. - static int word_count(int items) { - if (items == 0) return 0; - return (items - 1) / kItemsPerWord + 1; - } - - // The array index to look at for item. - static int index(int base_index, int item) { - return base_index + item / kItemsPerWord; - } - - // Extract T data for a given item from data. - static T decode(U data, int item) { - return static_cast((data >> shift(item)) & kMask); - } - - // Return the encoding for a store of value for item in previous. - static U encode(U previous, int item, T value) { - int shift_value = shift(item); - int set_bits = (static_cast(value) << shift_value); - return (previous & ~(kMask << shift_value)) | set_bits; - } - - static int shift(int item) { return (item % kItemsPerWord) * kBitsPerItem; } -}; - // Helper macros for defining a contiguous sequence of field offset constants. // Example: (backslashes at the ends of respective lines of this multi-line // macro definition are omitted here to please the compiler) diff --git a/src/wasm/baseline/liftoff-compiler.cc b/src/wasm/baseline/liftoff-compiler.cc index 721060965b..7a28dec74e 100644 --- a/src/wasm/baseline/liftoff-compiler.cc +++ b/src/wasm/baseline/liftoff-compiler.cc @@ -1580,7 +1580,7 @@ class LiftoffCompiler { bool BoundsCheckMem(FullDecoder* decoder, uint32_t access_size, uint32_t offset, Register index, LiftoffRegList pinned) { const bool statically_oob = - !IsInBounds(offset, access_size, env_->max_memory_size); + !base::IsInBounds(offset, access_size, env_->max_memory_size); if (!statically_oob && (FLAG_wasm_no_bounds_checks || env_->use_trap_handler)) { diff --git a/src/wasm/module-compiler.cc b/src/wasm/module-compiler.cc index 14350155d8..30cbd91e54 100644 --- a/src/wasm/module-compiler.cc +++ b/src/wasm/module-compiler.cc @@ -540,9 +540,9 @@ class CompilationStateImpl { ////////////////////////////////////////////////////////////////////////////// // Encoding of fields in the {compilation_progress_} vector. - using RequiredBaselineTierField = BitField8; - using RequiredTopTierField = BitField8; - using ReachedTierField = BitField8; + using RequiredBaselineTierField = base::BitField8; + using RequiredTopTierField = base::BitField8; + using ReachedTierField = base::BitField8; }; CompilationStateImpl* Impl(CompilationState* compilation_state) { diff --git a/src/wasm/module-instantiate.cc b/src/wasm/module-instantiate.cc index eba4f3dd50..bec60378bf 100644 --- a/src/wasm/module-instantiate.cc +++ b/src/wasm/module-instantiate.cc @@ -491,7 +491,7 @@ MaybeHandle InstanceBuilder::Build() { elem_segment.table_index)), isolate_); size_t table_size = table_object->entries().length(); - if (!IsInBounds(base, elem_segment.entries.size(), table_size)) { + if (!base::IsInBounds(base, elem_segment.entries.size(), table_size)) { thrower_->LinkError("table initializer is out of bounds"); return {}; } @@ -503,7 +503,8 @@ MaybeHandle InstanceBuilder::Build() { for (const WasmDataSegment& seg : module_->data_segments) { if (!seg.active) continue; uint32_t base = EvalUint32InitExpr(instance, seg.dest_addr); - if (!IsInBounds(base, seg.source.length(), instance->memory_size())) { + if (!base::IsInBounds(base, seg.source.length(), + instance->memory_size())) { thrower_->LinkError("data segment is out of bounds"); return {}; } @@ -662,8 +663,8 @@ void InstanceBuilder::LoadDataSegments(Handle instance) { if (!segment.active) continue; uint32_t dest_offset = EvalUint32InitExpr(instance, segment.dest_addr); - bool ok = ClampToBounds(dest_offset, &size, - static_cast(instance->memory_size())); + bool ok = base::ClampToBounds( + dest_offset, &size, static_cast(instance->memory_size())); Address dest_addr = reinterpret_cast
(instance->memory_start()) + dest_offset; Address src_addr = reinterpret_cast
(wire_bytes.begin()) + @@ -679,7 +680,7 @@ void InstanceBuilder::LoadDataSegments(Handle instance) { if (size == 0) continue; uint32_t dest_offset = EvalUint32InitExpr(instance, segment.dest_addr); - DCHECK(IsInBounds(dest_offset, size, instance->memory_size())); + DCHECK(base::IsInBounds(dest_offset, size, instance->memory_size())); byte* dest = instance->memory_start() + dest_offset; const byte* src = wire_bytes.begin() + segment.source.offset(); memcpy(dest, src, size); @@ -1633,10 +1634,10 @@ bool LoadElemSegmentImpl(Isolate* isolate, Handle instance, // TODO(wasm): Move this functionality into wasm-objects, since it is used // for both instantiation and in the implementation of the table.init // instruction. - bool ok = - ClampToBounds(dst, &count, table_object->entries().length()); + bool ok = base::ClampToBounds(dst, &count, + table_object->entries().length()); // Use & instead of && so the clamp is not short-circuited. - ok &= ClampToBounds(src, &count, elem_segment.entries.size()); + ok &= base::ClampToBounds(src, &count, elem_segment.entries.size()); const WasmModule* module = instance->module(); for (size_t i = 0; i < count; ++i) { diff --git a/src/wasm/wasm-interpreter.cc b/src/wasm/wasm-interpreter.cc index 51abdfb2a3..06d7b8c0d8 100644 --- a/src/wasm/wasm-interpreter.cc +++ b/src/wasm/wasm-interpreter.cc @@ -1645,8 +1645,8 @@ class ThreadImpl { if (effective_index < index) { return kNullAddress; // wraparound => oob } - if (!IsInBounds(effective_index, sizeof(mtype), - instance_object_->memory_size())) { + if (!base::IsInBounds(effective_index, sizeof(mtype), + instance_object_->memory_size())) { return kNullAddress; // oob } return EffectiveAddress(effective_index); @@ -1654,7 +1654,7 @@ class ThreadImpl { inline bool BoundsCheckMemRange(uint32_t index, uint32_t* size, Address* out_address) { - bool ok = ClampToBounds( + bool ok = base::ClampToBounds( index, size, static_cast(instance_object_->memory_size())); *out_address = EffectiveAddress(index); return ok; @@ -1807,7 +1807,7 @@ class ThreadImpl { auto src_max = instance_object_->data_segment_sizes()[imm.data_segment_index]; // Use & instead of && so the clamp is not short-circuited. - ok &= ClampToBounds(src, &size, src_max); + ok &= base::ClampToBounds(src, &size, src_max); Address src_addr = instance_object_->data_segment_starts()[imm.data_segment_index] + src; diff --git a/src/wasm/wasm-objects.cc b/src/wasm/wasm-objects.cc index d71a8ae5fe..6b8ef550bc 100644 --- a/src/wasm/wasm-objects.cc +++ b/src/wasm/wasm-objects.cc @@ -1444,9 +1444,9 @@ bool WasmInstanceObject::CopyTableEntries(Isolate* isolate, uint32_t max_dst = static_cast(table_dst->entries().length()); uint32_t max_src = static_cast(table_src->entries().length()); bool copy_backward = src < dst; - bool ok = ClampToBounds(dst, &count, max_dst); + bool ok = base::ClampToBounds(dst, &count, max_dst); // Use & instead of && so the clamp is not short-circuited. - ok &= ClampToBounds(src, &count, max_src); + ok &= base::ClampToBounds(src, &count, max_src); // If performing a partial copy when copying backward, then the first access // will be out-of-bounds, so no entries should be copied. diff --git a/src/wasm/wasm-objects.h b/src/wasm/wasm-objects.h index 4038452012..90392cc959 100644 --- a/src/wasm/wasm-objects.h +++ b/src/wasm/wasm-objects.h @@ -7,6 +7,7 @@ #include +#include "src/base/bit-field.h" #include "src/base/bits.h" #include "src/codegen/signature.h" #include "src/debug/debug.h" diff --git a/test/cctest/test-code-stub-assembler.cc b/test/cctest/test-code-stub-assembler.cc index 077cd9eb92..9c568a1260 100644 --- a/test/cctest/test-code-stub-assembler.cc +++ b/test/cctest/test-code-stub-assembler.cc @@ -467,7 +467,7 @@ TEST(DecodeWordFromWord32) { CodeAssemblerTester asm_tester(isolate); CodeStubAssembler m(asm_tester.state()); - using TestBitField = BitField; + using TestBitField = base::BitField; m.Return(m.SmiTag( m.Signed(m.DecodeWordFromWord32(m.Int32Constant(0x2F))))); FunctionTester ft(asm_tester.GenerateCode()); diff --git a/test/cctest/test-conversions.cc b/test/cctest/test-conversions.cc index 2bf07888af..72a604b96a 100644 --- a/test/cctest/test-conversions.cc +++ b/test/cctest/test-conversions.cc @@ -312,10 +312,10 @@ TEST(ExponentNumberStr) { CHECK_EQ(1e-106, StringToDouble(".000001e-100", NO_FLAGS)); } -using OneBit1 = BitField; -using OneBit2 = BitField; -using EightBit1 = BitField; -using EightBit2 = BitField; +using OneBit1 = base::BitField; +using OneBit2 = base::BitField; +using EightBit1 = base::BitField; +using EightBit2 = base::BitField; TEST(BitField) { uint32_t x; @@ -350,8 +350,8 @@ TEST(BitField) { CHECK(!EightBit2::is_valid(256)); } -using UpperBits = BitField64; -using MiddleBits = BitField64; +using UpperBits = base::BitField64; +using MiddleBits = base::BitField64; TEST(BitField64) { uint64_t x; diff --git a/test/cctest/test-utils.cc b/test/cctest/test-utils.cc index 628ed1ba4f..3abab9430d 100644 --- a/test/cctest/test-utils.cc +++ b/test/cctest/test-utils.cc @@ -32,6 +32,7 @@ #include "src/init/v8.h" #include "src/api/api-inl.h" +#include "src/base/bit-field.h" #include "src/base/platform/platform.h" #include "src/numbers/conversions.h" #include "test/cctest/cctest.h" @@ -79,7 +80,7 @@ TEST(Utils1) { TEST(BitSetComputer) { - using BoolComputer = BitSetComputer; + using BoolComputer = base::BitSetComputer; CHECK_EQ(0, BoolComputer::word_count(0)); CHECK_EQ(1, BoolComputer::word_count(8)); CHECK_EQ(2, BoolComputer::word_count(50)); @@ -97,7 +98,7 @@ TEST(BitSetComputer) { // Lets store 2 bits per item with 3000 items and verify the values are // correct. - using TwoBits = BitSetComputer; + using TwoBits = base::BitSetComputer; const int words = 750; CHECK_EQ(words, TwoBits::word_count(3000)); const int offset = 10; diff --git a/test/unittests/utils/utils-unittest.cc b/test/unittests/utils/utils-unittest.cc index 98771da9c9..ecc29b0630 100644 --- a/test/unittests/utils/utils-unittest.cc +++ b/test/unittests/utils/utils-unittest.cc @@ -4,6 +4,7 @@ #include +#include "src/base/bounds.h" #include "src/utils/utils.h" #include "testing/gtest-support.h" @@ -134,8 +135,8 @@ TYPED_TEST(UtilsTest, PassesFilterTest) { TEST(UtilsTest, IsInBounds) { // for column consistency and terseness -#define INB(x, y, z) EXPECT_TRUE(IsInBounds(x, y, z)) -#define OOB(x, y, z) EXPECT_FALSE(IsInBounds(x, y, z)) +#define INB(x, y, z) EXPECT_TRUE(base::IsInBounds(x, y, z)) +#define OOB(x, y, z) EXPECT_FALSE(base::IsInBounds(x, y, z)) INB(0, 0, 1); INB(0, 1, 1); INB(1, 0, 1);