Commit 0700bc1b authored by ishell's avatar ishell Committed by Commit bot

[stubs] Ensure CSA_ASSERT and CSA_SLOW_ASSERT do not produce unused instructions in release mode.

... and make them applicable outside of CSA.

Nice bonus is that the assert condition instructions will now appear inside [Assert / ]Assert brackets.

BUG=

Review-Url: https://codereview.chromium.org/2489743002
Cr-Commit-Position: refs/heads/master@{#40869}
parent abad9b2f
...@@ -2179,14 +2179,14 @@ void Builtins::Generate_ArrayIteratorPrototypeNext( ...@@ -2179,14 +2179,14 @@ void Builtins::Generate_ArrayIteratorPrototypeNext(
assembler->Bind(&if_isfastarray); assembler->Bind(&if_isfastarray);
{ {
assembler->Assert( CSA_ASSERT(assembler,
assembler->Word32Equal(assembler->LoadMapInstanceType(array_map), assembler->Word32Equal(assembler->LoadMapInstanceType(array_map),
assembler->Int32Constant(JS_ARRAY_TYPE))); assembler->Int32Constant(JS_ARRAY_TYPE)));
Node* length = assembler->LoadObjectField(array, JSArray::kLengthOffset); Node* length = assembler->LoadObjectField(array, JSArray::kLengthOffset);
assembler->Assert(assembler->TaggedIsSmi(length)); CSA_ASSERT(assembler, assembler->TaggedIsSmi(length));
assembler->Assert(assembler->TaggedIsSmi(index)); CSA_ASSERT(assembler, assembler->TaggedIsSmi(index));
assembler->GotoUnless(assembler->SmiBelow(index, length), &set_done); assembler->GotoUnless(assembler->SmiBelow(index, length), &set_done);
...@@ -2384,8 +2384,8 @@ void Builtins::Generate_ArrayIteratorPrototypeNext( ...@@ -2384,8 +2384,8 @@ void Builtins::Generate_ArrayIteratorPrototypeNext(
assembler->Bind(&done); assembler->Bind(&done);
length = var_length.value(); length = var_length.value();
} }
assembler->Assert(assembler->TaggedIsSmi(length)); CSA_ASSERT(assembler, assembler->TaggedIsSmi(length));
assembler->Assert(assembler->TaggedIsSmi(index)); CSA_ASSERT(assembler, assembler->TaggedIsSmi(index));
assembler->GotoUnless(assembler->SmiBelow(index, length), &set_done); assembler->GotoUnless(assembler->SmiBelow(index, length), &set_done);
......
...@@ -1602,7 +1602,7 @@ compiler::Node* ReplaceGlobalCallableFastPath( ...@@ -1602,7 +1602,7 @@ compiler::Node* ReplaceGlobalCallableFastPath(
Node* const res_length = a->LoadJSArrayLength(res); Node* const res_length = a->LoadJSArrayLength(res);
Node* const res_elems = a->LoadElements(res); Node* const res_elems = a->LoadElements(res);
a->CSA_ASSERT(a->HasInstanceType(res_elems, FIXED_ARRAY_TYPE)); CSA_ASSERT(a, a->HasInstanceType(res_elems, FIXED_ARRAY_TYPE));
CodeStubAssembler::ParameterMode mode = CodeStubAssembler::INTPTR_PARAMETERS; CodeStubAssembler::ParameterMode mode = CodeStubAssembler::INTPTR_PARAMETERS;
Node* const num_capture_registers = a->LoadFixedArrayElement( Node* const num_capture_registers = a->LoadFixedArrayElement(
...@@ -1677,7 +1677,7 @@ compiler::Node* ReplaceGlobalCallableFastPath( ...@@ -1677,7 +1677,7 @@ compiler::Node* ReplaceGlobalCallableFastPath(
a->Bind(&if_isstring); a->Bind(&if_isstring);
{ {
a->Assert(a->IsStringInstanceType(a->LoadInstanceType(elem))); CSA_ASSERT(a, a->IsStringInstanceType(a->LoadInstanceType(elem)));
Callable call_callable = CodeFactory::Call(isolate); Callable call_callable = CodeFactory::Call(isolate);
Node* const replacement_obj = Node* const replacement_obj =
...@@ -1725,7 +1725,7 @@ compiler::Node* ReplaceGlobalCallableFastPath( ...@@ -1725,7 +1725,7 @@ compiler::Node* ReplaceGlobalCallableFastPath(
// elem must be an Array. // elem must be an Array.
// Use the apply argument as backing for global RegExp properties. // Use the apply argument as backing for global RegExp properties.
a->CSA_ASSERT(a->HasInstanceType(elem, JS_ARRAY_TYPE)); CSA_ASSERT(a, a->HasInstanceType(elem, JS_ARRAY_TYPE));
// TODO(jgruber): Remove indirection through Call->ReflectApply. // TODO(jgruber): Remove indirection through Call->ReflectApply.
Callable call_callable = CodeFactory::Call(isolate); Callable call_callable = CodeFactory::Call(isolate);
......
...@@ -1001,7 +1001,7 @@ void Builtins::Generate_StringPrototypeSubstr(CodeStubAssembler* a) { ...@@ -1001,7 +1001,7 @@ void Builtins::Generate_StringPrototypeSubstr(CodeStubAssembler* a) {
// two cases according to the spec: if it is negative, "" is returned; if // two cases according to the spec: if it is negative, "" is returned; if
// it is positive, then length is set to {string_length} - {start}. // it is positive, then length is set to {string_length} - {start}.
a->Assert(a->WordEqual(a->LoadMap(var_length.value()), CSA_ASSERT(a, a->WordEqual(a->LoadMap(var_length.value()),
a->HeapNumberMapConstant())); a->HeapNumberMapConstant()));
Label if_isnegative(a), if_ispositive(a); Label if_isnegative(a), if_ispositive(a);
...@@ -1071,7 +1071,8 @@ compiler::Node* ToSmiBetweenZeroAnd(CodeStubAssembler* a, ...@@ -1071,7 +1071,8 @@ compiler::Node* ToSmiBetweenZeroAnd(CodeStubAssembler* a,
a->Bind(&if_isnotsmi); a->Bind(&if_isnotsmi);
{ {
// {value} is a heap number - in this case, it is definitely out of bounds. // {value} is a heap number - in this case, it is definitely out of bounds.
a->Assert(a->WordEqual(a->LoadMap(value_int), a->HeapNumberMapConstant())); CSA_ASSERT(a,
a->WordEqual(a->LoadMap(value_int), a->HeapNumberMapConstant()));
Node* const float_zero = a->Float64Constant(0.); Node* const float_zero = a->Float64Constant(0.);
Node* const smi_zero = a->SmiConstant(Smi::kZero); Node* const smi_zero = a->SmiConstant(Smi::kZero);
...@@ -1301,17 +1302,16 @@ compiler::Node* LoadSurrogatePairInternal(CodeStubAssembler* assembler, ...@@ -1301,17 +1302,16 @@ compiler::Node* LoadSurrogatePairInternal(CodeStubAssembler* assembler,
{ {
Node* lead = var_result.value(); Node* lead = var_result.value();
Node* trail = var_trail.value(); Node* trail = var_trail.value();
#ifdef ENABLE_SLOW_DCHECKS
// Check that this path is only taken if a surrogate pair is found // Check that this path is only taken if a surrogate pair is found
assembler->Assert(assembler->Uint32GreaterThanOrEqual( CSA_SLOW_ASSERT(assembler, assembler->Uint32GreaterThanOrEqual(
lead, assembler->Int32Constant(0xD800))); lead, assembler->Int32Constant(0xD800)));
assembler->Assert( CSA_SLOW_ASSERT(assembler, assembler->Uint32LessThan(
assembler->Uint32LessThan(lead, assembler->Int32Constant(0xDC00))); lead, assembler->Int32Constant(0xDC00)));
assembler->Assert(assembler->Uint32GreaterThanOrEqual( CSA_SLOW_ASSERT(assembler, assembler->Uint32GreaterThanOrEqual(
trail, assembler->Int32Constant(0xDC00))); trail, assembler->Int32Constant(0xDC00)));
assembler->Assert( CSA_SLOW_ASSERT(assembler, assembler->Uint32LessThan(
assembler->Uint32LessThan(trail, assembler->Int32Constant(0xE000))); trail, assembler->Int32Constant(0xE000)));
#endif
switch (encoding) { switch (encoding) {
case UnicodeEncoding::UTF16: case UnicodeEncoding::UTF16:
......
...@@ -25,7 +25,7 @@ CodeStubAssembler::CodeStubAssembler(Isolate* isolate, Zone* zone, ...@@ -25,7 +25,7 @@ CodeStubAssembler::CodeStubAssembler(Isolate* isolate, Zone* zone,
const char* name) const char* name)
: compiler::CodeAssembler(isolate, zone, parameter_count, flags, name) {} : compiler::CodeAssembler(isolate, zone, parameter_count, flags, name) {}
void CodeStubAssembler::Assert(Node* condition, const char* message, void CodeStubAssembler::Assert(ConditionBody codition_body, const char* message,
const char* file, int line) { const char* file, int line) {
#if defined(DEBUG) #if defined(DEBUG)
Label ok(this); Label ok(this);
...@@ -33,9 +33,10 @@ void CodeStubAssembler::Assert(Node* condition, const char* message, ...@@ -33,9 +33,10 @@ void CodeStubAssembler::Assert(Node* condition, const char* message,
if (message != nullptr && FLAG_code_comments) { if (message != nullptr && FLAG_code_comments) {
Comment("[ Assert: %s", message); Comment("[ Assert: %s", message);
} else { } else {
Comment("[ Assert "); Comment("[ Assert");
} }
Node* condition = codition_body();
DCHECK_NOT_NULL(condition);
Branch(condition, &ok, &not_ok); Branch(condition, &ok, &not_ok);
Bind(&not_ok); Bind(&not_ok);
if (message != nullptr) { if (message != nullptr) {
...@@ -129,7 +130,7 @@ Node* CodeStubAssembler::IntPtrSubFoldConstants(Node* left, Node* right) { ...@@ -129,7 +130,7 @@ Node* CodeStubAssembler::IntPtrSubFoldConstants(Node* left, Node* right) {
Node* CodeStubAssembler::IntPtrRoundUpToPowerOfTwo32(Node* value) { Node* CodeStubAssembler::IntPtrRoundUpToPowerOfTwo32(Node* value) {
Comment("IntPtrRoundUpToPowerOfTwo32"); Comment("IntPtrRoundUpToPowerOfTwo32");
CSA_ASSERT(UintPtrLessThanOrEqual(value, IntPtrConstant(0x80000000u))); CSA_ASSERT(this, UintPtrLessThanOrEqual(value, IntPtrConstant(0x80000000u)));
value = IntPtrSub(value, IntPtrConstant(1)); value = IntPtrSub(value, IntPtrConstant(1));
for (int i = 1; i <= 16; i *= 2) { for (int i = 1; i <= 16; i *= 2) {
value = WordOr(value, WordShr(value, IntPtrConstant(i))); value = WordOr(value, WordShr(value, IntPtrConstant(i)));
...@@ -1009,7 +1010,7 @@ Node* CodeStubAssembler::LoadElements(Node* object) { ...@@ -1009,7 +1010,7 @@ Node* CodeStubAssembler::LoadElements(Node* object) {
} }
Node* CodeStubAssembler::LoadJSArrayLength(Node* array) { Node* CodeStubAssembler::LoadJSArrayLength(Node* array) {
CSA_ASSERT(IsJSArray(array)); CSA_ASSERT(this, IsJSArray(array));
return LoadObjectField(array, JSArray::kLengthOffset); return LoadObjectField(array, JSArray::kLengthOffset);
} }
...@@ -1022,17 +1023,17 @@ Node* CodeStubAssembler::LoadAndUntagFixedArrayBaseLength(Node* array) { ...@@ -1022,17 +1023,17 @@ Node* CodeStubAssembler::LoadAndUntagFixedArrayBaseLength(Node* array) {
} }
Node* CodeStubAssembler::LoadMapBitField(Node* map) { Node* CodeStubAssembler::LoadMapBitField(Node* map) {
CSA_SLOW_ASSERT(IsMap(map)); CSA_SLOW_ASSERT(this, IsMap(map));
return LoadObjectField(map, Map::kBitFieldOffset, MachineType::Uint8()); return LoadObjectField(map, Map::kBitFieldOffset, MachineType::Uint8());
} }
Node* CodeStubAssembler::LoadMapBitField2(Node* map) { Node* CodeStubAssembler::LoadMapBitField2(Node* map) {
CSA_SLOW_ASSERT(IsMap(map)); CSA_SLOW_ASSERT(this, IsMap(map));
return LoadObjectField(map, Map::kBitField2Offset, MachineType::Uint8()); return LoadObjectField(map, Map::kBitField2Offset, MachineType::Uint8());
} }
Node* CodeStubAssembler::LoadMapBitField3(Node* map) { Node* CodeStubAssembler::LoadMapBitField3(Node* map) {
CSA_SLOW_ASSERT(IsMap(map)); CSA_SLOW_ASSERT(this, IsMap(map));
return LoadObjectField(map, Map::kBitField3Offset, MachineType::Uint32()); return LoadObjectField(map, Map::kBitField3Offset, MachineType::Uint32());
} }
...@@ -1041,24 +1042,24 @@ Node* CodeStubAssembler::LoadMapInstanceType(Node* map) { ...@@ -1041,24 +1042,24 @@ Node* CodeStubAssembler::LoadMapInstanceType(Node* map) {
} }
Node* CodeStubAssembler::LoadMapElementsKind(Node* map) { Node* CodeStubAssembler::LoadMapElementsKind(Node* map) {
CSA_SLOW_ASSERT(IsMap(map)); CSA_SLOW_ASSERT(this, IsMap(map));
Node* bit_field2 = LoadMapBitField2(map); Node* bit_field2 = LoadMapBitField2(map);
return DecodeWord32<Map::ElementsKindBits>(bit_field2); return DecodeWord32<Map::ElementsKindBits>(bit_field2);
} }
Node* CodeStubAssembler::LoadMapDescriptors(Node* map) { Node* CodeStubAssembler::LoadMapDescriptors(Node* map) {
CSA_SLOW_ASSERT(IsMap(map)); CSA_SLOW_ASSERT(this, IsMap(map));
return LoadObjectField(map, Map::kDescriptorsOffset); return LoadObjectField(map, Map::kDescriptorsOffset);
} }
Node* CodeStubAssembler::LoadMapPrototype(Node* map) { Node* CodeStubAssembler::LoadMapPrototype(Node* map) {
CSA_SLOW_ASSERT(IsMap(map)); CSA_SLOW_ASSERT(this, IsMap(map));
return LoadObjectField(map, Map::kPrototypeOffset); return LoadObjectField(map, Map::kPrototypeOffset);
} }
Node* CodeStubAssembler::LoadMapPrototypeInfo(Node* map, Node* CodeStubAssembler::LoadMapPrototypeInfo(Node* map,
Label* if_no_proto_info) { Label* if_no_proto_info) {
CSA_ASSERT(IsMap(map)); CSA_ASSERT(this, IsMap(map));
Node* prototype_info = Node* prototype_info =
LoadObjectField(map, Map::kTransitionsOrPrototypeInfoOffset); LoadObjectField(map, Map::kTransitionsOrPrototypeInfoOffset);
GotoIf(TaggedIsSmi(prototype_info), if_no_proto_info); GotoIf(TaggedIsSmi(prototype_info), if_no_proto_info);
...@@ -1069,16 +1070,17 @@ Node* CodeStubAssembler::LoadMapPrototypeInfo(Node* map, ...@@ -1069,16 +1070,17 @@ Node* CodeStubAssembler::LoadMapPrototypeInfo(Node* map,
} }
Node* CodeStubAssembler::LoadMapInstanceSize(Node* map) { Node* CodeStubAssembler::LoadMapInstanceSize(Node* map) {
CSA_SLOW_ASSERT(IsMap(map)); CSA_SLOW_ASSERT(this, IsMap(map));
return ChangeUint32ToWord( return ChangeUint32ToWord(
LoadObjectField(map, Map::kInstanceSizeOffset, MachineType::Uint8())); LoadObjectField(map, Map::kInstanceSizeOffset, MachineType::Uint8()));
} }
Node* CodeStubAssembler::LoadMapInobjectProperties(Node* map) { Node* CodeStubAssembler::LoadMapInobjectProperties(Node* map) {
CSA_SLOW_ASSERT(IsMap(map)); CSA_SLOW_ASSERT(this, IsMap(map));
// See Map::GetInObjectProperties() for details. // See Map::GetInObjectProperties() for details.
STATIC_ASSERT(LAST_JS_OBJECT_TYPE == LAST_TYPE); STATIC_ASSERT(LAST_JS_OBJECT_TYPE == LAST_TYPE);
CSA_ASSERT(Int32GreaterThanOrEqual(LoadMapInstanceType(map), CSA_ASSERT(this,
Int32GreaterThanOrEqual(LoadMapInstanceType(map),
Int32Constant(FIRST_JS_OBJECT_TYPE))); Int32Constant(FIRST_JS_OBJECT_TYPE)));
return ChangeUint32ToWord(LoadObjectField( return ChangeUint32ToWord(LoadObjectField(
map, Map::kInObjectPropertiesOrConstructorFunctionIndexOffset, map, Map::kInObjectPropertiesOrConstructorFunctionIndexOffset,
...@@ -1086,10 +1088,10 @@ Node* CodeStubAssembler::LoadMapInobjectProperties(Node* map) { ...@@ -1086,10 +1088,10 @@ Node* CodeStubAssembler::LoadMapInobjectProperties(Node* map) {
} }
Node* CodeStubAssembler::LoadMapConstructorFunctionIndex(Node* map) { Node* CodeStubAssembler::LoadMapConstructorFunctionIndex(Node* map) {
CSA_SLOW_ASSERT(IsMap(map)); CSA_SLOW_ASSERT(this, IsMap(map));
// See Map::GetConstructorFunctionIndex() for details. // See Map::GetConstructorFunctionIndex() for details.
STATIC_ASSERT(FIRST_PRIMITIVE_TYPE == FIRST_TYPE); STATIC_ASSERT(FIRST_PRIMITIVE_TYPE == FIRST_TYPE);
CSA_ASSERT(Int32LessThanOrEqual(LoadMapInstanceType(map), CSA_ASSERT(this, Int32LessThanOrEqual(LoadMapInstanceType(map),
Int32Constant(LAST_PRIMITIVE_TYPE))); Int32Constant(LAST_PRIMITIVE_TYPE)));
return ChangeUint32ToWord(LoadObjectField( return ChangeUint32ToWord(LoadObjectField(
map, Map::kInObjectPropertiesOrConstructorFunctionIndexOffset, map, Map::kInObjectPropertiesOrConstructorFunctionIndexOffset,
...@@ -1097,7 +1099,7 @@ Node* CodeStubAssembler::LoadMapConstructorFunctionIndex(Node* map) { ...@@ -1097,7 +1099,7 @@ Node* CodeStubAssembler::LoadMapConstructorFunctionIndex(Node* map) {
} }
Node* CodeStubAssembler::LoadMapConstructor(Node* map) { Node* CodeStubAssembler::LoadMapConstructor(Node* map) {
CSA_SLOW_ASSERT(IsMap(map)); CSA_SLOW_ASSERT(this, IsMap(map));
Variable result(this, MachineRepresentation::kTagged); Variable result(this, MachineRepresentation::kTagged);
result.Bind(LoadObjectField(map, Map::kConstructorOrBackPointerOffset)); result.Bind(LoadObjectField(map, Map::kConstructorOrBackPointerOffset));
...@@ -1118,7 +1120,7 @@ Node* CodeStubAssembler::LoadMapConstructor(Node* map) { ...@@ -1118,7 +1120,7 @@ Node* CodeStubAssembler::LoadMapConstructor(Node* map) {
} }
Node* CodeStubAssembler::LoadNameHashField(Node* name) { Node* CodeStubAssembler::LoadNameHashField(Node* name) {
CSA_ASSERT(IsName(name)); CSA_ASSERT(this, IsName(name));
return LoadObjectField(name, Name::kHashFieldOffset, MachineType::Uint32()); return LoadObjectField(name, Name::kHashFieldOffset, MachineType::Uint32());
} }
...@@ -1134,12 +1136,12 @@ Node* CodeStubAssembler::LoadNameHash(Node* name, Label* if_hash_not_computed) { ...@@ -1134,12 +1136,12 @@ Node* CodeStubAssembler::LoadNameHash(Node* name, Label* if_hash_not_computed) {
} }
Node* CodeStubAssembler::LoadStringLength(Node* object) { Node* CodeStubAssembler::LoadStringLength(Node* object) {
CSA_ASSERT(IsString(object)); CSA_ASSERT(this, IsString(object));
return LoadObjectField(object, String::kLengthOffset); return LoadObjectField(object, String::kLengthOffset);
} }
Node* CodeStubAssembler::LoadJSValueValue(Node* object) { Node* CodeStubAssembler::LoadJSValueValue(Node* object) {
CSA_ASSERT(IsJSValue(object)); CSA_ASSERT(this, IsJSValue(object));
return LoadObjectField(object, JSValue::kValueOffset); return LoadObjectField(object, JSValue::kValueOffset);
} }
...@@ -1149,7 +1151,7 @@ Node* CodeStubAssembler::LoadWeakCellValueUnchecked(Node* weak_cell) { ...@@ -1149,7 +1151,7 @@ Node* CodeStubAssembler::LoadWeakCellValueUnchecked(Node* weak_cell) {
} }
Node* CodeStubAssembler::LoadWeakCellValue(Node* weak_cell, Label* if_cleared) { Node* CodeStubAssembler::LoadWeakCellValue(Node* weak_cell, Label* if_cleared) {
CSA_ASSERT(IsWeakCell(weak_cell)); CSA_ASSERT(this, IsWeakCell(weak_cell));
Node* value = LoadWeakCellValueUnchecked(weak_cell); Node* value = LoadWeakCellValueUnchecked(weak_cell);
if (if_cleared != nullptr) { if (if_cleared != nullptr) {
GotoIf(WordEqual(value, IntPtrConstant(0)), if_cleared); GotoIf(WordEqual(value, IntPtrConstant(0)), if_cleared);
...@@ -1227,7 +1229,7 @@ Node* CodeStubAssembler::LoadAndUntagToWord32FixedArrayElement( ...@@ -1227,7 +1229,7 @@ Node* CodeStubAssembler::LoadAndUntagToWord32FixedArrayElement(
Node* CodeStubAssembler::LoadFixedDoubleArrayElement( Node* CodeStubAssembler::LoadFixedDoubleArrayElement(
Node* object, Node* index_node, MachineType machine_type, Node* object, Node* index_node, MachineType machine_type,
int additional_offset, ParameterMode parameter_mode, Label* if_hole) { int additional_offset, ParameterMode parameter_mode, Label* if_hole) {
CSA_ASSERT(IsFixedDoubleArray(object)); CSA_ASSERT(this, IsFixedDoubleArray(object));
int32_t header_size = int32_t header_size =
FixedDoubleArray::kHeaderSize + additional_offset - kHeapObjectTag; FixedDoubleArray::kHeaderSize + additional_offset - kHeapObjectTag;
Node* offset = ElementOffsetFromIndex(index_node, FAST_HOLEY_DOUBLE_ELEMENTS, Node* offset = ElementOffsetFromIndex(index_node, FAST_HOLEY_DOUBLE_ELEMENTS,
...@@ -1293,7 +1295,7 @@ Node* CodeStubAssembler::LoadNativeContext(Node* context) { ...@@ -1293,7 +1295,7 @@ Node* CodeStubAssembler::LoadNativeContext(Node* context) {
Node* CodeStubAssembler::LoadJSArrayElementsMap(ElementsKind kind, Node* CodeStubAssembler::LoadJSArrayElementsMap(ElementsKind kind,
Node* native_context) { Node* native_context) {
CSA_ASSERT(IsNativeContext(native_context)); CSA_ASSERT(this, IsNativeContext(native_context));
return LoadFixedArrayElement(native_context, return LoadFixedArrayElement(native_context,
IntPtrConstant(Context::ArrayMapIndex(kind))); IntPtrConstant(Context::ArrayMapIndex(kind)));
} }
...@@ -1369,7 +1371,7 @@ Node* CodeStubAssembler::StoreFixedArrayElement(Node* object, Node* index_node, ...@@ -1369,7 +1371,7 @@ Node* CodeStubAssembler::StoreFixedArrayElement(Node* object, Node* index_node,
Node* CodeStubAssembler::StoreFixedDoubleArrayElement( Node* CodeStubAssembler::StoreFixedDoubleArrayElement(
Node* object, Node* index_node, Node* value, ParameterMode parameter_mode) { Node* object, Node* index_node, Node* value, ParameterMode parameter_mode) {
CSA_ASSERT(IsFixedDoubleArray(object)); CSA_ASSERT(this, IsFixedDoubleArray(object));
Node* offset = Node* offset =
ElementOffsetFromIndex(index_node, FAST_DOUBLE_ELEMENTS, parameter_mode, ElementOffsetFromIndex(index_node, FAST_DOUBLE_ELEMENTS, parameter_mode,
FixedArray::kHeaderSize - kHeapObjectTag); FixedArray::kHeaderSize - kHeapObjectTag);
...@@ -1517,7 +1519,7 @@ Node* CodeStubAssembler::AllocateSeqTwoByteString(Node* context, Node* length, ...@@ -1517,7 +1519,7 @@ Node* CodeStubAssembler::AllocateSeqTwoByteString(Node* context, Node* length,
Node* CodeStubAssembler::AllocateSlicedString( Node* CodeStubAssembler::AllocateSlicedString(
Heap::RootListIndex map_root_index, Node* length, Node* parent, Heap::RootListIndex map_root_index, Node* length, Node* parent,
Node* offset) { Node* offset) {
CSA_ASSERT(TaggedIsSmi(length)); CSA_ASSERT(this, TaggedIsSmi(length));
Node* result = Allocate(SlicedString::kSize); Node* result = Allocate(SlicedString::kSize);
Node* map = LoadRoot(map_root_index); Node* map = LoadRoot(map_root_index);
DCHECK(Heap::RootIsImmortalImmovable(map_root_index)); DCHECK(Heap::RootIsImmortalImmovable(map_root_index));
...@@ -1550,7 +1552,7 @@ Node* CodeStubAssembler::AllocateConsString(Heap::RootListIndex map_root_index, ...@@ -1550,7 +1552,7 @@ Node* CodeStubAssembler::AllocateConsString(Heap::RootListIndex map_root_index,
Node* length, Node* first, Node* length, Node* first,
Node* second, Node* second,
AllocationFlags flags) { AllocationFlags flags) {
CSA_ASSERT(TaggedIsSmi(length)); CSA_ASSERT(this, TaggedIsSmi(length));
Node* result = Allocate(ConsString::kSize, flags); Node* result = Allocate(ConsString::kSize, flags);
Node* map = LoadRoot(map_root_index); Node* map = LoadRoot(map_root_index);
DCHECK(Heap::RootIsImmortalImmovable(map_root_index)); DCHECK(Heap::RootIsImmortalImmovable(map_root_index));
...@@ -1589,7 +1591,7 @@ Node* CodeStubAssembler::AllocateTwoByteConsString(Node* length, Node* first, ...@@ -1589,7 +1591,7 @@ Node* CodeStubAssembler::AllocateTwoByteConsString(Node* length, Node* first,
Node* CodeStubAssembler::NewConsString(Node* context, Node* length, Node* left, Node* CodeStubAssembler::NewConsString(Node* context, Node* length, Node* left,
Node* right, AllocationFlags flags) { Node* right, AllocationFlags flags) {
CSA_ASSERT(TaggedIsSmi(length)); CSA_ASSERT(this, TaggedIsSmi(length));
// Added string can be a cons string. // Added string can be a cons string.
Comment("Allocating ConsString"); Comment("Allocating ConsString");
Node* left_instance_type = LoadInstanceType(left); Node* left_instance_type = LoadInstanceType(left);
...@@ -1644,7 +1646,8 @@ Node* CodeStubAssembler::AllocateRegExpResult(Node* context, Node* length, ...@@ -1644,7 +1646,8 @@ Node* CodeStubAssembler::AllocateRegExpResult(Node* context, Node* length,
Node* index, Node* input) { Node* index, Node* input) {
Node* const max_length = Node* const max_length =
SmiConstant(Smi::FromInt(JSArray::kInitialMaxFastElementArray)); SmiConstant(Smi::FromInt(JSArray::kInitialMaxFastElementArray));
CSA_ASSERT(SmiLessThanOrEqual(length, max_length)); CSA_ASSERT(this, SmiLessThanOrEqual(length, max_length));
USE(max_length);
// Allocate the JSRegExpResult. // Allocate the JSRegExpResult.
// TODO(jgruber): Fold JSArray and FixedArray allocations, then remove // TODO(jgruber): Fold JSArray and FixedArray allocations, then remove
...@@ -1689,11 +1692,12 @@ Node* CodeStubAssembler::AllocateNameDictionary(int at_least_space_for) { ...@@ -1689,11 +1692,12 @@ Node* CodeStubAssembler::AllocateNameDictionary(int at_least_space_for) {
} }
Node* CodeStubAssembler::AllocateNameDictionary(Node* at_least_space_for) { Node* CodeStubAssembler::AllocateNameDictionary(Node* at_least_space_for) {
CSA_ASSERT(UintPtrLessThanOrEqual( CSA_ASSERT(this, UintPtrLessThanOrEqual(
at_least_space_for, IntPtrConstant(NameDictionary::kMaxCapacity))); at_least_space_for,
IntPtrConstant(NameDictionary::kMaxCapacity)));
Node* capacity = HashTableComputeCapacity(at_least_space_for); Node* capacity = HashTableComputeCapacity(at_least_space_for);
CSA_ASSERT(WordIsPowerOfTwo(capacity)); CSA_ASSERT(this, WordIsPowerOfTwo(capacity));
Node* length = EntryToIndex<NameDictionary>(capacity); Node* length = EntryToIndex<NameDictionary>(capacity);
Node* store_size = Node* store_size =
...@@ -1738,10 +1742,10 @@ Node* CodeStubAssembler::AllocateNameDictionary(Node* at_least_space_for) { ...@@ -1738,10 +1742,10 @@ Node* CodeStubAssembler::AllocateNameDictionary(Node* at_least_space_for) {
Node* CodeStubAssembler::AllocateJSObjectFromMap(Node* map, Node* properties, Node* CodeStubAssembler::AllocateJSObjectFromMap(Node* map, Node* properties,
Node* elements) { Node* elements) {
CSA_ASSERT(IsMap(map)); CSA_ASSERT(this, IsMap(map));
Node* size = Node* size =
IntPtrMul(LoadMapInstanceSize(map), IntPtrConstant(kPointerSize)); IntPtrMul(LoadMapInstanceSize(map), IntPtrConstant(kPointerSize));
CSA_ASSERT(IsRegularHeapObjectSize(size)); CSA_ASSERT(this, IsRegularHeapObjectSize(size));
Node* object = Allocate(size); Node* object = Allocate(size);
StoreMapNoWriteBarrier(object, map); StoreMapNoWriteBarrier(object, map);
InitializeJSObjectFromMap(object, map, size, properties, elements); InitializeJSObjectFromMap(object, map, size, properties, elements);
...@@ -1754,7 +1758,7 @@ void CodeStubAssembler::InitializeJSObjectFromMap(Node* object, Node* map, ...@@ -1754,7 +1758,7 @@ void CodeStubAssembler::InitializeJSObjectFromMap(Node* object, Node* map,
// This helper assumes that the object is in new-space, as guarded by the // This helper assumes that the object is in new-space, as guarded by the
// check in AllocatedJSObjectFromMap. // check in AllocatedJSObjectFromMap.
if (properties == nullptr) { if (properties == nullptr) {
CSA_ASSERT(Word32BinaryNot(IsDictionaryMap((map)))); CSA_ASSERT(this, Word32BinaryNot(IsDictionaryMap((map))));
StoreObjectFieldRoot(object, JSObject::kPropertiesOffset, StoreObjectFieldRoot(object, JSObject::kPropertiesOffset,
Heap::kEmptyFixedArrayRootIndex); Heap::kEmptyFixedArrayRootIndex);
} else { } else {
...@@ -1787,8 +1791,8 @@ void CodeStubAssembler::StoreFieldsNoWriteBarrier(Node* start_address, ...@@ -1787,8 +1791,8 @@ void CodeStubAssembler::StoreFieldsNoWriteBarrier(Node* start_address,
Node* end_address, Node* end_address,
Node* value) { Node* value) {
Comment("StoreFieldsNoWriteBarrier"); Comment("StoreFieldsNoWriteBarrier");
CSA_ASSERT(WordIsWordAligned(start_address)); CSA_ASSERT(this, WordIsWordAligned(start_address));
CSA_ASSERT(WordIsWordAligned(end_address)); CSA_ASSERT(this, WordIsWordAligned(end_address));
BuildFastLoop( BuildFastLoop(
MachineType::PointerRepresentation(), start_address, end_address, MachineType::PointerRepresentation(), start_address, end_address,
[value](CodeStubAssembler* a, Node* current) { [value](CodeStubAssembler* a, Node* current) {
...@@ -1890,7 +1894,8 @@ Node* CodeStubAssembler::AllocateFixedArray(ElementsKind kind, ...@@ -1890,7 +1894,8 @@ Node* CodeStubAssembler::AllocateFixedArray(ElementsKind kind,
Node* capacity_node, Node* capacity_node,
ParameterMode mode, ParameterMode mode,
AllocationFlags flags) { AllocationFlags flags) {
CSA_ASSERT(IntPtrGreaterThan(capacity_node, IntPtrOrSmiConstant(0, mode))); CSA_ASSERT(this,
IntPtrGreaterThan(capacity_node, IntPtrOrSmiConstant(0, mode)));
Node* total_size = GetFixedArrayAllocationSize(capacity_node, kind, mode); Node* total_size = GetFixedArrayAllocationSize(capacity_node, kind, mode);
// Allocate both array and elements object, and initialize the JSArray. // Allocate both array and elements object, and initialize the JSArray.
...@@ -2658,24 +2663,24 @@ Node* CodeStubAssembler::ThrowIfNotInstanceType(Node* context, Node* value, ...@@ -2658,24 +2663,24 @@ Node* CodeStubAssembler::ThrowIfNotInstanceType(Node* context, Node* value,
Node* CodeStubAssembler::IsSpecialReceiverMap(Node* map) { Node* CodeStubAssembler::IsSpecialReceiverMap(Node* map) {
Node* is_special = IsSpecialReceiverInstanceType(LoadMapInstanceType(map)); Node* is_special = IsSpecialReceiverInstanceType(LoadMapInstanceType(map));
Node* bit_field = LoadMapBitField(map);
uint32_t mask = uint32_t mask =
1 << Map::kHasNamedInterceptor | 1 << Map::kIsAccessCheckNeeded; 1 << Map::kHasNamedInterceptor | 1 << Map::kIsAccessCheckNeeded;
USE(mask);
// Interceptors or access checks imply special receiver. // Interceptors or access checks imply special receiver.
CSA_ASSERT( CSA_ASSERT(this, Select(IsSetWord32(LoadMapBitField(map), mask), is_special,
Select(IsSetWord32(bit_field, mask), is_special, Int32Constant(1))); Int32Constant(1), MachineRepresentation::kWord32));
return is_special; return is_special;
} }
Node* CodeStubAssembler::IsDictionaryMap(Node* map) { Node* CodeStubAssembler::IsDictionaryMap(Node* map) {
CSA_SLOW_ASSERT(IsMap(map)); CSA_SLOW_ASSERT(this, IsMap(map));
Node* bit_field3 = LoadMapBitField3(map); Node* bit_field3 = LoadMapBitField3(map);
return Word32NotEqual(IsSetWord32<Map::DictionaryMap>(bit_field3), return Word32NotEqual(IsSetWord32<Map::DictionaryMap>(bit_field3),
Int32Constant(0)); Int32Constant(0));
} }
Node* CodeStubAssembler::IsCallableMap(Node* map) { Node* CodeStubAssembler::IsCallableMap(Node* map) {
CSA_ASSERT(IsMap(map)); CSA_ASSERT(this, IsMap(map));
return Word32NotEqual( return Word32NotEqual(
Word32And(LoadMapBitField(map), Int32Constant(1 << Map::kIsCallable)), Word32And(LoadMapBitField(map), Int32Constant(1 << Map::kIsCallable)),
Int32Constant(0)); Int32Constant(0));
...@@ -2762,7 +2767,7 @@ Node* CodeStubAssembler::IsUnseededNumberDictionary(Node* object) { ...@@ -2762,7 +2767,7 @@ Node* CodeStubAssembler::IsUnseededNumberDictionary(Node* object) {
} }
Node* CodeStubAssembler::StringCharCodeAt(Node* string, Node* index) { Node* CodeStubAssembler::StringCharCodeAt(Node* string, Node* index) {
CSA_ASSERT(IsString(string)); CSA_ASSERT(this, IsString(string));
// Translate the {index} into a Word. // Translate the {index} into a Word.
index = SmiToWord(index); index = SmiToWord(index);
...@@ -3294,8 +3299,8 @@ Node* CodeStubAssembler::StringAdd(Node* context, Node* left, Node* right, ...@@ -3294,8 +3299,8 @@ Node* CodeStubAssembler::StringAdd(Node* context, Node* left, Node* right,
Goto(&done_native); Goto(&done_native);
Bind(&cons); Bind(&cons);
CSA_ASSERT(TaggedIsSmi(left_length)); CSA_ASSERT(this, TaggedIsSmi(left_length));
CSA_ASSERT(TaggedIsSmi(right_length)); CSA_ASSERT(this, TaggedIsSmi(right_length));
Node* new_length = SmiAdd(left_length, right_length); Node* new_length = SmiAdd(left_length, right_length);
GotoIf(UintPtrGreaterThanOrEqual( GotoIf(UintPtrGreaterThanOrEqual(
new_length, SmiConstant(Smi::FromInt(String::kMaxLength))), new_length, SmiConstant(Smi::FromInt(String::kMaxLength))),
...@@ -3379,7 +3384,7 @@ Node* CodeStubAssembler::StringAdd(Node* context, Node* left, Node* right, ...@@ -3379,7 +3384,7 @@ Node* CodeStubAssembler::StringAdd(Node* context, Node* left, Node* right,
Node* CodeStubAssembler::StringIndexOfChar(Node* context, Node* string, Node* CodeStubAssembler::StringIndexOfChar(Node* context, Node* string,
Node* needle_char, Node* from) { Node* needle_char, Node* from) {
CSA_ASSERT(IsString(string)); CSA_ASSERT(this, IsString(string));
Variable var_result(this, MachineRepresentation::kTagged); Variable var_result(this, MachineRepresentation::kTagged);
Label out(this), runtime(this, Label::kDeferred); Label out(this), runtime(this, Label::kDeferred);
...@@ -3651,8 +3656,8 @@ Node* CodeStubAssembler::ToName(Node* context, Node* value) { ...@@ -3651,8 +3656,8 @@ Node* CodeStubAssembler::ToName(Node* context, Node* value) {
Node* CodeStubAssembler::NonNumberToNumber(Node* context, Node* input) { Node* CodeStubAssembler::NonNumberToNumber(Node* context, Node* input) {
// Assert input is a HeapObject (not smi or heap number) // Assert input is a HeapObject (not smi or heap number)
CSA_ASSERT(Word32BinaryNot(TaggedIsSmi(input))); CSA_ASSERT(this, Word32BinaryNot(TaggedIsSmi(input)));
CSA_ASSERT(Word32NotEqual(LoadMap(input), HeapNumberMapConstant())); CSA_ASSERT(this, Word32NotEqual(LoadMap(input), HeapNumberMapConstant()));
// We might need to loop once here due to ToPrimitive conversions. // We might need to loop once here due to ToPrimitive conversions.
Variable var_input(this, MachineRepresentation::kTagged); Variable var_input(this, MachineRepresentation::kTagged);
...@@ -3809,7 +3814,7 @@ Node* CodeStubAssembler::ToString(Node* context, Node* input) { ...@@ -3809,7 +3814,7 @@ Node* CodeStubAssembler::ToString(Node* context, Node* input) {
} }
Node* CodeStubAssembler::FlattenString(Node* string) { Node* CodeStubAssembler::FlattenString(Node* string) {
CSA_ASSERT(IsString(string)); CSA_ASSERT(this, IsString(string));
Variable var_result(this, MachineRepresentation::kTagged); Variable var_result(this, MachineRepresentation::kTagged);
var_result.Bind(string); var_result.Bind(string);
...@@ -4043,7 +4048,7 @@ void CodeStubAssembler::NameDictionaryLookup(Node* dictionary, ...@@ -4043,7 +4048,7 @@ void CodeStubAssembler::NameDictionaryLookup(Node* dictionary,
Variable* var_name_index, Variable* var_name_index,
Label* if_not_found, Label* if_not_found,
int inlined_probes) { int inlined_probes) {
CSA_ASSERT(IsDictionary(dictionary)); CSA_ASSERT(this, IsDictionary(dictionary));
DCHECK_EQ(MachineType::PointerRepresentation(), var_name_index->rep()); DCHECK_EQ(MachineType::PointerRepresentation(), var_name_index->rep());
Comment("NameDictionaryLookup"); Comment("NameDictionaryLookup");
...@@ -4128,7 +4133,7 @@ void CodeStubAssembler::NumberDictionaryLookup(Node* dictionary, ...@@ -4128,7 +4133,7 @@ void CodeStubAssembler::NumberDictionaryLookup(Node* dictionary,
Label* if_found, Label* if_found,
Variable* var_entry, Variable* var_entry,
Label* if_not_found) { Label* if_not_found) {
CSA_ASSERT(IsDictionary(dictionary)); CSA_ASSERT(this, IsDictionary(dictionary));
DCHECK_EQ(MachineType::PointerRepresentation(), var_entry->rep()); DCHECK_EQ(MachineType::PointerRepresentation(), var_entry->rep());
Comment("NumberDictionaryLookup"); Comment("NumberDictionaryLookup");
...@@ -4235,10 +4240,10 @@ void CodeStubAssembler::TryLookupProperty( ...@@ -4235,10 +4240,10 @@ void CodeStubAssembler::TryLookupProperty(
Int32Constant(LAST_SPECIAL_RECEIVER_TYPE)), Int32Constant(LAST_SPECIAL_RECEIVER_TYPE)),
&if_objectisspecial); &if_objectisspecial);
Node* bit_field = LoadMapBitField(map); uint32_t mask =
Node* mask = Int32Constant(1 << Map::kHasNamedInterceptor | 1 << Map::kHasNamedInterceptor | 1 << Map::kIsAccessCheckNeeded;
1 << Map::kIsAccessCheckNeeded); CSA_ASSERT(this, Word32BinaryNot(IsSetWord32(LoadMapBitField(map), mask)));
CSA_ASSERT(Word32Equal(Word32And(bit_field, mask), Int32Constant(0))); USE(mask);
Node* bit_field3 = LoadMapBitField3(map); Node* bit_field3 = LoadMapBitField3(map);
Label if_isfastmap(this), if_isslowmap(this); Label if_isfastmap(this), if_isslowmap(this);
...@@ -4431,7 +4436,7 @@ void CodeStubAssembler::LoadPropertyFromNameDictionary(Node* dictionary, ...@@ -4431,7 +4436,7 @@ void CodeStubAssembler::LoadPropertyFromNameDictionary(Node* dictionary,
Variable* var_details, Variable* var_details,
Variable* var_value) { Variable* var_value) {
Comment("LoadPropertyFromNameDictionary"); Comment("LoadPropertyFromNameDictionary");
CSA_ASSERT(IsDictionary(dictionary)); CSA_ASSERT(this, IsDictionary(dictionary));
const int name_to_details_offset = const int name_to_details_offset =
(NameDictionary::kEntryDetailsIndex - NameDictionary::kEntryKeyIndex) * (NameDictionary::kEntryDetailsIndex - NameDictionary::kEntryKeyIndex) *
kPointerSize; kPointerSize;
...@@ -4455,7 +4460,7 @@ void CodeStubAssembler::LoadPropertyFromGlobalDictionary(Node* dictionary, ...@@ -4455,7 +4460,7 @@ void CodeStubAssembler::LoadPropertyFromGlobalDictionary(Node* dictionary,
Variable* var_value, Variable* var_value,
Label* if_deleted) { Label* if_deleted) {
Comment("[ LoadPropertyFromGlobalDictionary"); Comment("[ LoadPropertyFromGlobalDictionary");
CSA_ASSERT(IsDictionary(dictionary)); CSA_ASSERT(this, IsDictionary(dictionary));
const int name_to_value_offset = const int name_to_value_offset =
(GlobalDictionary::kEntryValueIndex - GlobalDictionary::kEntryKeyIndex) * (GlobalDictionary::kEntryValueIndex - GlobalDictionary::kEntryKeyIndex) *
...@@ -4495,7 +4500,7 @@ Node* CodeStubAssembler::CallGetterIfAccessor(Node* value, Node* details, ...@@ -4495,7 +4500,7 @@ Node* CodeStubAssembler::CallGetterIfAccessor(Node* value, Node* details,
GotoIf(Word32Equal(LoadInstanceType(accessor_pair), GotoIf(Word32Equal(LoadInstanceType(accessor_pair),
Int32Constant(ACCESSOR_INFO_TYPE)), Int32Constant(ACCESSOR_INFO_TYPE)),
if_bailout); if_bailout);
CSA_ASSERT(HasInstanceType(accessor_pair, ACCESSOR_PAIR_TYPE)); CSA_ASSERT(this, HasInstanceType(accessor_pair, ACCESSOR_PAIR_TYPE));
Node* getter = LoadObjectField(accessor_pair, AccessorPair::kGetterOffset); Node* getter = LoadObjectField(accessor_pair, AccessorPair::kGetterOffset);
Node* getter_map = LoadMap(getter); Node* getter_map = LoadMap(getter);
Node* instance_type = LoadMapInstanceType(getter_map); Node* instance_type = LoadMapInstanceType(getter_map);
...@@ -4650,18 +4655,18 @@ void CodeStubAssembler::TryLookupElement(Node* object, Node* map, ...@@ -4650,18 +4655,18 @@ void CodeStubAssembler::TryLookupElement(Node* object, Node* map,
} }
Bind(&if_isfaststringwrapper); Bind(&if_isfaststringwrapper);
{ {
CSA_ASSERT(HasInstanceType(object, JS_VALUE_TYPE)); CSA_ASSERT(this, HasInstanceType(object, JS_VALUE_TYPE));
Node* string = LoadJSValueValue(object); Node* string = LoadJSValueValue(object);
CSA_ASSERT(IsStringInstanceType(LoadInstanceType(string))); CSA_ASSERT(this, IsStringInstanceType(LoadInstanceType(string)));
Node* length = LoadStringLength(string); Node* length = LoadStringLength(string);
GotoIf(UintPtrLessThan(intptr_index, SmiUntag(length)), if_found); GotoIf(UintPtrLessThan(intptr_index, SmiUntag(length)), if_found);
Goto(&if_isobjectorsmi); Goto(&if_isobjectorsmi);
} }
Bind(&if_isslowstringwrapper); Bind(&if_isslowstringwrapper);
{ {
CSA_ASSERT(HasInstanceType(object, JS_VALUE_TYPE)); CSA_ASSERT(this, HasInstanceType(object, JS_VALUE_TYPE));
Node* string = LoadJSValueValue(object); Node* string = LoadJSValueValue(object);
CSA_ASSERT(IsStringInstanceType(LoadInstanceType(string))); CSA_ASSERT(this, IsStringInstanceType(LoadInstanceType(string)));
Node* length = LoadStringLength(string); Node* length = LoadStringLength(string);
GotoIf(UintPtrLessThan(intptr_index, SmiUntag(length)), if_found); GotoIf(UintPtrLessThan(intptr_index, SmiUntag(length)), if_found);
Goto(&if_isdictionary); Goto(&if_isdictionary);
...@@ -5134,8 +5139,9 @@ compiler::Node* CodeStubAssembler::StubCachePrimaryOffset(compiler::Node* name, ...@@ -5134,8 +5139,9 @@ compiler::Node* CodeStubAssembler::StubCachePrimaryOffset(compiler::Node* name,
STATIC_ASSERT(StubCache::kCacheIndexShift == Name::kHashShift); STATIC_ASSERT(StubCache::kCacheIndexShift == Name::kHashShift);
// Compute the hash of the name (use entire hash field). // Compute the hash of the name (use entire hash field).
Node* hash_field = LoadNameHashField(name); Node* hash_field = LoadNameHashField(name);
CSA_ASSERT(Word32Equal( CSA_ASSERT(this,
Word32And(hash_field, Int32Constant(Name::kHashNotComputedMask)), Word32Equal(Word32And(hash_field,
Int32Constant(Name::kHashNotComputedMask)),
Int32Constant(0))); Int32Constant(0)));
// Using only the low bits in 64-bit mode is unlikely to increase the // Using only the low bits in 64-bit mode is unlikely to increase the
...@@ -5612,8 +5618,9 @@ void CodeStubAssembler::HandleLoadICHandlerCase( ...@@ -5612,8 +5618,9 @@ void CodeStubAssembler::HandleLoadICHandlerCase(
Node* descriptor = Node* descriptor =
DecodeWord<LoadHandler::DescriptorValueIndexBits>(handler_word); DecodeWord<LoadHandler::DescriptorValueIndexBits>(handler_word);
#if defined(DEBUG) #if defined(DEBUG)
CSA_ASSERT(UintPtrLessThan( CSA_ASSERT(
descriptor, LoadAndUntagFixedArrayBaseLength(descriptors))); this, UintPtrLessThan(descriptor,
LoadAndUntagFixedArrayBaseLength(descriptors)));
#endif #endif
Node* value = Node* value =
LoadFixedArrayElement(descriptors, descriptor, 0, INTPTR_PARAMETERS); LoadFixedArrayElement(descriptors, descriptor, 0, INTPTR_PARAMETERS);
...@@ -5675,7 +5682,7 @@ void CodeStubAssembler::HandleLoadICProtoHandler( ...@@ -5675,7 +5682,7 @@ void CodeStubAssembler::HandleLoadICProtoHandler(
Bind(&validity_cell_check_done); Bind(&validity_cell_check_done);
Node* smi_handler = LoadObjectField(handler, LoadHandler::kSmiHandlerOffset); Node* smi_handler = LoadObjectField(handler, LoadHandler::kSmiHandlerOffset);
CSA_ASSERT(TaggedIsSmi(smi_handler)); CSA_ASSERT(this, TaggedIsSmi(smi_handler));
Node* handler_flags = SmiUntag(smi_handler); Node* handler_flags = SmiUntag(smi_handler);
Label check_prototypes(this); Label check_prototypes(this);
...@@ -5705,7 +5712,7 @@ void CodeStubAssembler::HandleLoadICProtoHandler( ...@@ -5705,7 +5712,7 @@ void CodeStubAssembler::HandleLoadICProtoHandler(
Node* holder = LoadWeakCellValue(maybe_holder_cell); Node* holder = LoadWeakCellValue(maybe_holder_cell);
// The |holder| is guaranteed to be alive at this point since we passed // The |holder| is guaranteed to be alive at this point since we passed
// both the receiver map check and the validity cell check. // both the receiver map check and the validity cell check.
CSA_ASSERT(WordNotEqual(holder, IntPtrConstant(0))); CSA_ASSERT(this, WordNotEqual(holder, IntPtrConstant(0)));
var_holder->Bind(holder); var_holder->Bind(holder);
var_smi_handler->Bind(smi_handler); var_smi_handler->Bind(smi_handler);
...@@ -5731,7 +5738,7 @@ void CodeStubAssembler::HandleLoadICProtoHandler( ...@@ -5731,7 +5738,7 @@ void CodeStubAssembler::HandleLoadICProtoHandler(
FixedArray::OffsetOfElementAt(LoadHandler::kFirstPrototypeIndex); FixedArray::OffsetOfElementAt(LoadHandler::kFirstPrototypeIndex);
Node* expected_native_context = Node* expected_native_context =
LoadWeakCellValue(LoadObjectField(handler, offset), miss); LoadWeakCellValue(LoadObjectField(handler, offset), miss);
CSA_ASSERT(IsNativeContext(expected_native_context)); CSA_ASSERT(this, IsNativeContext(expected_native_context));
Node* native_context = LoadNativeContext(p->context); Node* native_context = LoadNativeContext(p->context);
GotoIf(WordEqual(expected_native_context, native_context), &can_access); GotoIf(WordEqual(expected_native_context, native_context), &can_access);
...@@ -5769,7 +5776,7 @@ void CodeStubAssembler::HandleLoadICProtoHandler( ...@@ -5769,7 +5776,7 @@ void CodeStubAssembler::HandleLoadICProtoHandler(
// The |holder| is guaranteed to be alive at this point since we passed // The |holder| is guaranteed to be alive at this point since we passed
// the receiver map check, the validity cell check and the prototype chain // the receiver map check, the validity cell check and the prototype chain
// check. // check.
CSA_ASSERT(WordNotEqual(holder, IntPtrConstant(0))); CSA_ASSERT(this, WordNotEqual(holder, IntPtrConstant(0)));
var_holder->Bind(holder); var_holder->Bind(holder);
var_smi_handler->Bind(smi_handler); var_smi_handler->Bind(smi_handler);
...@@ -5791,7 +5798,7 @@ void CodeStubAssembler::CheckPrototype(Node* prototype_cell, Node* name, ...@@ -5791,7 +5798,7 @@ void CodeStubAssembler::CheckPrototype(Node* prototype_cell, Node* name,
Bind(&if_dictionary_object); Bind(&if_dictionary_object);
{ {
CSA_ASSERT(IsDictionaryMap(LoadMap(maybe_prototype))); CSA_ASSERT(this, IsDictionaryMap(LoadMap(maybe_prototype)));
NameDictionaryNegativeLookup(maybe_prototype, name, miss); NameDictionaryNegativeLookup(maybe_prototype, name, miss);
Goto(&done); Goto(&done);
} }
...@@ -5809,7 +5816,7 @@ void CodeStubAssembler::CheckPrototype(Node* prototype_cell, Node* name, ...@@ -5809,7 +5816,7 @@ void CodeStubAssembler::CheckPrototype(Node* prototype_cell, Node* name,
void CodeStubAssembler::NameDictionaryNegativeLookup(Node* object, Node* name, void CodeStubAssembler::NameDictionaryNegativeLookup(Node* object, Node* name,
Label* miss) { Label* miss) {
CSA_ASSERT(IsDictionaryMap(LoadMap(object))); CSA_ASSERT(this, IsDictionaryMap(LoadMap(object)));
Node* properties = LoadProperties(object); Node* properties = LoadProperties(object);
// Ensure the property does not exist in a dictionary-mode object. // Ensure the property does not exist in a dictionary-mode object.
Variable var_name_index(this, MachineType::PointerRepresentation()); Variable var_name_index(this, MachineType::PointerRepresentation());
...@@ -6126,8 +6133,8 @@ void CodeStubAssembler::HandleStoreICSmiHandlerCase(Node* handler_word, ...@@ -6126,8 +6133,8 @@ void CodeStubAssembler::HandleStoreICSmiHandlerCase(Node* handler_word,
&if_heap_object_field); &if_heap_object_field);
GotoIf(WordEqual(field_representation, IntPtrConstant(StoreHandler::kDouble)), GotoIf(WordEqual(field_representation, IntPtrConstant(StoreHandler::kDouble)),
&if_double_field); &if_double_field);
CSA_ASSERT( CSA_ASSERT(this, WordEqual(field_representation,
WordEqual(field_representation, IntPtrConstant(StoreHandler::kSmi))); IntPtrConstant(StoreHandler::kSmi)));
Goto(&if_smi_field); Goto(&if_smi_field);
Bind(&if_tagged_field); Bind(&if_tagged_field);
...@@ -6332,11 +6339,11 @@ void CodeStubAssembler::LoadGlobalIC(const LoadICParameters* p) { ...@@ -6332,11 +6339,11 @@ void CodeStubAssembler::LoadGlobalIC(const LoadICParameters* p) {
Label try_handler(this), miss(this); Label try_handler(this), miss(this);
Node* weak_cell = Node* weak_cell =
LoadFixedArrayElement(p->vector, p->slot, 0, SMI_PARAMETERS); LoadFixedArrayElement(p->vector, p->slot, 0, SMI_PARAMETERS);
CSA_ASSERT(HasInstanceType(weak_cell, WEAK_CELL_TYPE)); CSA_ASSERT(this, HasInstanceType(weak_cell, WEAK_CELL_TYPE));
// Load value or try handler case if the {weak_cell} is cleared. // Load value or try handler case if the {weak_cell} is cleared.
Node* property_cell = LoadWeakCellValue(weak_cell, &try_handler); Node* property_cell = LoadWeakCellValue(weak_cell, &try_handler);
CSA_ASSERT(HasInstanceType(property_cell, PROPERTY_CELL_TYPE)); CSA_ASSERT(this, HasInstanceType(property_cell, PROPERTY_CELL_TYPE));
Node* value = LoadObjectField(property_cell, PropertyCell::kValueOffset); Node* value = LoadObjectField(property_cell, PropertyCell::kValueOffset);
GotoIf(WordEqual(value, TheHoleConstant()), &miss); GotoIf(WordEqual(value, TheHoleConstant()), &miss);
...@@ -6350,7 +6357,7 @@ void CodeStubAssembler::LoadGlobalIC(const LoadICParameters* p) { ...@@ -6350,7 +6357,7 @@ void CodeStubAssembler::LoadGlobalIC(const LoadICParameters* p) {
&miss); &miss);
// In this case {handler} must be a Code object. // In this case {handler} must be a Code object.
CSA_ASSERT(HasInstanceType(handler, CODE_TYPE)); CSA_ASSERT(this, HasInstanceType(handler, CODE_TYPE));
LoadWithVectorDescriptor descriptor(isolate()); LoadWithVectorDescriptor descriptor(isolate());
Node* native_context = LoadNativeContext(p->context); Node* native_context = LoadNativeContext(p->context);
Node* receiver = Node* receiver =
...@@ -6382,9 +6389,9 @@ void CodeStubAssembler::ExtendPropertiesBackingStore(compiler::Node* object) { ...@@ -6382,9 +6389,9 @@ void CodeStubAssembler::ExtendPropertiesBackingStore(compiler::Node* object) {
FixedArrayBase::GetMaxLengthForNewSpaceAllocation(kind)); FixedArrayBase::GetMaxLengthForNewSpaceAllocation(kind));
// The size of a new properties backing store is guaranteed to be small // The size of a new properties backing store is guaranteed to be small
// enough that the new backing store will be allocated in new space. // enough that the new backing store will be allocated in new space.
CSA_ASSERT(UintPtrLessThan( CSA_ASSERT(this, UintPtrLessThan(new_capacity,
new_capacity, IntPtrConstant(kMaxNumberOfDescriptors +
IntPtrConstant(kMaxNumberOfDescriptors + JSObject::kFieldsAdded))); JSObject::kFieldsAdded)));
Node* new_properties = AllocateFixedArray(kind, new_capacity, mode); Node* new_properties = AllocateFixedArray(kind, new_capacity, mode);
...@@ -6531,7 +6538,7 @@ Node* CodeStubAssembler::EmitKeyedSloppyArguments(Node* receiver, Node* key, ...@@ -6531,7 +6538,7 @@ Node* CodeStubAssembler::EmitKeyedSloppyArguments(Node* receiver, Node* key,
Bind(&if_mapped); Bind(&if_mapped);
{ {
CSA_ASSERT(TaggedIsSmi(mapped_index)); CSA_ASSERT(this, TaggedIsSmi(mapped_index));
mapped_index = SmiUntag(mapped_index); mapped_index = SmiUntag(mapped_index);
Node* the_context = LoadFixedArrayElement(elements, IntPtrConstant(0), 0, Node* the_context = LoadFixedArrayElement(elements, IntPtrConstant(0), 0,
INTPTR_PARAMETERS); INTPTR_PARAMETERS);
...@@ -6543,7 +6550,7 @@ Node* CodeStubAssembler::EmitKeyedSloppyArguments(Node* receiver, Node* key, ...@@ -6543,7 +6550,7 @@ Node* CodeStubAssembler::EmitKeyedSloppyArguments(Node* receiver, Node* key,
if (is_load) { if (is_load) {
Node* result = LoadFixedArrayElement(the_context, mapped_index, 0, Node* result = LoadFixedArrayElement(the_context, mapped_index, 0,
INTPTR_PARAMETERS); INTPTR_PARAMETERS);
CSA_ASSERT(WordNotEqual(result, TheHoleConstant())); CSA_ASSERT(this, WordNotEqual(result, TheHoleConstant()));
var_result.Bind(result); var_result.Bind(result);
} else { } else {
StoreFixedArrayElement(the_context, mapped_index, value, StoreFixedArrayElement(the_context, mapped_index, value,
...@@ -6937,7 +6944,7 @@ Node* CodeStubAssembler::PageFromAddress(Node* address) { ...@@ -6937,7 +6944,7 @@ Node* CodeStubAssembler::PageFromAddress(Node* address) {
} }
Node* CodeStubAssembler::EnumLength(Node* map) { Node* CodeStubAssembler::EnumLength(Node* map) {
CSA_ASSERT(IsMap(map)); CSA_ASSERT(this, IsMap(map));
Node* bitfield_3 = LoadMapBitField3(map); Node* bitfield_3 = LoadMapBitField3(map);
Node* enum_length = DecodeWordFromWord32<Map::EnumLengthBits>(bitfield_3); Node* enum_length = DecodeWordFromWord32<Map::EnumLengthBits>(bitfield_3);
return SmiTag(enum_length); return SmiTag(enum_length);
...@@ -7202,7 +7209,7 @@ void CodeStubAssembler::BranchIfNumericRelationalComparison( ...@@ -7202,7 +7209,7 @@ void CodeStubAssembler::BranchIfNumericRelationalComparison(
Bind(&if_rhsisnotsmi); Bind(&if_rhsisnotsmi);
{ {
CSA_ASSERT(WordEqual(LoadMap(rhs), HeapNumberMapConstant())); CSA_ASSERT(this, WordEqual(LoadMap(rhs), HeapNumberMapConstant()));
// Convert the {lhs} and {rhs} to floating point values, and // Convert the {lhs} and {rhs} to floating point values, and
// perform a floating point comparison. // perform a floating point comparison.
var_fcmp_lhs.Bind(SmiToFloat64(lhs)); var_fcmp_lhs.Bind(SmiToFloat64(lhs));
...@@ -7213,7 +7220,7 @@ void CodeStubAssembler::BranchIfNumericRelationalComparison( ...@@ -7213,7 +7220,7 @@ void CodeStubAssembler::BranchIfNumericRelationalComparison(
Bind(&if_lhsisnotsmi); Bind(&if_lhsisnotsmi);
{ {
CSA_ASSERT(WordEqual(LoadMap(lhs), HeapNumberMapConstant())); CSA_ASSERT(this, WordEqual(LoadMap(lhs), HeapNumberMapConstant()));
// Check if {rhs} is a Smi or a HeapObject. // Check if {rhs} is a Smi or a HeapObject.
Label if_rhsissmi(this), if_rhsisnotsmi(this); Label if_rhsissmi(this), if_rhsisnotsmi(this);
...@@ -7230,7 +7237,7 @@ void CodeStubAssembler::BranchIfNumericRelationalComparison( ...@@ -7230,7 +7237,7 @@ void CodeStubAssembler::BranchIfNumericRelationalComparison(
Bind(&if_rhsisnotsmi); Bind(&if_rhsisnotsmi);
{ {
CSA_ASSERT(WordEqual(LoadMap(rhs), HeapNumberMapConstant())); CSA_ASSERT(this, WordEqual(LoadMap(rhs), HeapNumberMapConstant()));
// Convert the {lhs} and {rhs} to floating point values, and // Convert the {lhs} and {rhs} to floating point values, and
// perform a floating point comparison. // perform a floating point comparison.
...@@ -8529,7 +8536,7 @@ compiler::Node* CodeStubAssembler::Typeof(compiler::Node* value, ...@@ -8529,7 +8536,7 @@ compiler::Node* CodeStubAssembler::Typeof(compiler::Node* value,
SIMD128_TYPES(SIMD128_BRANCH) SIMD128_TYPES(SIMD128_BRANCH)
#undef SIMD128_BRANCH #undef SIMD128_BRANCH
CSA_ASSERT(Word32Equal(instance_type, Int32Constant(SYMBOL_TYPE))); CSA_ASSERT(this, Word32Equal(instance_type, Int32Constant(SYMBOL_TYPE)));
result_var.Bind(HeapConstant(isolate()->factory()->symbol_string())); result_var.Bind(HeapConstant(isolate()->factory()->symbol_string()));
Goto(&return_result); Goto(&return_result);
...@@ -8647,7 +8654,7 @@ compiler::Node* CodeStubAssembler::NumberInc(compiler::Node* value) { ...@@ -8647,7 +8654,7 @@ compiler::Node* CodeStubAssembler::NumberInc(compiler::Node* value) {
Bind(&if_isnotsmi); Bind(&if_isnotsmi);
{ {
// Check if the value is a HeapNumber. // Check if the value is a HeapNumber.
CSA_ASSERT(IsHeapNumberMap(LoadMap(value))); CSA_ASSERT(this, IsHeapNumberMap(LoadMap(value)));
// Load the HeapNumber value. // Load the HeapNumber value.
var_finc_value.Bind(LoadHeapNumberValue(value)); var_finc_value.Bind(LoadHeapNumberValue(value));
...@@ -8702,7 +8709,7 @@ compiler::Node* CodeStubAssembler::CreateArrayIterator( ...@@ -8702,7 +8709,7 @@ compiler::Node* CodeStubAssembler::CreateArrayIterator(
Context::UINT8_ARRAY_KEY_VALUE_ITERATOR_MAP_INDEX)); Context::UINT8_ARRAY_KEY_VALUE_ITERATOR_MAP_INDEX));
// Assert: Type(array) is Object // Assert: Type(array) is Object
CSA_ASSERT(IsJSReceiverInstanceType(array_type)); CSA_ASSERT(this, IsJSReceiverInstanceType(array_type));
Variable var_result(this, MachineRepresentation::kTagged); Variable var_result(this, MachineRepresentation::kTagged);
Variable var_map_index(this, MachineType::PointerRepresentation()); Variable var_map_index(this, MachineType::PointerRepresentation());
...@@ -8761,10 +8768,12 @@ compiler::Node* CodeStubAssembler::CreateArrayIterator( ...@@ -8761,10 +8768,12 @@ compiler::Node* CodeStubAssembler::CreateArrayIterator(
Node* map_index = Node* map_index =
IntPtrAdd(IntPtrConstant(kBaseMapIndex + kFastIteratorOffset), IntPtrAdd(IntPtrConstant(kBaseMapIndex + kFastIteratorOffset),
LoadMapElementsKind(array_map)); LoadMapElementsKind(array_map));
CSA_ASSERT(IntPtrGreaterThanOrEqual( CSA_ASSERT(this, IntPtrGreaterThanOrEqual(
map_index, IntPtrConstant(kBaseMapIndex + kFastIteratorOffset))); map_index, IntPtrConstant(kBaseMapIndex +
CSA_ASSERT(IntPtrLessThan( kFastIteratorOffset)));
map_index, IntPtrConstant(kBaseMapIndex + kSlowIteratorOffset))); CSA_ASSERT(this, IntPtrLessThan(map_index,
IntPtrConstant(kBaseMapIndex +
kSlowIteratorOffset)));
var_map_index.Bind(map_index); var_map_index.Bind(map_index);
var_array_map.Bind(array_map); var_array_map.Bind(array_map);
...@@ -8786,10 +8795,11 @@ compiler::Node* CodeStubAssembler::CreateArrayIterator( ...@@ -8786,10 +8795,11 @@ compiler::Node* CodeStubAssembler::CreateArrayIterator(
Node* map_index = Node* map_index =
IntPtrAdd(IntPtrConstant(kBaseMapIndex - UINT8_ELEMENTS), IntPtrAdd(IntPtrConstant(kBaseMapIndex - UINT8_ELEMENTS),
LoadMapElementsKind(array_map)); LoadMapElementsKind(array_map));
CSA_ASSERT(IntPtrLessThan(
map_index, IntPtrConstant(kBaseMapIndex + kFastIteratorOffset)));
CSA_ASSERT( CSA_ASSERT(
IntPtrGreaterThanOrEqual(map_index, IntPtrConstant(kBaseMapIndex))); this, IntPtrLessThan(map_index, IntPtrConstant(kBaseMapIndex +
kFastIteratorOffset)));
CSA_ASSERT(this, IntPtrGreaterThanOrEqual(map_index,
IntPtrConstant(kBaseMapIndex)));
var_map_index.Bind(map_index); var_map_index.Bind(map_index);
var_array_map.Bind(UndefinedConstant()); var_array_map.Bind(UndefinedConstant());
Goto(&allocate_iterator); Goto(&allocate_iterator);
...@@ -8827,7 +8837,7 @@ compiler::Node* CodeStubAssembler::AllocateJSArrayIterator( ...@@ -8827,7 +8837,7 @@ compiler::Node* CodeStubAssembler::AllocateJSArrayIterator(
} }
compiler::Node* CodeStubAssembler::IsDetachedBuffer(compiler::Node* buffer) { compiler::Node* CodeStubAssembler::IsDetachedBuffer(compiler::Node* buffer) {
CSA_ASSERT(HasInstanceType(buffer, JS_ARRAY_BUFFER_TYPE)); CSA_ASSERT(this, HasInstanceType(buffer, JS_ARRAY_BUFFER_TYPE));
Node* buffer_bit_field = LoadObjectField( Node* buffer_bit_field = LoadObjectField(
buffer, JSArrayBuffer::kBitFieldOffset, MachineType::Uint32()); buffer, JSArrayBuffer::kBitFieldOffset, MachineType::Uint32());
......
...@@ -161,7 +161,8 @@ class V8_EXPORT_PRIVATE CodeStubAssembler : public compiler::CodeAssembler { ...@@ -161,7 +161,8 @@ class V8_EXPORT_PRIVATE CodeStubAssembler : public compiler::CodeAssembler {
compiler::Node* offset); compiler::Node* offset);
compiler::Node* IsRegularHeapObjectSize(compiler::Node* size); compiler::Node* IsRegularHeapObjectSize(compiler::Node* size);
void Assert(compiler::Node* condition, const char* string = nullptr, typedef std::function<compiler::Node*()> ConditionBody;
void Assert(ConditionBody condition_body, const char* string = nullptr,
const char* file = nullptr, int line = 0); const char* file = nullptr, int line = 0);
// Check a value for smi-ness // Check a value for smi-ness
...@@ -1263,14 +1264,20 @@ class CodeStubArguments { ...@@ -1263,14 +1264,20 @@ class CodeStubArguments {
compiler::Node* fp_; compiler::Node* fp_;
}; };
#define CSA_ASSERT(x) Assert((x), #x, __FILE__, __LINE__) #ifdef DEBUG
#define CSA_ASSERT(csa, x) \
(csa)->Assert([&] { return (x); }, #x, __FILE__, __LINE__)
#else
#define CSA_ASSERT(csa, x) ((void)0)
#endif
#ifdef ENABLE_SLOW_DCHECKS #ifdef ENABLE_SLOW_DCHECKS
#define CSA_SLOW_ASSERT(x) \ #define CSA_SLOW_ASSERT(csa, x) \
if (FLAG_enable_slow_asserts) { \ if (FLAG_enable_slow_asserts) { \
Assert((x), #x, __FILE__, __LINE__); \ (csa)->Assert([&] { return (x); }, #x, __FILE__, __LINE__); \
} }
#else #else
#define CSA_SLOW_ASSERT(x) #define CSA_SLOW_ASSERT(csa, x) ((void)0)
#endif #endif
DEFINE_OPERATORS_FOR_FLAGS(CodeStubAssembler::AllocationFlags); DEFINE_OPERATORS_FOR_FLAGS(CodeStubAssembler::AllocationFlags);
......
...@@ -1754,9 +1754,10 @@ compiler::Node* IncStub::Generate(CodeStubAssembler* assembler, ...@@ -1754,9 +1754,10 @@ compiler::Node* IncStub::Generate(CodeStubAssembler* assembler,
// We do not require an Or with earlier feedback here because once we // We do not require an Or with earlier feedback here because once we
// convert the value to a number, we cannot reach this path. We can // convert the value to a number, we cannot reach this path. We can
// only reach this path on the first pass when the feedback is kNone. // only reach this path on the first pass when the feedback is kNone.
assembler->Assert(assembler->Word32Equal( CSA_ASSERT(assembler,
var_type_feedback.value(), assembler->Word32Equal(var_type_feedback.value(),
assembler->Int32Constant(BinaryOperationFeedback::kNone))); assembler->Int32Constant(
BinaryOperationFeedback::kNone)));
Label if_valueisoddball(assembler), if_valuenotoddball(assembler); Label if_valueisoddball(assembler), if_valuenotoddball(assembler);
Node* instance_type = assembler->LoadMapInstanceType(value_map); Node* instance_type = assembler->LoadMapInstanceType(value_map);
...@@ -1893,9 +1894,10 @@ compiler::Node* DecStub::Generate(CodeStubAssembler* assembler, ...@@ -1893,9 +1894,10 @@ compiler::Node* DecStub::Generate(CodeStubAssembler* assembler,
// We do not require an Or with earlier feedback here because once we // We do not require an Or with earlier feedback here because once we
// convert the value to a number, we cannot reach this path. We can // convert the value to a number, we cannot reach this path. We can
// only reach this path on the first pass when the feedback is kNone. // only reach this path on the first pass when the feedback is kNone.
assembler->Assert(assembler->Word32Equal( CSA_ASSERT(assembler,
var_type_feedback.value(), assembler->Word32Equal(var_type_feedback.value(),
assembler->Int32Constant(BinaryOperationFeedback::kNone))); assembler->Int32Constant(
BinaryOperationFeedback::kNone)));
Label if_valueisoddball(assembler), if_valuenotoddball(assembler); Label if_valueisoddball(assembler), if_valuenotoddball(assembler);
Node* instance_type = assembler->LoadMapInstanceType(value_map); Node* instance_type = assembler->LoadMapInstanceType(value_map);
...@@ -2571,9 +2573,10 @@ compiler::Node* FastNewClosureStub::Generate(CodeStubAssembler* assembler, ...@@ -2571,9 +2573,10 @@ compiler::Node* FastNewClosureStub::Generate(CodeStubAssembler* assembler,
if (FLAG_debug_code) { if (FLAG_debug_code) {
// Function must be a function without a prototype. // Function must be a function without a prototype.
assembler->Assert(assembler->Word32And( CSA_ASSERT(assembler, assembler->Word32And(
compiler_hints, compiler_hints,
assembler->Int32Constant((FunctionKind::kAccessorFunction | assembler->Int32Constant(
(FunctionKind::kAccessorFunction |
FunctionKind::kArrowFunction | FunctionKind::kArrowFunction |
FunctionKind::kConciseMethod) FunctionKind::kConciseMethod)
<< SharedFunctionInfo::kFunctionKindShift))); << SharedFunctionInfo::kFunctionKindShift)));
......
...@@ -1159,7 +1159,8 @@ Node* InterpreterAssembler::TruncateTaggedToWord32WithFeedback( ...@@ -1159,7 +1159,8 @@ Node* InterpreterAssembler::TruncateTaggedToWord32WithFeedback(
// We do not require an Or with earlier feedback here because once we // We do not require an Or with earlier feedback here because once we
// convert the value to a number, we cannot reach this path. We can // convert the value to a number, we cannot reach this path. We can
// only reach this path on the first pass when the feedback is kNone. // only reach this path on the first pass when the feedback is kNone.
Assert(Word32Equal(var_type_feedback->value(), CSA_ASSERT(this,
Word32Equal(var_type_feedback->value(),
Int32Constant(BinaryOperationFeedback::kNone))); Int32Constant(BinaryOperationFeedback::kNone)));
Label if_valueisoddball(this), Label if_valueisoddball(this),
......
...@@ -1925,9 +1925,12 @@ TEST(Arguments) { ...@@ -1925,9 +1925,12 @@ TEST(Arguments) {
CodeStubArguments arguments(&m, m.IntPtrConstant(3)); CodeStubArguments arguments(&m, m.IntPtrConstant(3));
m.Assert(m.WordEqual(arguments.AtIndex(0), m.SmiConstant(Smi::FromInt(12)))); CSA_ASSERT(
m.Assert(m.WordEqual(arguments.AtIndex(1), m.SmiConstant(Smi::FromInt(13)))); &m, m.WordEqual(arguments.AtIndex(0), m.SmiConstant(Smi::FromInt(12))));
m.Assert(m.WordEqual(arguments.AtIndex(2), m.SmiConstant(Smi::FromInt(14)))); CSA_ASSERT(
&m, m.WordEqual(arguments.AtIndex(1), m.SmiConstant(Smi::FromInt(13))));
CSA_ASSERT(
&m, m.WordEqual(arguments.AtIndex(2), m.SmiConstant(Smi::FromInt(14))));
m.Return(arguments.GetReceiver()); m.Return(arguments.GetReceiver());
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment