| Index: runtime/vm/aot_optimizer.cc
|
| diff --git a/runtime/vm/aot_optimizer.cc b/runtime/vm/aot_optimizer.cc
|
| index c1d1b8fd604842127f94447cb1b3ae3ecb8fe4ff..ea444c0de86088e8ef351217ecbe072f4158100e 100644
|
| --- a/runtime/vm/aot_optimizer.cc
|
| +++ b/runtime/vm/aot_optimizer.cc
|
| @@ -29,7 +29,9 @@
|
|
|
| namespace dart {
|
|
|
| -DEFINE_FLAG(int, max_exhaustive_polymorphic_checks, 5,
|
| +DEFINE_FLAG(int,
|
| + max_exhaustive_polymorphic_checks,
|
| + 5,
|
| "If a call receiver is known to be of at most this many classes, "
|
| "generate exhaustive class tests instead of a megamorphic call");
|
|
|
| @@ -68,7 +70,7 @@ static void GetUniqueDynamicTarget(Isolate* isolate,
|
| ASSERT(fname.IsSymbol());
|
| *function = functions_set.GetOrNull(fname);
|
| ASSERT(functions_set.Release().raw() ==
|
| - isolate->object_store()->unique_dynamic_targets());
|
| + isolate->object_store()->unique_dynamic_targets());
|
| }
|
|
|
|
|
| @@ -85,8 +87,8 @@ AotOptimizer::AotOptimizer(Precompiler* precompiler,
|
| ASSERT(!use_speculative_inlining || (inlining_black_list != NULL));
|
| Function& target_function = Function::Handle();
|
| if (isolate()->object_store()->unique_dynamic_targets() != Array::null()) {
|
| - GetUniqueDynamicTarget(
|
| - isolate(), Symbols::NoSuchMethod(), &target_function);
|
| + GetUniqueDynamicTarget(isolate(), Symbols::NoSuchMethod(),
|
| + &target_function);
|
| has_unique_no_such_method_ = !target_function.IsNull();
|
| }
|
| }
|
| @@ -101,22 +103,20 @@ void AotOptimizer::ApplyICData() {
|
| void AotOptimizer::PopulateWithICData() {
|
| ASSERT(current_iterator_ == NULL);
|
| for (BlockIterator block_it = flow_graph_->reverse_postorder_iterator();
|
| - !block_it.Done();
|
| - block_it.Advance()) {
|
| + !block_it.Done(); block_it.Advance()) {
|
| ForwardInstructionIterator it(block_it.Current());
|
| for (; !it.Done(); it.Advance()) {
|
| Instruction* instr = it.Current();
|
| if (instr->IsInstanceCall()) {
|
| InstanceCallInstr* call = instr->AsInstanceCall();
|
| if (!call->HasICData()) {
|
| - const Array& arguments_descriptor =
|
| - Array::Handle(zone(),
|
| - ArgumentsDescriptor::New(call->ArgumentCount(),
|
| - call->argument_names()));
|
| - const ICData& ic_data = ICData::ZoneHandle(zone(), ICData::New(
|
| - function(), call->function_name(),
|
| - arguments_descriptor, call->deopt_id(),
|
| - call->checked_argument_count(), false));
|
| + const Array& arguments_descriptor = Array::Handle(
|
| + zone(), ArgumentsDescriptor::New(call->ArgumentCount(),
|
| + call->argument_names()));
|
| + const ICData& ic_data = ICData::ZoneHandle(
|
| + zone(), ICData::New(function(), call->function_name(),
|
| + arguments_descriptor, call->deopt_id(),
|
| + call->checked_argument_count(), false));
|
| call->set_ic_data(&ic_data);
|
| }
|
| }
|
| @@ -138,29 +138,23 @@ bool AotOptimizer::RecognizeRuntimeTypeGetter(InstanceCallInstr* call) {
|
| // There is only a single function Object.get:runtimeType that can be invoked
|
| // by this call. Convert dynamic invocation to a static one.
|
| const Class& cls = Class::Handle(Z, I->object_store()->object_class());
|
| - const Array& args_desc_array = Array::Handle(Z,
|
| - ArgumentsDescriptor::New(call->ArgumentCount(),
|
| - call->argument_names()));
|
| + const Array& args_desc_array = Array::Handle(
|
| + Z,
|
| + ArgumentsDescriptor::New(call->ArgumentCount(), call->argument_names()));
|
| ArgumentsDescriptor args_desc(args_desc_array);
|
| - const Function& function = Function::Handle(Z,
|
| - Resolver::ResolveDynamicForReceiverClass(
|
| - cls,
|
| - call->function_name(),
|
| - args_desc));
|
| + const Function& function =
|
| + Function::Handle(Z, Resolver::ResolveDynamicForReceiverClass(
|
| + cls, call->function_name(), args_desc));
|
| ASSERT(!function.IsNull());
|
|
|
| ZoneGrowableArray<PushArgumentInstr*>* args =
|
| - new (Z) ZoneGrowableArray<PushArgumentInstr*>(
|
| - call->ArgumentCount());
|
| + new (Z) ZoneGrowableArray<PushArgumentInstr*>(call->ArgumentCount());
|
| for (intptr_t i = 0; i < call->ArgumentCount(); i++) {
|
| args->Add(call->PushArgumentAt(i));
|
| }
|
| StaticCallInstr* static_call = new (Z) StaticCallInstr(
|
| - call->token_pos(),
|
| - Function::ZoneHandle(Z, function.raw()),
|
| - call->argument_names(),
|
| - args,
|
| - call->deopt_id());
|
| + call->token_pos(), Function::ZoneHandle(Z, function.raw()),
|
| + call->argument_names(), args, call->deopt_id());
|
| static_call->set_result_cid(kTypeCid);
|
| call->ReplaceWith(static_call, current_iterator());
|
| return true;
|
| @@ -176,8 +170,7 @@ bool AotOptimizer::RecognizeRuntimeTypeGetter(InstanceCallInstr* call) {
|
| void AotOptimizer::ApplyClassIds() {
|
| ASSERT(current_iterator_ == NULL);
|
| for (BlockIterator block_it = flow_graph_->reverse_postorder_iterator();
|
| - !block_it.Done();
|
| - block_it.Advance()) {
|
| + !block_it.Done(); block_it.Advance()) {
|
| ForwardInstructionIterator it(block_it.Current());
|
| current_iterator_ = ⁢
|
| for (; !it.Done(); it.Advance()) {
|
| @@ -217,8 +210,7 @@ bool AotOptimizer::TryCreateICData(InstanceCallInstr* call) {
|
|
|
| const Token::Kind op_kind = call->token_kind();
|
| if (Token::IsRelationalOperator(op_kind) ||
|
| - Token::IsEqualityOperator(op_kind) ||
|
| - Token::IsBinaryOperator(op_kind)) {
|
| + Token::IsEqualityOperator(op_kind) || Token::IsBinaryOperator(op_kind)) {
|
| // Guess cid: if one of the inputs is a number assume that the other
|
| // is a number of same type.
|
| if (FLAG_guess_icdata_cid) {
|
| @@ -242,23 +234,21 @@ bool AotOptimizer::TryCreateICData(InstanceCallInstr* call) {
|
| }
|
|
|
| if (all_cids_known) {
|
| - const Class& receiver_class = Class::Handle(Z,
|
| - isolate()->class_table()->At(class_ids[0]));
|
| + const Class& receiver_class =
|
| + Class::Handle(Z, isolate()->class_table()->At(class_ids[0]));
|
| if (!receiver_class.is_finalized()) {
|
| // Do not eagerly finalize classes. ResolveDynamicForReceiverClass can
|
| // cause class finalization, since callee's receiver class may not be
|
| // finalized yet.
|
| return false;
|
| }
|
| - const Array& args_desc_array = Array::Handle(Z,
|
| - ArgumentsDescriptor::New(call->ArgumentCount(),
|
| - call->argument_names()));
|
| + const Array& args_desc_array =
|
| + Array::Handle(Z, ArgumentsDescriptor::New(call->ArgumentCount(),
|
| + call->argument_names()));
|
| ArgumentsDescriptor args_desc(args_desc_array);
|
| - const Function& function = Function::Handle(Z,
|
| - Resolver::ResolveDynamicForReceiverClass(
|
| - receiver_class,
|
| - call->function_name(),
|
| - args_desc));
|
| + const Function& function = Function::Handle(
|
| + Z, Resolver::ResolveDynamicForReceiverClass(
|
| + receiver_class, call->function_name(), args_desc));
|
| if (function.IsNull()) {
|
| return false;
|
| }
|
| @@ -267,8 +257,8 @@ bool AotOptimizer::TryCreateICData(InstanceCallInstr* call) {
|
| // since it is attached to the assembly instruction itself.
|
| // TODO(srdjan): Prevent modification of ICData object that is
|
| // referenced in assembly code.
|
| - const ICData& ic_data = ICData::ZoneHandle(Z,
|
| - ICData::NewFrom(*call->ic_data(), class_ids.length()));
|
| + const ICData& ic_data = ICData::ZoneHandle(
|
| + Z, ICData::NewFrom(*call->ic_data(), class_ids.length()));
|
| if (class_ids.length() > 1) {
|
| ic_data.AddCheck(class_ids, function);
|
| } else {
|
| @@ -290,8 +280,8 @@ bool AotOptimizer::TryCreateICData(InstanceCallInstr* call) {
|
| /* error_message = */ NULL)) {
|
| const Class& cls = Class::Handle(Z, target_function.Owner());
|
| if (!CHA::IsImplemented(cls) && !CHA::HasSubclasses(cls)) {
|
| - const ICData& ic_data = ICData::ZoneHandle(Z,
|
| - ICData::NewFrom(*call->ic_data(), 1));
|
| + const ICData& ic_data =
|
| + ICData::ZoneHandle(Z, ICData::NewFrom(*call->ic_data(), 1));
|
| ic_data.AddReceiverCheck(cls.id(), target_function);
|
| call->set_ic_data(&ic_data);
|
| if (has_unique_no_such_method_) {
|
| @@ -319,12 +309,11 @@ const ICData& AotOptimizer::TrySpecializeICData(const ICData& ic_data,
|
| // TODO(fschneider): Try looking up the function on the class if it is
|
| // not found in the ICData.
|
| if (!function.IsNull()) {
|
| - const ICData& new_ic_data = ICData::ZoneHandle(Z, ICData::New(
|
| - Function::Handle(Z, ic_data.Owner()),
|
| - String::Handle(Z, ic_data.target_name()),
|
| - Object::empty_array(), // Dummy argument descriptor.
|
| - ic_data.deopt_id(),
|
| - ic_data.NumArgsTested(), false));
|
| + const ICData& new_ic_data = ICData::ZoneHandle(
|
| + Z, ICData::New(Function::Handle(Z, ic_data.Owner()),
|
| + String::Handle(Z, ic_data.target_name()),
|
| + Object::empty_array(), // Dummy argument descriptor.
|
| + ic_data.deopt_id(), ic_data.NumArgsTested(), false));
|
| new_ic_data.SetDeoptReasons(ic_data.DeoptReasons());
|
| new_ic_data.AddReceiverCheck(cid, function);
|
| return new_ic_data;
|
| @@ -394,19 +383,19 @@ static bool ICDataHasReceiverArgumentClassIds(const ICData& ic_data,
|
|
|
|
|
| static bool HasOnlyOneSmi(const ICData& ic_data) {
|
| - return (ic_data.NumberOfUsedChecks() == 1)
|
| - && ic_data.HasReceiverClassId(kSmiCid);
|
| + return (ic_data.NumberOfUsedChecks() == 1) &&
|
| + ic_data.HasReceiverClassId(kSmiCid);
|
| }
|
|
|
|
|
| static bool HasOnlySmiOrMint(const ICData& ic_data) {
|
| if (ic_data.NumberOfUsedChecks() == 1) {
|
| - return ic_data.HasReceiverClassId(kSmiCid)
|
| - || ic_data.HasReceiverClassId(kMintCid);
|
| + return ic_data.HasReceiverClassId(kSmiCid) ||
|
| + ic_data.HasReceiverClassId(kMintCid);
|
| }
|
| - return (ic_data.NumberOfUsedChecks() == 2)
|
| - && ic_data.HasReceiverClassId(kSmiCid)
|
| - && ic_data.HasReceiverClassId(kMintCid);
|
| + return (ic_data.NumberOfUsedChecks() == 2) &&
|
| + ic_data.HasReceiverClassId(kSmiCid) &&
|
| + ic_data.HasReceiverClassId(kMintCid);
|
| }
|
|
|
|
|
| @@ -449,8 +438,8 @@ static bool HasTwoDoubleOrSmi(const ICData& ic_data) {
|
|
|
|
|
| static bool HasOnlyOneDouble(const ICData& ic_data) {
|
| - return (ic_data.NumberOfUsedChecks() == 1)
|
| - && ic_data.HasReceiverClassId(kDoubleCid);
|
| + return (ic_data.NumberOfUsedChecks() == 1) &&
|
| + ic_data.HasReceiverClassId(kDoubleCid);
|
| }
|
|
|
|
|
| @@ -470,8 +459,7 @@ static bool ShouldSpecializeForDouble(const ICData& ic_data) {
|
| }
|
|
|
|
|
| -void AotOptimizer::ReplaceCall(Definition* call,
|
| - Definition* replacement) {
|
| +void AotOptimizer::ReplaceCall(Definition* call, Definition* replacement) {
|
| // Remove the original push arguments.
|
| for (intptr_t i = 0; i < call->ArgumentCount(); ++i) {
|
| PushArgumentInstr* push = call->PushArgumentAt(i);
|
| @@ -488,11 +476,9 @@ void AotOptimizer::AddCheckSmi(Definition* to_check,
|
| Instruction* insert_before) {
|
| if (to_check->Type()->ToCid() != kSmiCid) {
|
| InsertBefore(insert_before,
|
| - new(Z) CheckSmiInstr(new(Z) Value(to_check),
|
| - deopt_id,
|
| - insert_before->token_pos()),
|
| - deopt_environment,
|
| - FlowGraph::kEffect);
|
| + new (Z) CheckSmiInstr(new (Z) Value(to_check), deopt_id,
|
| + insert_before->token_pos()),
|
| + deopt_environment, FlowGraph::kEffect);
|
| }
|
| }
|
|
|
| @@ -503,12 +489,10 @@ Instruction* AotOptimizer::GetCheckClass(Definition* to_check,
|
| TokenPosition token_pos) {
|
| if ((unary_checks.NumberOfUsedChecks() == 1) &&
|
| unary_checks.HasReceiverClassId(kSmiCid)) {
|
| - return new(Z) CheckSmiInstr(new(Z) Value(to_check),
|
| - deopt_id,
|
| - token_pos);
|
| + return new (Z) CheckSmiInstr(new (Z) Value(to_check), deopt_id, token_pos);
|
| }
|
| - return new(Z) CheckClassInstr(
|
| - new(Z) Value(to_check), deopt_id, unary_checks, token_pos);
|
| + return new (Z) CheckClassInstr(new (Z) Value(to_check), deopt_id,
|
| + unary_checks, token_pos);
|
| }
|
|
|
|
|
| @@ -518,8 +502,8 @@ void AotOptimizer::AddCheckClass(Definition* to_check,
|
| Environment* deopt_environment,
|
| Instruction* insert_before) {
|
| // Type propagation has not run yet, we cannot eliminate the check.
|
| - Instruction* check = GetCheckClass(
|
| - to_check, unary_checks, deopt_id, insert_before->token_pos());
|
| + Instruction* check = GetCheckClass(to_check, unary_checks, deopt_id,
|
| + insert_before->token_pos());
|
| InsertBefore(insert_before, check, deopt_environment, FlowGraph::kEffect);
|
| }
|
|
|
| @@ -527,9 +511,7 @@ void AotOptimizer::AddCheckClass(Definition* to_check,
|
| void AotOptimizer::AddReceiverCheck(InstanceCallInstr* call) {
|
| AddCheckClass(call->ArgumentAt(0),
|
| ICData::ZoneHandle(Z, call->ic_data()->AsUnaryClassChecks()),
|
| - call->deopt_id(),
|
| - call->env(),
|
| - call);
|
| + call->deopt_id(), call->env(), call);
|
| }
|
|
|
|
|
| @@ -607,12 +589,12 @@ bool AotOptimizer::TryStringLengthOneEquality(InstanceCallInstr* call,
|
| ASSERT(str.Length() == 1);
|
| ConstantInstr* char_code_left = flow_graph()->GetConstant(
|
| Smi::ZoneHandle(Z, Smi::New(static_cast<intptr_t>(str.CharAt(0)))));
|
| - left_val = new(Z) Value(char_code_left);
|
| + left_val = new (Z) Value(char_code_left);
|
| } else if (left->IsOneByteStringFromCharCode()) {
|
| // Use input of string-from-charcode as left value.
|
| OneByteStringFromCharCodeInstr* instr =
|
| left->AsOneByteStringFromCharCode();
|
| - left_val = new(Z) Value(instr->char_code()->definition());
|
| + left_val = new (Z) Value(instr->char_code()->definition());
|
| to_remove_left = instr;
|
| } else {
|
| // IsLengthOneString(left) should have been false.
|
| @@ -625,32 +607,24 @@ bool AotOptimizer::TryStringLengthOneEquality(InstanceCallInstr* call,
|
| // Skip string-from-char-code, and use its input as right value.
|
| OneByteStringFromCharCodeInstr* right_instr =
|
| right->AsOneByteStringFromCharCode();
|
| - right_val = new(Z) Value(right_instr->char_code()->definition());
|
| + right_val = new (Z) Value(right_instr->char_code()->definition());
|
| to_remove_right = right_instr;
|
| } else {
|
| const ICData& unary_checks_1 =
|
| ICData::ZoneHandle(Z, call->ic_data()->AsUnaryClassChecksForArgNr(1));
|
| - AddCheckClass(right,
|
| - unary_checks_1,
|
| - call->deopt_id(),
|
| - call->env(),
|
| - call);
|
| + AddCheckClass(right, unary_checks_1, call->deopt_id(), call->env(), call);
|
| // String-to-char-code instructions returns -1 (illegal charcode) if
|
| // string is not of length one.
|
| - StringToCharCodeInstr* char_code_right =
|
| - new(Z) StringToCharCodeInstr(new(Z) Value(right), kOneByteStringCid);
|
| + StringToCharCodeInstr* char_code_right = new (Z)
|
| + StringToCharCodeInstr(new (Z) Value(right), kOneByteStringCid);
|
| InsertBefore(call, char_code_right, call->env(), FlowGraph::kValue);
|
| - right_val = new(Z) Value(char_code_right);
|
| + right_val = new (Z) Value(char_code_right);
|
| }
|
|
|
| // Comparing char-codes instead of strings.
|
| EqualityCompareInstr* comp =
|
| - new(Z) EqualityCompareInstr(call->token_pos(),
|
| - op_kind,
|
| - left_val,
|
| - right_val,
|
| - kSmiCid,
|
| - call->deopt_id());
|
| + new (Z) EqualityCompareInstr(call->token_pos(), op_kind, left_val,
|
| + right_val, kSmiCid, call->deopt_id());
|
| ReplaceCall(call, comp);
|
|
|
| // Remove dead instructions.
|
| @@ -670,14 +644,15 @@ bool AotOptimizer::TryStringLengthOneEquality(InstanceCallInstr* call,
|
| }
|
|
|
|
|
| -static bool SmiFitsInDouble() { return kSmiBits < 53; }
|
| +static bool SmiFitsInDouble() {
|
| + return kSmiBits < 53;
|
| +}
|
|
|
|
|
| static bool IsGetRuntimeType(Definition* defn) {
|
| StaticCallInstr* call = defn->AsStaticCall();
|
| - return (call != NULL) &&
|
| - (call->function().recognized_kind() ==
|
| - MethodRecognizer::kObjectRuntimeType);
|
| + return (call != NULL) && (call->function().recognized_kind() ==
|
| + MethodRecognizer::kObjectRuntimeType);
|
| }
|
|
|
|
|
| @@ -695,26 +670,24 @@ bool AotOptimizer::TryReplaceWithHaveSameRuntimeType(InstanceCallInstr* call) {
|
| if (IsGetRuntimeType(left) && left->input_use_list()->IsSingleUse() &&
|
| IsGetRuntimeType(right) && right->input_use_list()->IsSingleUse()) {
|
| const Class& cls = Class::Handle(Z, I->object_store()->object_class());
|
| - const Function& have_same_runtime_type = Function::ZoneHandle(Z,
|
| + const Function& have_same_runtime_type = Function::ZoneHandle(
|
| + Z,
|
| cls.LookupStaticFunctionAllowPrivate(Symbols::HaveSameRuntimeType()));
|
| ASSERT(!have_same_runtime_type.IsNull());
|
|
|
| ZoneGrowableArray<PushArgumentInstr*>* args =
|
| new (Z) ZoneGrowableArray<PushArgumentInstr*>(2);
|
| - PushArgumentInstr* arg = new (Z) PushArgumentInstr(
|
| - new (Z) Value(left->ArgumentAt(0)));
|
| + PushArgumentInstr* arg =
|
| + new (Z) PushArgumentInstr(new (Z) Value(left->ArgumentAt(0)));
|
| InsertBefore(call, arg, NULL, FlowGraph::kEffect);
|
| args->Add(arg);
|
| - arg = new (Z) PushArgumentInstr(
|
| - new (Z) Value(right->ArgumentAt(0)));
|
| + arg = new (Z) PushArgumentInstr(new (Z) Value(right->ArgumentAt(0)));
|
| InsertBefore(call, arg, NULL, FlowGraph::kEffect);
|
| args->Add(arg);
|
| - StaticCallInstr* static_call = new (Z) StaticCallInstr(
|
| - call->token_pos(),
|
| - have_same_runtime_type,
|
| - Object::null_array(), // argument_names
|
| - args,
|
| - call->deopt_id());
|
| + StaticCallInstr* static_call =
|
| + new (Z) StaticCallInstr(call->token_pos(), have_same_runtime_type,
|
| + Object::null_array(), // argument_names
|
| + args, call->deopt_id());
|
| static_call->set_result_cid(kBoolCid);
|
| ReplaceCall(call, static_call);
|
| return true;
|
| @@ -738,17 +711,13 @@ bool AotOptimizer::TryReplaceWithEqualityOp(InstanceCallInstr* call,
|
| return TryStringLengthOneEquality(call, op_kind);
|
| } else if (HasOnlyTwoOf(ic_data, kSmiCid)) {
|
| InsertBefore(call,
|
| - new(Z) CheckSmiInstr(new(Z) Value(left),
|
| - call->deopt_id(),
|
| - call->token_pos()),
|
| - call->env(),
|
| - FlowGraph::kEffect);
|
| + new (Z) CheckSmiInstr(new (Z) Value(left), call->deopt_id(),
|
| + call->token_pos()),
|
| + call->env(), FlowGraph::kEffect);
|
| InsertBefore(call,
|
| - new(Z) CheckSmiInstr(new(Z) Value(right),
|
| - call->deopt_id(),
|
| - call->token_pos()),
|
| - call->env(),
|
| - FlowGraph::kEffect);
|
| + new (Z) CheckSmiInstr(new (Z) Value(right), call->deopt_id(),
|
| + call->token_pos()),
|
| + call->env(), FlowGraph::kEffect);
|
| cid = kSmiCid;
|
| } else if (HasTwoMintOrSmi(ic_data) &&
|
| FlowGraphCompiler::SupportsUnboxedMints()) {
|
| @@ -763,13 +732,10 @@ bool AotOptimizer::TryReplaceWithEqualityOp(InstanceCallInstr* call,
|
| // call.
|
| return false;
|
| } else {
|
| - InsertBefore(call,
|
| - new(Z) CheckEitherNonSmiInstr(
|
| - new(Z) Value(left),
|
| - new(Z) Value(right),
|
| - call->deopt_id()),
|
| - call->env(),
|
| - FlowGraph::kEffect);
|
| + InsertBefore(call, new (Z) CheckEitherNonSmiInstr(new (Z) Value(left),
|
| + new (Z) Value(right),
|
| + call->deopt_id()),
|
| + call->env(), FlowGraph::kEffect);
|
| cid = kDoubleCid;
|
| }
|
| }
|
| @@ -780,24 +746,15 @@ bool AotOptimizer::TryReplaceWithEqualityOp(InstanceCallInstr* call,
|
| GrowableArray<intptr_t> smi_or_null(2);
|
| smi_or_null.Add(kSmiCid);
|
| smi_or_null.Add(kNullCid);
|
| - if (ICDataHasOnlyReceiverArgumentClassIds(ic_data,
|
| - smi_or_null,
|
| + if (ICDataHasOnlyReceiverArgumentClassIds(ic_data, smi_or_null,
|
| smi_or_null)) {
|
| const ICData& unary_checks_0 =
|
| ICData::ZoneHandle(Z, call->ic_data()->AsUnaryClassChecks());
|
| - AddCheckClass(left,
|
| - unary_checks_0,
|
| - call->deopt_id(),
|
| - call->env(),
|
| - call);
|
| + AddCheckClass(left, unary_checks_0, call->deopt_id(), call->env(), call);
|
|
|
| const ICData& unary_checks_1 =
|
| ICData::ZoneHandle(Z, call->ic_data()->AsUnaryClassChecksForArgNr(1));
|
| - AddCheckClass(right,
|
| - unary_checks_1,
|
| - call->deopt_id(),
|
| - call->env(),
|
| - call);
|
| + AddCheckClass(right, unary_checks_1, call->deopt_id(), call->env(), call);
|
| cid = kSmiCid;
|
| } else {
|
| // Shortcut for equality with null.
|
| @@ -807,12 +764,10 @@ bool AotOptimizer::TryReplaceWithEqualityOp(InstanceCallInstr* call,
|
| ConstantInstr* left_const = left->AsConstant();
|
| if ((right_const != NULL && right_const->value().IsNull()) ||
|
| (left_const != NULL && left_const->value().IsNull())) {
|
| - StrictCompareInstr* comp =
|
| - new(Z) StrictCompareInstr(call->token_pos(),
|
| - Token::kEQ_STRICT,
|
| - new(Z) Value(left),
|
| - new(Z) Value(right),
|
| - false); // No number check.
|
| + StrictCompareInstr* comp = new (Z)
|
| + StrictCompareInstr(call->token_pos(), Token::kEQ_STRICT,
|
| + new (Z) Value(left), new (Z) Value(right),
|
| + false); // No number check.
|
| ReplaceCall(call, comp);
|
| return true;
|
| }
|
| @@ -820,12 +775,9 @@ bool AotOptimizer::TryReplaceWithEqualityOp(InstanceCallInstr* call,
|
| }
|
| }
|
| ASSERT(cid != kIllegalCid);
|
| - EqualityCompareInstr* comp = new(Z) EqualityCompareInstr(call->token_pos(),
|
| - op_kind,
|
| - new(Z) Value(left),
|
| - new(Z) Value(right),
|
| - cid,
|
| - call->deopt_id());
|
| + EqualityCompareInstr* comp = new (Z)
|
| + EqualityCompareInstr(call->token_pos(), op_kind, new (Z) Value(left),
|
| + new (Z) Value(right), cid, call->deopt_id());
|
| ReplaceCall(call, comp);
|
| return true;
|
| }
|
| @@ -843,17 +795,13 @@ bool AotOptimizer::TryReplaceWithRelationalOp(InstanceCallInstr* call,
|
| intptr_t cid = kIllegalCid;
|
| if (HasOnlyTwoOf(ic_data, kSmiCid)) {
|
| InsertBefore(call,
|
| - new(Z) CheckSmiInstr(new(Z) Value(left),
|
| - call->deopt_id(),
|
| - call->token_pos()),
|
| - call->env(),
|
| - FlowGraph::kEffect);
|
| + new (Z) CheckSmiInstr(new (Z) Value(left), call->deopt_id(),
|
| + call->token_pos()),
|
| + call->env(), FlowGraph::kEffect);
|
| InsertBefore(call,
|
| - new(Z) CheckSmiInstr(new(Z) Value(right),
|
| - call->deopt_id(),
|
| - call->token_pos()),
|
| - call->env(),
|
| - FlowGraph::kEffect);
|
| + new (Z) CheckSmiInstr(new (Z) Value(right), call->deopt_id(),
|
| + call->token_pos()),
|
| + call->env(), FlowGraph::kEffect);
|
| cid = kSmiCid;
|
| } else if (HasTwoMintOrSmi(ic_data) &&
|
| FlowGraphCompiler::SupportsUnboxedMints()) {
|
| @@ -868,13 +816,10 @@ bool AotOptimizer::TryReplaceWithRelationalOp(InstanceCallInstr* call,
|
| // call.
|
| return false;
|
| } else {
|
| - InsertBefore(call,
|
| - new(Z) CheckEitherNonSmiInstr(
|
| - new(Z) Value(left),
|
| - new(Z) Value(right),
|
| - call->deopt_id()),
|
| - call->env(),
|
| - FlowGraph::kEffect);
|
| + InsertBefore(call, new (Z) CheckEitherNonSmiInstr(new (Z) Value(left),
|
| + new (Z) Value(right),
|
| + call->deopt_id()),
|
| + call->env(), FlowGraph::kEffect);
|
| cid = kDoubleCid;
|
| }
|
| }
|
| @@ -882,12 +827,9 @@ bool AotOptimizer::TryReplaceWithRelationalOp(InstanceCallInstr* call,
|
| return false;
|
| }
|
| ASSERT(cid != kIllegalCid);
|
| - RelationalOpInstr* comp = new(Z) RelationalOpInstr(call->token_pos(),
|
| - op_kind,
|
| - new(Z) Value(left),
|
| - new(Z) Value(right),
|
| - cid,
|
| - call->deopt_id());
|
| + RelationalOpInstr* comp =
|
| + new (Z) RelationalOpInstr(call->token_pos(), op_kind, new (Z) Value(left),
|
| + new (Z) Value(right), cid, call->deopt_id());
|
| ReplaceCall(call, comp);
|
| return true;
|
| }
|
| @@ -906,8 +848,8 @@ bool AotOptimizer::TryReplaceWithBinaryOp(InstanceCallInstr* call,
|
| // Don't generate smi code if the IC data is marked because
|
| // of an overflow.
|
| operands_type = ic_data.HasDeoptReason(ICData::kDeoptBinarySmiOp)
|
| - ? kMintCid
|
| - : kSmiCid;
|
| + ? kMintCid
|
| + : kSmiCid;
|
| } else if (HasTwoMintOrSmi(ic_data) &&
|
| FlowGraphCompiler::SupportsUnboxedMints()) {
|
| // Don't generate mint code if the IC data is marked because of an
|
| @@ -963,11 +905,11 @@ bool AotOptimizer::TryReplaceWithBinaryOp(InstanceCallInstr* call,
|
| return false;
|
| }
|
| operands_type = ic_data.HasDeoptReason(ICData::kDeoptBinarySmiOp)
|
| - ? kMintCid
|
| - : kSmiCid;
|
| + ? kMintCid
|
| + : kSmiCid;
|
| } else if (HasTwoMintOrSmi(ic_data) &&
|
| - HasOnlyOneSmi(ICData::Handle(Z,
|
| - ic_data.AsUnaryClassChecksForArgNr(1)))) {
|
| + HasOnlyOneSmi(ICData::Handle(
|
| + Z, ic_data.AsUnaryClassChecksForArgNr(1)))) {
|
| // Don't generate mint code if the IC data is marked because of an
|
| // overflow.
|
| if (ic_data.HasDeoptReason(ICData::kDeoptBinaryMintOp)) {
|
| @@ -1006,34 +948,25 @@ bool AotOptimizer::TryReplaceWithBinaryOp(InstanceCallInstr* call,
|
| // binary operation with two smis is a smi not a double, except '/' which
|
| // returns a double for two smis.
|
| if (op_kind != Token::kDIV) {
|
| - InsertBefore(call,
|
| - new(Z) CheckEitherNonSmiInstr(
|
| - new(Z) Value(left),
|
| - new(Z) Value(right),
|
| - call->deopt_id()),
|
| - call->env(),
|
| - FlowGraph::kEffect);
|
| + InsertBefore(call, new (Z) CheckEitherNonSmiInstr(new (Z) Value(left),
|
| + new (Z) Value(right),
|
| + call->deopt_id()),
|
| + call->env(), FlowGraph::kEffect);
|
| }
|
|
|
| - BinaryDoubleOpInstr* double_bin_op =
|
| - new(Z) BinaryDoubleOpInstr(op_kind,
|
| - new(Z) Value(left),
|
| - new(Z) Value(right),
|
| - call->deopt_id(), call->token_pos());
|
| + BinaryDoubleOpInstr* double_bin_op = new (Z)
|
| + BinaryDoubleOpInstr(op_kind, new (Z) Value(left), new (Z) Value(right),
|
| + call->deopt_id(), call->token_pos());
|
| ReplaceCall(call, double_bin_op);
|
| } else if (operands_type == kMintCid) {
|
| if (!FlowGraphCompiler::SupportsUnboxedMints()) return false;
|
| if ((op_kind == Token::kSHR) || (op_kind == Token::kSHL)) {
|
| - ShiftMintOpInstr* shift_op =
|
| - new(Z) ShiftMintOpInstr(
|
| - op_kind, new(Z) Value(left), new(Z) Value(right),
|
| - call->deopt_id());
|
| + ShiftMintOpInstr* shift_op = new (Z) ShiftMintOpInstr(
|
| + op_kind, new (Z) Value(left), new (Z) Value(right), call->deopt_id());
|
| ReplaceCall(call, shift_op);
|
| } else {
|
| - BinaryMintOpInstr* bin_op =
|
| - new(Z) BinaryMintOpInstr(
|
| - op_kind, new(Z) Value(left), new(Z) Value(right),
|
| - call->deopt_id());
|
| + BinaryMintOpInstr* bin_op = new (Z) BinaryMintOpInstr(
|
| + op_kind, new (Z) Value(left), new (Z) Value(right), call->deopt_id());
|
| ReplaceCall(call, bin_op);
|
| }
|
| } else if (operands_type == kFloat32x4Cid) {
|
| @@ -1050,19 +983,14 @@ bool AotOptimizer::TryReplaceWithBinaryOp(InstanceCallInstr* call,
|
| // Insert smi check and attach a copy of the original environment
|
| // because the smi operation can still deoptimize.
|
| InsertBefore(call,
|
| - new(Z) CheckSmiInstr(new(Z) Value(left),
|
| - call->deopt_id(),
|
| - call->token_pos()),
|
| - call->env(),
|
| - FlowGraph::kEffect);
|
| - ConstantInstr* constant =
|
| - flow_graph()->GetConstant(Smi::Handle(Z,
|
| - Smi::New(Smi::Cast(obj).Value() - 1)));
|
| + new (Z) CheckSmiInstr(new (Z) Value(left),
|
| + call->deopt_id(), call->token_pos()),
|
| + call->env(), FlowGraph::kEffect);
|
| + ConstantInstr* constant = flow_graph()->GetConstant(
|
| + Smi::Handle(Z, Smi::New(Smi::Cast(obj).Value() - 1)));
|
| BinarySmiOpInstr* bin_op =
|
| - new(Z) BinarySmiOpInstr(Token::kBIT_AND,
|
| - new(Z) Value(left),
|
| - new(Z) Value(constant),
|
| - call->deopt_id());
|
| + new (Z) BinarySmiOpInstr(Token::kBIT_AND, new (Z) Value(left),
|
| + new (Z) Value(constant), call->deopt_id());
|
| ReplaceCall(call, bin_op);
|
| return true;
|
| }
|
| @@ -1071,11 +999,8 @@ bool AotOptimizer::TryReplaceWithBinaryOp(InstanceCallInstr* call,
|
| // environment because the smi operation can still deoptimize.
|
| AddCheckSmi(left, call->deopt_id(), call->env(), call);
|
| AddCheckSmi(right, call->deopt_id(), call->env(), call);
|
| - BinarySmiOpInstr* bin_op =
|
| - new(Z) BinarySmiOpInstr(op_kind,
|
| - new(Z) Value(left),
|
| - new(Z) Value(right),
|
| - call->deopt_id());
|
| + BinarySmiOpInstr* bin_op = new (Z) BinarySmiOpInstr(
|
| + op_kind, new (Z) Value(left), new (Z) Value(right), call->deopt_id());
|
| ReplaceCall(call, bin_op);
|
| } else {
|
| ASSERT(operands_type == kSmiCid);
|
| @@ -1090,12 +1015,8 @@ bool AotOptimizer::TryReplaceWithBinaryOp(InstanceCallInstr* call,
|
| left = right;
|
| right = temp;
|
| }
|
| - BinarySmiOpInstr* bin_op =
|
| - new(Z) BinarySmiOpInstr(
|
| - op_kind,
|
| - new(Z) Value(left),
|
| - new(Z) Value(right),
|
| - call->deopt_id());
|
| + BinarySmiOpInstr* bin_op = new (Z) BinarySmiOpInstr(
|
| + op_kind, new (Z) Value(left), new (Z) Value(right), call->deopt_id());
|
| ReplaceCall(call, bin_op);
|
| }
|
| return true;
|
| @@ -1109,24 +1030,21 @@ bool AotOptimizer::TryReplaceWithUnaryOp(InstanceCallInstr* call,
|
| Definition* unary_op = NULL;
|
| if (HasOnlyOneSmi(*call->ic_data())) {
|
| InsertBefore(call,
|
| - new(Z) CheckSmiInstr(new(Z) Value(input),
|
| - call->deopt_id(),
|
| - call->token_pos()),
|
| - call->env(),
|
| - FlowGraph::kEffect);
|
| - unary_op = new(Z) UnarySmiOpInstr(
|
| - op_kind, new(Z) Value(input), call->deopt_id());
|
| + new (Z) CheckSmiInstr(new (Z) Value(input), call->deopt_id(),
|
| + call->token_pos()),
|
| + call->env(), FlowGraph::kEffect);
|
| + unary_op = new (Z)
|
| + UnarySmiOpInstr(op_kind, new (Z) Value(input), call->deopt_id());
|
| } else if ((op_kind == Token::kBIT_NOT) &&
|
| HasOnlySmiOrMint(*call->ic_data()) &&
|
| FlowGraphCompiler::SupportsUnboxedMints()) {
|
| - unary_op = new(Z) UnaryMintOpInstr(
|
| - op_kind, new(Z) Value(input), call->deopt_id());
|
| + unary_op = new (Z)
|
| + UnaryMintOpInstr(op_kind, new (Z) Value(input), call->deopt_id());
|
| } else if (HasOnlyOneDouble(*call->ic_data()) &&
|
| - (op_kind == Token::kNEGATE) &&
|
| - CanUnboxDouble()) {
|
| + (op_kind == Token::kNEGATE) && CanUnboxDouble()) {
|
| AddReceiverCheck(call);
|
| - unary_op = new(Z) UnaryDoubleOpInstr(
|
| - Token::kNEGATE, new(Z) Value(input), call->deopt_id());
|
| + unary_op = new (Z) UnaryDoubleOpInstr(Token::kNEGATE, new (Z) Value(input),
|
| + call->deopt_id());
|
| } else {
|
| return false;
|
| }
|
| @@ -1137,8 +1055,7 @@ bool AotOptimizer::TryReplaceWithUnaryOp(InstanceCallInstr* call,
|
|
|
|
|
| // Using field class
|
| -RawField* AotOptimizer::GetField(intptr_t class_id,
|
| - const String& field_name) {
|
| +RawField* AotOptimizer::GetField(intptr_t class_id, const String& field_name) {
|
| Class& cls = Class::Handle(Z, isolate()->class_table()->At(class_id));
|
| Field& field = Field::Handle(Z);
|
| while (!cls.IsNull()) {
|
| @@ -1162,19 +1079,16 @@ bool AotOptimizer::InlineImplicitInstanceGetter(InstanceCallInstr* call) {
|
| // Inline implicit instance getter.
|
| const String& field_name =
|
| String::Handle(Z, Field::NameFromGetter(call->function_name()));
|
| - const Field& field =
|
| - Field::ZoneHandle(Z, GetField(class_ids[0], field_name));
|
| + const Field& field = Field::ZoneHandle(Z, GetField(class_ids[0], field_name));
|
| ASSERT(!field.IsNull());
|
|
|
| - if (flow_graph()->InstanceCallNeedsClassCheck(
|
| - call, RawFunction::kImplicitGetter)) {
|
| + if (flow_graph()->InstanceCallNeedsClassCheck(call,
|
| + RawFunction::kImplicitGetter)) {
|
| return false;
|
| }
|
| - LoadFieldInstr* load = new(Z) LoadFieldInstr(
|
| - new(Z) Value(call->ArgumentAt(0)),
|
| - &field,
|
| - AbstractType::ZoneHandle(Z, field.type()),
|
| - call->token_pos());
|
| + LoadFieldInstr* load = new (Z) LoadFieldInstr(
|
| + new (Z) Value(call->ArgumentAt(0)), &field,
|
| + AbstractType::ZoneHandle(Z, field.type()), call->token_pos());
|
| load->set_is_immutable(field.is_final());
|
|
|
| // Discard the environment from the original instruction because the load
|
| @@ -1184,9 +1098,7 @@ bool AotOptimizer::InlineImplicitInstanceGetter(InstanceCallInstr* call) {
|
|
|
| if (load->result_cid() != kDynamicCid) {
|
| // Reset value types if guarded_cid was used.
|
| - for (Value::Iterator it(load->input_use_list());
|
| - !it.Done();
|
| - it.Advance()) {
|
| + for (Value::Iterator it(load->input_use_list()); !it.Done(); it.Advance()) {
|
| it.Current()->SetReachingType(NULL);
|
| }
|
| }
|
| @@ -1203,24 +1115,16 @@ bool AotOptimizer::InlineFloat32x4BinaryOp(InstanceCallInstr* call,
|
| Definition* left = call->ArgumentAt(0);
|
| Definition* right = call->ArgumentAt(1);
|
| // Type check left.
|
| - AddCheckClass(left,
|
| - ICData::ZoneHandle(
|
| - Z, call->ic_data()->AsUnaryClassChecksForArgNr(0)),
|
| - call->deopt_id(),
|
| - call->env(),
|
| - call);
|
| + AddCheckClass(left, ICData::ZoneHandle(
|
| + Z, call->ic_data()->AsUnaryClassChecksForArgNr(0)),
|
| + call->deopt_id(), call->env(), call);
|
| // Type check right.
|
| - AddCheckClass(right,
|
| - ICData::ZoneHandle(
|
| - Z, call->ic_data()->AsUnaryClassChecksForArgNr(1)),
|
| - call->deopt_id(),
|
| - call->env(),
|
| - call);
|
| + AddCheckClass(right, ICData::ZoneHandle(
|
| + Z, call->ic_data()->AsUnaryClassChecksForArgNr(1)),
|
| + call->deopt_id(), call->env(), call);
|
| // Replace call.
|
| - BinaryFloat32x4OpInstr* float32x4_bin_op =
|
| - new(Z) BinaryFloat32x4OpInstr(
|
| - op_kind, new(Z) Value(left), new(Z) Value(right),
|
| - call->deopt_id());
|
| + BinaryFloat32x4OpInstr* float32x4_bin_op = new (Z) BinaryFloat32x4OpInstr(
|
| + op_kind, new (Z) Value(left), new (Z) Value(right), call->deopt_id());
|
| ReplaceCall(call, float32x4_bin_op);
|
|
|
| return true;
|
| @@ -1236,24 +1140,16 @@ bool AotOptimizer::InlineInt32x4BinaryOp(InstanceCallInstr* call,
|
| Definition* left = call->ArgumentAt(0);
|
| Definition* right = call->ArgumentAt(1);
|
| // Type check left.
|
| - AddCheckClass(left,
|
| - ICData::ZoneHandle(
|
| - Z, call->ic_data()->AsUnaryClassChecksForArgNr(0)),
|
| - call->deopt_id(),
|
| - call->env(),
|
| - call);
|
| + AddCheckClass(left, ICData::ZoneHandle(
|
| + Z, call->ic_data()->AsUnaryClassChecksForArgNr(0)),
|
| + call->deopt_id(), call->env(), call);
|
| // Type check right.
|
| - AddCheckClass(right,
|
| - ICData::ZoneHandle(Z,
|
| - call->ic_data()->AsUnaryClassChecksForArgNr(1)),
|
| - call->deopt_id(),
|
| - call->env(),
|
| - call);
|
| + AddCheckClass(right, ICData::ZoneHandle(
|
| + Z, call->ic_data()->AsUnaryClassChecksForArgNr(1)),
|
| + call->deopt_id(), call->env(), call);
|
| // Replace call.
|
| - BinaryInt32x4OpInstr* int32x4_bin_op =
|
| - new(Z) BinaryInt32x4OpInstr(
|
| - op_kind, new(Z) Value(left), new(Z) Value(right),
|
| - call->deopt_id());
|
| + BinaryInt32x4OpInstr* int32x4_bin_op = new (Z) BinaryInt32x4OpInstr(
|
| + op_kind, new (Z) Value(left), new (Z) Value(right), call->deopt_id());
|
| ReplaceCall(call, int32x4_bin_op);
|
| return true;
|
| }
|
| @@ -1268,24 +1164,16 @@ bool AotOptimizer::InlineFloat64x2BinaryOp(InstanceCallInstr* call,
|
| Definition* left = call->ArgumentAt(0);
|
| Definition* right = call->ArgumentAt(1);
|
| // Type check left.
|
| - AddCheckClass(left,
|
| - ICData::ZoneHandle(
|
| - call->ic_data()->AsUnaryClassChecksForArgNr(0)),
|
| - call->deopt_id(),
|
| - call->env(),
|
| - call);
|
| + AddCheckClass(
|
| + left, ICData::ZoneHandle(call->ic_data()->AsUnaryClassChecksForArgNr(0)),
|
| + call->deopt_id(), call->env(), call);
|
| // Type check right.
|
| - AddCheckClass(right,
|
| - ICData::ZoneHandle(
|
| - call->ic_data()->AsUnaryClassChecksForArgNr(1)),
|
| - call->deopt_id(),
|
| - call->env(),
|
| - call);
|
| + AddCheckClass(
|
| + right, ICData::ZoneHandle(call->ic_data()->AsUnaryClassChecksForArgNr(1)),
|
| + call->deopt_id(), call->env(), call);
|
| // Replace call.
|
| - BinaryFloat64x2OpInstr* float64x2_bin_op =
|
| - new(Z) BinaryFloat64x2OpInstr(
|
| - op_kind, new(Z) Value(left), new(Z) Value(right),
|
| - call->deopt_id());
|
| + BinaryFloat64x2OpInstr* float64x2_bin_op = new (Z) BinaryFloat64x2OpInstr(
|
| + op_kind, new (Z) Value(left), new (Z) Value(right), call->deopt_id());
|
| ReplaceCall(call, float64x2_bin_op);
|
| return true;
|
| }
|
| @@ -1321,15 +1209,12 @@ void AotOptimizer::ReplaceWithMathCFunction(
|
| MethodRecognizer::Kind recognized_kind) {
|
| AddReceiverCheck(call);
|
| ZoneGrowableArray<Value*>* args =
|
| - new(Z) ZoneGrowableArray<Value*>(call->ArgumentCount());
|
| + new (Z) ZoneGrowableArray<Value*>(call->ArgumentCount());
|
| for (intptr_t i = 0; i < call->ArgumentCount(); i++) {
|
| - args->Add(new(Z) Value(call->ArgumentAt(i)));
|
| + args->Add(new (Z) Value(call->ArgumentAt(i)));
|
| }
|
| - InvokeMathCFunctionInstr* invoke =
|
| - new(Z) InvokeMathCFunctionInstr(args,
|
| - call->deopt_id(),
|
| - recognized_kind,
|
| - call->token_pos());
|
| + InvokeMathCFunctionInstr* invoke = new (Z) InvokeMathCFunctionInstr(
|
| + args, call->deopt_id(), recognized_kind, call->token_pos());
|
| ReplaceCall(call, invoke);
|
| }
|
|
|
| @@ -1354,15 +1239,14 @@ bool AotOptimizer::TryInlineInstanceMethod(InstanceCallInstr* call) {
|
| if (class_ids[0] == kSmiCid) {
|
| AddReceiverCheck(call);
|
| ReplaceCall(call,
|
| - new(Z) SmiToDoubleInstr(
|
| - new(Z) Value(call->ArgumentAt(0)),
|
| - call->token_pos()));
|
| + new (Z) SmiToDoubleInstr(new (Z) Value(call->ArgumentAt(0)),
|
| + call->token_pos()));
|
| return true;
|
| } else if ((class_ids[0] == kMintCid) && CanConvertUnboxedMintToDouble()) {
|
| AddReceiverCheck(call);
|
| ReplaceCall(call,
|
| - new(Z) MintToDoubleInstr(new(Z) Value(call->ArgumentAt(0)),
|
| - call->deopt_id()));
|
| + new (Z) MintToDoubleInstr(new (Z) Value(call->ArgumentAt(0)),
|
| + call->deopt_id()));
|
| return true;
|
| }
|
| }
|
| @@ -1380,12 +1264,11 @@ bool AotOptimizer::TryInlineInstanceMethod(InstanceCallInstr* call) {
|
| Definition* d2i_instr = NULL;
|
| if (ic_data.HasDeoptReason(ICData::kDeoptDoubleToSmi)) {
|
| // Do not repeatedly deoptimize because result didn't fit into Smi.
|
| - d2i_instr = new(Z) DoubleToIntegerInstr(
|
| - new(Z) Value(input), call);
|
| + d2i_instr = new (Z) DoubleToIntegerInstr(new (Z) Value(input), call);
|
| } else {
|
| // Optimistically assume result fits into Smi.
|
| - d2i_instr = new(Z) DoubleToSmiInstr(
|
| - new(Z) Value(input), call->deopt_id());
|
| + d2i_instr =
|
| + new (Z) DoubleToSmiInstr(new (Z) Value(input), call->deopt_id());
|
| }
|
| ReplaceCall(call, d2i_instr);
|
| return true;
|
| @@ -1402,8 +1285,8 @@ bool AotOptimizer::TryInlineInstanceMethod(InstanceCallInstr* call) {
|
| } else {
|
| AddReceiverCheck(call);
|
| DoubleToDoubleInstr* d2d_instr =
|
| - new(Z) DoubleToDoubleInstr(new(Z) Value(call->ArgumentAt(0)),
|
| - recognized_kind, call->deopt_id());
|
| + new (Z) DoubleToDoubleInstr(new (Z) Value(call->ArgumentAt(0)),
|
| + recognized_kind, call->deopt_id());
|
| ReplaceCall(call, d2d_instr);
|
| }
|
| return true;
|
| @@ -1444,7 +1327,7 @@ RawBool* AotOptimizer::InstanceOfAsBool(
|
| const TypeArguments& type_arguments =
|
| TypeArguments::Handle(Z, type.arguments());
|
| const bool is_raw_type = type_arguments.IsNull() ||
|
| - type_arguments.IsRaw(from_index, num_type_params);
|
| + type_arguments.IsRaw(from_index, num_type_params);
|
| if (!is_raw_type) {
|
| // Unknown result.
|
| return Bool::null();
|
| @@ -1461,13 +1344,9 @@ RawBool* AotOptimizer::InstanceOfAsBool(
|
| if (cls.NumTypeArguments() > 0) {
|
| return Bool::null();
|
| }
|
| - const bool is_subtype = cls.IsSubtypeOf(
|
| - TypeArguments::Handle(Z),
|
| - type_class,
|
| - TypeArguments::Handle(Z),
|
| - NULL,
|
| - NULL,
|
| - Heap::kOld);
|
| + const bool is_subtype =
|
| + cls.IsSubtypeOf(TypeArguments::Handle(Z), type_class,
|
| + TypeArguments::Handle(Z), NULL, NULL, Heap::kOld);
|
| results->Add(cls.id());
|
| results->Add(is_subtype);
|
| if (prev.IsNull()) {
|
| @@ -1478,7 +1357,7 @@ RawBool* AotOptimizer::InstanceOfAsBool(
|
| }
|
| }
|
| }
|
| - return results_differ ? Bool::null() : prev.raw();
|
| + return results_differ ? Bool::null() : prev.raw();
|
| }
|
|
|
|
|
| @@ -1501,7 +1380,8 @@ bool AotOptimizer::TypeCheckAsClassEquality(const AbstractType& type) {
|
| if (!type_class.IsPrivate()) {
|
| if (isolate()->all_classes_finalized()) {
|
| if (FLAG_trace_cha) {
|
| - THR_Print(" **(CHA) Typecheck as class equality since no "
|
| + THR_Print(
|
| + " **(CHA) Typecheck as class equality since no "
|
| "subclasses: %s\n",
|
| type_class.ToCString());
|
| }
|
| @@ -1519,7 +1399,7 @@ bool AotOptimizer::TypeCheckAsClassEquality(const AbstractType& type) {
|
| const TypeArguments& type_arguments =
|
| TypeArguments::Handle(type.arguments());
|
| const bool is_raw_type = type_arguments.IsNull() ||
|
| - type_arguments.IsRaw(from_index, num_type_params);
|
| + type_arguments.IsRaw(from_index, num_type_params);
|
| return is_raw_type;
|
| }
|
| return true;
|
| @@ -1555,12 +1435,9 @@ static bool TryExpandTestCidsResult(ZoneGrowableArray<intptr_t>* results,
|
| if ((*results)[0] != kSmiCid) {
|
| const Class& cls = Class::Handle(class_table.At(kSmiCid));
|
| const Class& type_class = Class::Handle(type.type_class());
|
| - const bool smi_is_subtype = cls.IsSubtypeOf(TypeArguments::Handle(),
|
| - type_class,
|
| - TypeArguments::Handle(),
|
| - NULL,
|
| - NULL,
|
| - Heap::kOld);
|
| + const bool smi_is_subtype =
|
| + cls.IsSubtypeOf(TypeArguments::Handle(), type_class,
|
| + TypeArguments::Handle(), NULL, NULL, Heap::kOld);
|
| results->Add((*results)[results->length() - 2]);
|
| results->Add((*results)[results->length() - 2]);
|
| for (intptr_t i = results->length() - 3; i > 1; --i) {
|
| @@ -1627,30 +1504,31 @@ void AotOptimizer::ReplaceWithInstanceOf(InstanceCallInstr* call) {
|
| } else {
|
| UNIMPLEMENTED();
|
| }
|
| - negate = Bool::Cast(call->ArgumentAt(1)->OriginalDefinition()
|
| - ->AsConstant()->value()).value();
|
| + negate =
|
| + Bool::Cast(
|
| + call->ArgumentAt(1)->OriginalDefinition()->AsConstant()->value())
|
| + .value();
|
| }
|
| } else {
|
| type_args = call->ArgumentAt(1);
|
| type = AbstractType::Cast(call->ArgumentAt(2)->AsConstant()->value()).raw();
|
| - negate = Bool::Cast(call->ArgumentAt(3)->OriginalDefinition()
|
| - ->AsConstant()->value()).value();
|
| + negate =
|
| + Bool::Cast(
|
| + call->ArgumentAt(3)->OriginalDefinition()->AsConstant()->value())
|
| + .value();
|
| }
|
|
|
| if (TypeCheckAsClassEquality(type)) {
|
| - LoadClassIdInstr* left_cid = new(Z) LoadClassIdInstr(new(Z) Value(left));
|
| + LoadClassIdInstr* left_cid = new (Z) LoadClassIdInstr(new (Z) Value(left));
|
| InsertBefore(call, left_cid, NULL, FlowGraph::kValue);
|
| const intptr_t type_cid = Class::Handle(Z, type.type_class()).id();
|
| ConstantInstr* cid =
|
| flow_graph()->GetConstant(Smi::Handle(Z, Smi::New(type_cid)));
|
|
|
| - StrictCompareInstr* check_cid =
|
| - new(Z) StrictCompareInstr(
|
| - call->token_pos(),
|
| - negate ? Token::kNE_STRICT : Token::kEQ_STRICT,
|
| - new(Z) Value(left_cid),
|
| - new(Z) Value(cid),
|
| - false); // No number check.
|
| + StrictCompareInstr* check_cid = new (Z) StrictCompareInstr(
|
| + call->token_pos(), negate ? Token::kNE_STRICT : Token::kEQ_STRICT,
|
| + new (Z) Value(left_cid), new (Z) Value(cid),
|
| + false); // No number check.
|
| ReplaceCall(call, check_cid);
|
| return;
|
| }
|
| @@ -1662,7 +1540,7 @@ void AotOptimizer::ReplaceWithInstanceOf(InstanceCallInstr* call) {
|
| // left.instanceof(type) =>
|
| // _classRangeCheck(left.cid, lower_limit, upper_limit)
|
|
|
| - LoadClassIdInstr* left_cid = new(Z) LoadClassIdInstr(new(Z) Value(left));
|
| + LoadClassIdInstr* left_cid = new (Z) LoadClassIdInstr(new (Z) Value(left));
|
| InsertBefore(call, left_cid, NULL, FlowGraph::kValue);
|
| ConstantInstr* lower_cid =
|
| flow_graph()->GetConstant(Smi::Handle(Z, Smi::New(lower_limit)));
|
| @@ -1670,7 +1548,7 @@ void AotOptimizer::ReplaceWithInstanceOf(InstanceCallInstr* call) {
|
| flow_graph()->GetConstant(Smi::Handle(Z, Smi::New(upper_limit)));
|
|
|
| ZoneGrowableArray<PushArgumentInstr*>* args =
|
| - new(Z) ZoneGrowableArray<PushArgumentInstr*>(3);
|
| + new (Z) ZoneGrowableArray<PushArgumentInstr*>(3);
|
| PushArgumentInstr* arg = new (Z) PushArgumentInstr(new (Z) Value(left_cid));
|
| InsertBefore(call, arg, NULL, FlowGraph::kEffect);
|
| args->Add(arg);
|
| @@ -1685,17 +1563,15 @@ void AotOptimizer::ReplaceWithInstanceOf(InstanceCallInstr* call) {
|
| Library::Handle(Z, Library::InternalLibrary());
|
| const String& target_name = negate ? Symbols::_classRangeCheckNegative()
|
| : Symbols::_classRangeCheck();
|
| - const Function& target = Function::ZoneHandle(Z,
|
| - dart_internal.LookupFunctionAllowPrivate(target_name));
|
| + const Function& target = Function::ZoneHandle(
|
| + Z, dart_internal.LookupFunctionAllowPrivate(target_name));
|
| ASSERT(!target.IsNull());
|
| ASSERT(target.IsRecognized() && target.always_inline());
|
|
|
| - StaticCallInstr* new_call = new (Z) StaticCallInstr(
|
| - call->token_pos(),
|
| - target,
|
| - Object::null_array(), // argument_names
|
| - args,
|
| - call->deopt_id());
|
| + StaticCallInstr* new_call =
|
| + new (Z) StaticCallInstr(call->token_pos(), target,
|
| + Object::null_array(), // argument_names
|
| + args, call->deopt_id());
|
| ReplaceCall(call, new_call);
|
| return;
|
| }
|
| @@ -1705,7 +1581,7 @@ void AotOptimizer::ReplaceWithInstanceOf(InstanceCallInstr* call) {
|
| if ((unary_checks.NumberOfChecks() > 0) &&
|
| (unary_checks.NumberOfChecks() <= FLAG_max_polymorphic_checks)) {
|
| ZoneGrowableArray<intptr_t>* results =
|
| - new(Z) ZoneGrowableArray<intptr_t>(unary_checks.NumberOfChecks() * 2);
|
| + new (Z) ZoneGrowableArray<intptr_t>(unary_checks.NumberOfChecks() * 2);
|
| InstanceOfAsBool(unary_checks, type, results);
|
| if (results->length() == unary_checks.NumberOfChecks() * 2) {
|
| const bool can_deopt = TryExpandTestCidsResult(results, type);
|
| @@ -1713,25 +1589,19 @@ void AotOptimizer::ReplaceWithInstanceOf(InstanceCallInstr* call) {
|
| // Guard against repeated speculative inlining.
|
| return;
|
| }
|
| - TestCidsInstr* test_cids = new(Z) TestCidsInstr(
|
| - call->token_pos(),
|
| - negate ? Token::kISNOT : Token::kIS,
|
| - new(Z) Value(left),
|
| - *results,
|
| - can_deopt ? call->deopt_id() : Thread::kNoDeoptId);
|
| + TestCidsInstr* test_cids = new (Z)
|
| + TestCidsInstr(call->token_pos(), negate ? Token::kISNOT : Token::kIS,
|
| + new (Z) Value(left), *results,
|
| + can_deopt ? call->deopt_id() : Thread::kNoDeoptId);
|
| // Remove type.
|
| ReplaceCall(call, test_cids);
|
| return;
|
| }
|
| }
|
|
|
| - InstanceOfInstr* instance_of =
|
| - new(Z) InstanceOfInstr(call->token_pos(),
|
| - new(Z) Value(left),
|
| - new(Z) Value(type_args),
|
| - type,
|
| - negate,
|
| - call->deopt_id());
|
| + InstanceOfInstr* instance_of = new (Z)
|
| + InstanceOfInstr(call->token_pos(), new (Z) Value(left),
|
| + new (Z) Value(type_args), type, negate, call->deopt_id());
|
| ReplaceCall(call, instance_of);
|
| }
|
|
|
| @@ -1749,9 +1619,9 @@ void AotOptimizer::ReplaceWithTypeCast(InstanceCallInstr* call) {
|
| if ((unary_checks.NumberOfChecks() > 0) &&
|
| (unary_checks.NumberOfChecks() <= FLAG_max_polymorphic_checks)) {
|
| ZoneGrowableArray<intptr_t>* results =
|
| - new(Z) ZoneGrowableArray<intptr_t>(unary_checks.NumberOfChecks() * 2);
|
| - const Bool& as_bool = Bool::ZoneHandle(Z,
|
| - InstanceOfAsBool(unary_checks, type, results));
|
| + new (Z) ZoneGrowableArray<intptr_t>(unary_checks.NumberOfChecks() * 2);
|
| + const Bool& as_bool =
|
| + Bool::ZoneHandle(Z, InstanceOfAsBool(unary_checks, type, results));
|
| if (as_bool.raw() == Bool::True().raw()) {
|
| // Guard against repeated speculative inlining.
|
| if (!IsAllowedForInlining(call->deopt_id())) {
|
| @@ -1771,13 +1641,9 @@ void AotOptimizer::ReplaceWithTypeCast(InstanceCallInstr* call) {
|
| return;
|
| }
|
| }
|
| - AssertAssignableInstr* assert_as =
|
| - new(Z) AssertAssignableInstr(call->token_pos(),
|
| - new(Z) Value(left),
|
| - new(Z) Value(type_args),
|
| - type,
|
| - Symbols::InTypeCast(),
|
| - call->deopt_id());
|
| + AssertAssignableInstr* assert_as = new (Z) AssertAssignableInstr(
|
| + call->token_pos(), new (Z) Value(left), new (Z) Value(type_args), type,
|
| + Symbols::InTypeCast(), call->deopt_id());
|
| ReplaceCall(call, assert_as);
|
| }
|
|
|
| @@ -1818,8 +1684,7 @@ bool AotOptimizer::TryInlineFieldAccess(InstanceCallInstr* call) {
|
|
|
| const ICData& unary_checks =
|
| ICData::Handle(Z, call->ic_data()->AsUnaryClassChecks());
|
| - if ((unary_checks.NumberOfChecks() > 0) &&
|
| - (op_kind == Token::kSET) &&
|
| + if ((unary_checks.NumberOfChecks() > 0) && (op_kind == Token::kSET) &&
|
| TryInlineInstanceSetter(call, unary_checks)) {
|
| return true;
|
| }
|
| @@ -1896,8 +1761,7 @@ void AotOptimizer::VisitInstanceCall(InstanceCallInstr* instr) {
|
| if (has_one_target) {
|
| // Check if the single target is a polymorphic target, if it is,
|
| // we don't have one target.
|
| - const Function& target =
|
| - Function::Handle(Z, unary_checks.GetTargetAt(0));
|
| + const Function& target = Function::Handle(Z, unary_checks.GetTargetAt(0));
|
| const bool polymorphic_target = MethodRecognizer::PolymorphicTarget(target);
|
| has_one_target = !polymorphic_target;
|
| }
|
| @@ -1905,12 +1769,11 @@ void AotOptimizer::VisitInstanceCall(InstanceCallInstr* instr) {
|
| if (has_one_target) {
|
| RawFunction::Kind function_kind =
|
| Function::Handle(Z, unary_checks.GetTargetAt(0)).kind();
|
| - if (!flow_graph()->InstanceCallNeedsClassCheck(
|
| - instr, function_kind)) {
|
| + if (!flow_graph()->InstanceCallNeedsClassCheck(instr, function_kind)) {
|
| PolymorphicInstanceCallInstr* call =
|
| - new(Z) PolymorphicInstanceCallInstr(instr, unary_checks,
|
| - /* with_checks = */ false,
|
| - /* complete = */ true);
|
| + new (Z) PolymorphicInstanceCallInstr(instr, unary_checks,
|
| + /* with_checks = */ false,
|
| + /* complete = */ true);
|
| instr->ReplaceWith(call, current_iterator());
|
| return;
|
| }
|
| @@ -1925,11 +1788,9 @@ void AotOptimizer::VisitInstanceCall(InstanceCallInstr* instr) {
|
| HasLikelySmiOperand(instr)) {
|
| Definition* left = instr->ArgumentAt(0);
|
| Definition* right = instr->ArgumentAt(1);
|
| - CheckedSmiComparisonInstr* smi_op =
|
| - new(Z) CheckedSmiComparisonInstr(instr->token_kind(),
|
| - new(Z) Value(left),
|
| - new(Z) Value(right),
|
| - instr);
|
| + CheckedSmiComparisonInstr* smi_op = new (Z)
|
| + CheckedSmiComparisonInstr(instr->token_kind(), new (Z) Value(left),
|
| + new (Z) Value(right), instr);
|
| ReplaceCall(instr, smi_op);
|
| return;
|
| }
|
| @@ -1946,10 +1807,8 @@ void AotOptimizer::VisitInstanceCall(InstanceCallInstr* instr) {
|
| Definition* left = instr->ArgumentAt(0);
|
| Definition* right = instr->ArgumentAt(1);
|
| CheckedSmiOpInstr* smi_op =
|
| - new(Z) CheckedSmiOpInstr(instr->token_kind(),
|
| - new(Z) Value(left),
|
| - new(Z) Value(right),
|
| - instr);
|
| + new (Z) CheckedSmiOpInstr(instr->token_kind(), new (Z) Value(left),
|
| + new (Z) Value(right), instr);
|
|
|
| ReplaceCall(instr, smi_op);
|
| return;
|
| @@ -1964,31 +1823,26 @@ void AotOptimizer::VisitInstanceCall(InstanceCallInstr* instr) {
|
| const intptr_t receiver_cid =
|
| instr->PushArgumentAt(0)->value()->Type()->ToCid();
|
| if (receiver_cid != kDynamicCid) {
|
| - const Class& receiver_class = Class::Handle(Z,
|
| - isolate()->class_table()->At(receiver_cid));
|
| + const Class& receiver_class =
|
| + Class::Handle(Z, isolate()->class_table()->At(receiver_cid));
|
|
|
| - const Array& args_desc_array = Array::Handle(Z,
|
| - ArgumentsDescriptor::New(instr->ArgumentCount(),
|
| - instr->argument_names()));
|
| + const Array& args_desc_array =
|
| + Array::Handle(Z, ArgumentsDescriptor::New(instr->ArgumentCount(),
|
| + instr->argument_names()));
|
| ArgumentsDescriptor args_desc(args_desc_array);
|
| - const Function& function = Function::Handle(Z,
|
| - Resolver::ResolveDynamicForReceiverClass(
|
| - receiver_class,
|
| - instr->function_name(),
|
| - args_desc));
|
| + const Function& function = Function::Handle(
|
| + Z, Resolver::ResolveDynamicForReceiverClass(
|
| + receiver_class, instr->function_name(), args_desc));
|
| if (!function.IsNull()) {
|
| const ICData& ic_data = ICData::Handle(
|
| - ICData::New(flow_graph_->function(),
|
| - instr->function_name(),
|
| - args_desc_array,
|
| - Thread::kNoDeoptId,
|
| - /* args_tested = */ 1,
|
| - false));
|
| + ICData::New(flow_graph_->function(), instr->function_name(),
|
| + args_desc_array, Thread::kNoDeoptId,
|
| + /* args_tested = */ 1, false));
|
| ic_data.AddReceiverCheck(receiver_class.id(), function);
|
| PolymorphicInstanceCallInstr* call =
|
| - new(Z) PolymorphicInstanceCallInstr(instr, ic_data,
|
| - /* with_checks = */ false,
|
| - /* complete = */ true);
|
| + new (Z) PolymorphicInstanceCallInstr(instr, ic_data,
|
| + /* with_checks = */ false,
|
| + /* complete = */ true);
|
| instr->ReplaceWith(call, current_iterator());
|
| return;
|
| }
|
| @@ -2011,9 +1865,9 @@ void AotOptimizer::VisitInstanceCall(InstanceCallInstr* instr) {
|
| Function& single_target = Function::Handle(Z);
|
| ICData& ic_data = ICData::Handle(Z);
|
|
|
| - const Array& args_desc_array = Array::Handle(Z,
|
| - ArgumentsDescriptor::New(instr->ArgumentCount(),
|
| - instr->argument_names()));
|
| + const Array& args_desc_array =
|
| + Array::Handle(Z, ArgumentsDescriptor::New(instr->ArgumentCount(),
|
| + instr->argument_names()));
|
| ArgumentsDescriptor args_desc(args_desc_array);
|
|
|
| Function& target = Function::Handle(Z);
|
| @@ -2022,9 +1876,7 @@ void AotOptimizer::VisitInstanceCall(InstanceCallInstr* instr) {
|
| const intptr_t cid = class_ids[i];
|
| cls = isolate()->class_table()->At(cid);
|
| target = Resolver::ResolveDynamicForReceiverClass(
|
| - cls,
|
| - instr->function_name(),
|
| - args_desc);
|
| + cls, instr->function_name(), args_desc);
|
|
|
| if (target.IsNull()) {
|
| // Can't resolve the target. It might be a noSuchMethod,
|
| @@ -2051,10 +1903,8 @@ void AotOptimizer::VisitInstanceCall(InstanceCallInstr* instr) {
|
|
|
| // Create an ICData and map all previously seen classes (< i) to
|
| // the computed single_target.
|
| - ic_data = ICData::New(function,
|
| - instr->function_name(),
|
| - args_desc_array,
|
| - Thread::kNoDeoptId,
|
| + ic_data = ICData::New(function, instr->function_name(),
|
| + args_desc_array, Thread::kNoDeoptId,
|
| /* args_tested = */ 1, false);
|
| for (intptr_t j = 0; j < i; j++) {
|
| ic_data.AddReceiverCheck(class_ids[j], single_target);
|
| @@ -2074,12 +1924,9 @@ void AotOptimizer::VisitInstanceCall(InstanceCallInstr* instr) {
|
| if ((op_kind == Token::kGET) || (op_kind == Token::kSET)) {
|
| // Create fake IC data with the resolved target.
|
| const ICData& ic_data = ICData::Handle(
|
| - ICData::New(flow_graph_->function(),
|
| - instr->function_name(),
|
| - args_desc_array,
|
| - Thread::kNoDeoptId,
|
| - /* args_tested = */ 1,
|
| - false));
|
| + ICData::New(flow_graph_->function(), instr->function_name(),
|
| + args_desc_array, Thread::kNoDeoptId,
|
| + /* args_tested = */ 1, false));
|
| cls = single_target.Owner();
|
| ic_data.AddReceiverCheck(cls.id(), single_target);
|
| instr->set_ic_data(&ic_data);
|
| @@ -2091,26 +1938,22 @@ void AotOptimizer::VisitInstanceCall(InstanceCallInstr* instr) {
|
|
|
| // We have computed that there is only a single target for this call
|
| // within the whole hierarchy. Replace InstanceCall with StaticCall.
|
| - ZoneGrowableArray<PushArgumentInstr*>* args =
|
| - new (Z) ZoneGrowableArray<PushArgumentInstr*>(
|
| - instr->ArgumentCount());
|
| + ZoneGrowableArray<PushArgumentInstr*>* args = new (Z)
|
| + ZoneGrowableArray<PushArgumentInstr*>(instr->ArgumentCount());
|
| for (intptr_t i = 0; i < instr->ArgumentCount(); i++) {
|
| args->Add(instr->PushArgumentAt(i));
|
| }
|
| StaticCallInstr* call = new (Z) StaticCallInstr(
|
| - instr->token_pos(),
|
| - Function::ZoneHandle(Z, single_target.raw()),
|
| - instr->argument_names(),
|
| - args,
|
| - instr->deopt_id());
|
| + instr->token_pos(), Function::ZoneHandle(Z, single_target.raw()),
|
| + instr->argument_names(), args, instr->deopt_id());
|
| instr->ReplaceWith(call, current_iterator());
|
| return;
|
| } else if ((ic_data.raw() != ICData::null()) &&
|
| (ic_data.NumberOfChecks() > 0)) {
|
| PolymorphicInstanceCallInstr* call =
|
| - new(Z) PolymorphicInstanceCallInstr(instr, ic_data,
|
| - /* with_checks = */ true,
|
| - /* complete = */ true);
|
| + new (Z) PolymorphicInstanceCallInstr(instr, ic_data,
|
| + /* with_checks = */ true,
|
| + /* complete = */ true);
|
| instr->ReplaceWith(call, current_iterator());
|
| return;
|
| }
|
| @@ -2124,9 +1967,9 @@ void AotOptimizer::VisitInstanceCall(InstanceCallInstr* instr) {
|
| // OK to use checks with PolymorphicInstanceCallInstr since no
|
| // deoptimization is allowed.
|
| PolymorphicInstanceCallInstr* call =
|
| - new(Z) PolymorphicInstanceCallInstr(instr, unary_checks,
|
| - /* with_checks = */ true,
|
| - /* complete = */ false);
|
| + new (Z) PolymorphicInstanceCallInstr(instr, unary_checks,
|
| + /* with_checks = */ true,
|
| + /* complete = */ false);
|
| instr->ReplaceWith(call, current_iterator());
|
| return;
|
| }
|
| @@ -2139,18 +1982,17 @@ void AotOptimizer::VisitPolymorphicInstanceCall(
|
| const intptr_t receiver_cid =
|
| call->PushArgumentAt(0)->value()->Type()->ToCid();
|
| if (receiver_cid != kDynamicCid) {
|
| - const Class& receiver_class = Class::Handle(Z,
|
| - isolate()->class_table()->At(receiver_cid));
|
| + const Class& receiver_class =
|
| + Class::Handle(Z, isolate()->class_table()->At(receiver_cid));
|
|
|
| - const Array& args_desc_array = Array::Handle(Z,
|
| - ArgumentsDescriptor::New(call->ArgumentCount(),
|
| - call->instance_call()->argument_names()));
|
| + const Array& args_desc_array = Array::Handle(
|
| + Z, ArgumentsDescriptor::New(call->ArgumentCount(),
|
| + call->instance_call()->argument_names()));
|
| ArgumentsDescriptor args_desc(args_desc_array);
|
| - const Function& function = Function::Handle(Z,
|
| - Resolver::ResolveDynamicForReceiverClass(
|
| - receiver_class,
|
| - call->instance_call()->function_name(),
|
| - args_desc));
|
| + const Function& function = Function::Handle(
|
| + Z, Resolver::ResolveDynamicForReceiverClass(
|
| + receiver_class, call->instance_call()->function_name(),
|
| + args_desc));
|
| if (!function.IsNull()) {
|
| call->set_with_checks(false);
|
| }
|
| @@ -2195,37 +2037,27 @@ void AotOptimizer::VisitStaticCall(StaticCallInstr* call) {
|
| case MethodRecognizer::kMathMax: {
|
| // We can handle only monomorphic min/max call sites with both arguments
|
| // being either doubles or smis.
|
| - if (CanUnboxDouble() &&
|
| - call->HasICData() &&
|
| + if (CanUnboxDouble() && call->HasICData() &&
|
| (call->ic_data()->NumberOfChecks() == 1)) {
|
| const ICData& ic_data = *call->ic_data();
|
| intptr_t result_cid = kIllegalCid;
|
| - if (ICDataHasReceiverArgumentClassIds(ic_data,
|
| - kDoubleCid, kDoubleCid)) {
|
| + if (ICDataHasReceiverArgumentClassIds(ic_data, kDoubleCid,
|
| + kDoubleCid)) {
|
| result_cid = kDoubleCid;
|
| - } else if (ICDataHasReceiverArgumentClassIds(ic_data,
|
| - kSmiCid, kSmiCid)) {
|
| + } else if (ICDataHasReceiverArgumentClassIds(ic_data, kSmiCid,
|
| + kSmiCid)) {
|
| result_cid = kSmiCid;
|
| }
|
| if (result_cid != kIllegalCid) {
|
| - MathMinMaxInstr* min_max = new(Z) MathMinMaxInstr(
|
| - recognized_kind,
|
| - new(Z) Value(call->ArgumentAt(0)),
|
| - new(Z) Value(call->ArgumentAt(1)),
|
| - call->deopt_id(),
|
| - result_cid);
|
| + MathMinMaxInstr* min_max = new (Z) MathMinMaxInstr(
|
| + recognized_kind, new (Z) Value(call->ArgumentAt(0)),
|
| + new (Z) Value(call->ArgumentAt(1)), call->deopt_id(), result_cid);
|
| const ICData& unary_checks =
|
| ICData::ZoneHandle(Z, ic_data.AsUnaryClassChecks());
|
| - AddCheckClass(min_max->left()->definition(),
|
| - unary_checks,
|
| - call->deopt_id(),
|
| - call->env(),
|
| - call);
|
| - AddCheckClass(min_max->right()->definition(),
|
| - unary_checks,
|
| - call->deopt_id(),
|
| - call->env(),
|
| - call);
|
| + AddCheckClass(min_max->left()->definition(), unary_checks,
|
| + call->deopt_id(), call->env(), call);
|
| + AddCheckClass(min_max->right()->definition(), unary_checks,
|
| + call->deopt_id(), call->env(), call);
|
| ReplaceCall(call, min_max);
|
| }
|
| }
|
| @@ -2238,15 +2070,13 @@ void AotOptimizer::VisitStaticCall(StaticCallInstr* call) {
|
| if (ArgIsAlways(kSmiCid, ic_data, 1)) {
|
| Definition* arg = call->ArgumentAt(1);
|
| AddCheckSmi(arg, call->deopt_id(), call->env(), call);
|
| - ReplaceCall(call,
|
| - new(Z) SmiToDoubleInstr(new(Z) Value(arg),
|
| - call->token_pos()));
|
| + ReplaceCall(call, new (Z) SmiToDoubleInstr(new (Z) Value(arg),
|
| + call->token_pos()));
|
| } else if (ArgIsAlways(kMintCid, ic_data, 1) &&
|
| CanConvertUnboxedMintToDouble()) {
|
| Definition* arg = call->ArgumentAt(1);
|
| - ReplaceCall(call,
|
| - new(Z) MintToDoubleInstr(new(Z) Value(arg),
|
| - call->deopt_id()));
|
| + ReplaceCall(call, new (Z) MintToDoubleInstr(new (Z) Value(arg),
|
| + call->deopt_id()));
|
| }
|
| }
|
| }
|
| @@ -2259,10 +2089,9 @@ void AotOptimizer::VisitStaticCall(StaticCallInstr* call) {
|
|
|
|
|
| void AotOptimizer::VisitLoadCodeUnits(LoadCodeUnitsInstr* instr) {
|
| - // TODO(zerny): Use kUnboxedUint32 once it is fully supported/optimized.
|
| +// TODO(zerny): Use kUnboxedUint32 once it is fully supported/optimized.
|
| #if defined(TARGET_ARCH_IA32) || defined(TARGET_ARCH_ARM)
|
| - if (!instr->can_pack_into_smi())
|
| - instr->set_representation(kUnboxedMint);
|
| + if (!instr->can_pack_into_smi()) instr->set_representation(kUnboxedMint);
|
| #endif
|
| }
|
|
|
| @@ -2270,7 +2099,7 @@ void AotOptimizer::VisitLoadCodeUnits(LoadCodeUnitsInstr* instr) {
|
| bool AotOptimizer::TryInlineInstanceSetter(InstanceCallInstr* instr,
|
| const ICData& unary_ic_data) {
|
| ASSERT((unary_ic_data.NumberOfChecks() > 0) &&
|
| - (unary_ic_data.NumArgsTested() == 1));
|
| + (unary_ic_data.NumArgsTested() == 1));
|
| if (I->type_checks()) {
|
| // Checked mode setters are inlined like normal methods by conventional
|
| // inlining.
|
| @@ -2297,22 +2126,19 @@ bool AotOptimizer::TryInlineInstanceSetter(InstanceCallInstr* instr,
|
| // Inline implicit instance setter.
|
| const String& field_name =
|
| String::Handle(Z, Field::NameFromSetter(instr->function_name()));
|
| - const Field& field =
|
| - Field::ZoneHandle(Z, GetField(class_id, field_name));
|
| + const Field& field = Field::ZoneHandle(Z, GetField(class_id, field_name));
|
| ASSERT(!field.IsNull());
|
|
|
| - if (flow_graph()->InstanceCallNeedsClassCheck(
|
| - instr, RawFunction::kImplicitSetter)) {
|
| + if (flow_graph()->InstanceCallNeedsClassCheck(instr,
|
| + RawFunction::kImplicitSetter)) {
|
| return false;
|
| }
|
|
|
| // Field guard was detached.
|
| - StoreInstanceFieldInstr* store = new(Z) StoreInstanceFieldInstr(
|
| - field,
|
| - new(Z) Value(instr->ArgumentAt(0)),
|
| - new(Z) Value(instr->ArgumentAt(1)),
|
| - kEmitStoreBarrier,
|
| - instr->token_pos());
|
| + StoreInstanceFieldInstr* store = new (Z)
|
| + StoreInstanceFieldInstr(field, new (Z) Value(instr->ArgumentAt(0)),
|
| + new (Z) Value(instr->ArgumentAt(1)),
|
| + kEmitStoreBarrier, instr->token_pos());
|
|
|
| // No unboxed stores in precompiled code.
|
| ASSERT(!store->IsUnboxedStore());
|
| @@ -2327,19 +2153,17 @@ bool AotOptimizer::TryInlineInstanceSetter(InstanceCallInstr* instr,
|
|
|
| void AotOptimizer::ReplaceArrayBoundChecks() {
|
| for (BlockIterator block_it = flow_graph_->reverse_postorder_iterator();
|
| - !block_it.Done();
|
| - block_it.Advance()) {
|
| + !block_it.Done(); block_it.Advance()) {
|
| ForwardInstructionIterator it(block_it.Current());
|
| current_iterator_ = ⁢
|
| for (; !it.Done(); it.Advance()) {
|
| CheckArrayBoundInstr* check = it.Current()->AsCheckArrayBound();
|
| if (check != NULL) {
|
| - GenericCheckBoundInstr* new_check = new(Z) GenericCheckBoundInstr(
|
| - new(Z) Value(check->length()->definition()),
|
| - new(Z) Value(check->index()->definition()),
|
| - check->deopt_id());
|
| - flow_graph_->InsertBefore(check, new_check,
|
| - check->env(), FlowGraph::kEffect);
|
| + GenericCheckBoundInstr* new_check = new (Z) GenericCheckBoundInstr(
|
| + new (Z) Value(check->length()->definition()),
|
| + new (Z) Value(check->index()->definition()), check->deopt_id());
|
| + flow_graph_->InsertBefore(check, new_check, check->env(),
|
| + FlowGraph::kEffect);
|
| current_iterator()->RemoveCurrentFromGraph();
|
| }
|
| }
|
|
|