Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(307)

Side by Side Diff: src/ppc/lithium-codegen-ppc.cc

Issue 1092353002: [strong] Disallow implicit conversions for binary arithmetic operations (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: cl feedback 5 Created 5 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2014 the V8 project authors. All rights reserved. 1 // Copyright 2014 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "src/v8.h" 5 #include "src/v8.h"
6 6
7 #include "src/base/bits.h" 7 #include "src/base/bits.h"
8 #include "src/code-factory.h" 8 #include "src/code-factory.h"
9 #include "src/code-stubs.h" 9 #include "src/code-stubs.h"
10 #include "src/cpu-profiler.h" 10 #include "src/cpu-profiler.h"
(...skipping 2175 matching lines...) Expand 10 before | Expand all | Expand 10 after
2186 } 2186 }
2187 } 2187 }
2188 2188
2189 2189
2190 void LCodeGen::DoArithmeticT(LArithmeticT* instr) { 2190 void LCodeGen::DoArithmeticT(LArithmeticT* instr) {
2191 DCHECK(ToRegister(instr->context()).is(cp)); 2191 DCHECK(ToRegister(instr->context()).is(cp));
2192 DCHECK(ToRegister(instr->left()).is(r4)); 2192 DCHECK(ToRegister(instr->left()).is(r4));
2193 DCHECK(ToRegister(instr->right()).is(r3)); 2193 DCHECK(ToRegister(instr->right()).is(r3));
2194 DCHECK(ToRegister(instr->result()).is(r3)); 2194 DCHECK(ToRegister(instr->result()).is(r3));
2195 2195
2196 Handle<Code> code = CodeFactory::BinaryOpIC(isolate(), instr->op()).code(); 2196 Handle<Code> code = CodeFactory::BinaryOpIC(
2197 isolate(), instr->op(), language_mode()).code();
2197 CallCode(code, RelocInfo::CODE_TARGET, instr); 2198 CallCode(code, RelocInfo::CODE_TARGET, instr);
2198 } 2199 }
2199 2200
2200 2201
2201 template <class InstrType> 2202 template <class InstrType>
2202 void LCodeGen::EmitBranch(InstrType instr, Condition cond, CRegister cr) { 2203 void LCodeGen::EmitBranch(InstrType instr, Condition cond, CRegister cr) {
2203 int left_block = instr->TrueDestination(chunk_); 2204 int left_block = instr->TrueDestination(chunk_);
2204 int right_block = instr->FalseDestination(chunk_); 2205 int right_block = instr->FalseDestination(chunk_);
2205 2206
2206 int next_block = GetNextEmittedBlock(); 2207 int next_block = GetNextEmittedBlock();
(...skipping 3968 matching lines...) Expand 10 before | Expand all | Expand 10 after
6175 __ Push(scope_info); 6176 __ Push(scope_info);
6176 __ push(ToRegister(instr->function())); 6177 __ push(ToRegister(instr->function()));
6177 CallRuntime(Runtime::kPushBlockContext, 2, instr); 6178 CallRuntime(Runtime::kPushBlockContext, 2, instr);
6178 RecordSafepoint(Safepoint::kNoLazyDeopt); 6179 RecordSafepoint(Safepoint::kNoLazyDeopt);
6179 } 6180 }
6180 6181
6181 6182
6182 #undef __ 6183 #undef __
6183 } 6184 }
6184 } // namespace v8::internal 6185 } // namespace v8::internal
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698