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

Side by Side Diff: src/mips/deoptimizer-mips.cc

Issue 1120753010: MIPS: Fix long branch mode and FPU branches. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Fixed typo. Created 5 years, 7 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
« no previous file with comments | « src/mips/constants-mips.h ('k') | src/mips/lithium-codegen-mips.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 1
2 // Copyright 2011 the V8 project authors. All rights reserved. 2 // Copyright 2011 the V8 project authors. All rights reserved.
3 // Use of this source code is governed by a BSD-style license that can be 3 // Use of this source code is governed by a BSD-style license that can be
4 // found in the LICENSE file. 4 // found in the LICENSE file.
5 5
6 #include "src/v8.h" 6 #include "src/v8.h"
7 7
8 #include "src/codegen.h" 8 #include "src/codegen.h"
9 #include "src/deoptimizer.h" 9 #include "src/deoptimizer.h"
10 #include "src/full-codegen.h" 10 #include "src/full-codegen.h"
(...skipping 250 matching lines...) Expand 10 before | Expand all | Expand 10 after
261 261
262 // Replace the current (input) frame with the output frames. 262 // Replace the current (input) frame with the output frames.
263 Label outer_push_loop, inner_push_loop, 263 Label outer_push_loop, inner_push_loop,
264 outer_loop_header, inner_loop_header; 264 outer_loop_header, inner_loop_header;
265 // Outer loop state: t0 = current "FrameDescription** output_", 265 // Outer loop state: t0 = current "FrameDescription** output_",
266 // a1 = one past the last FrameDescription**. 266 // a1 = one past the last FrameDescription**.
267 __ lw(a1, MemOperand(a0, Deoptimizer::output_count_offset())); 267 __ lw(a1, MemOperand(a0, Deoptimizer::output_count_offset()));
268 __ lw(t0, MemOperand(a0, Deoptimizer::output_offset())); // t0 is output_. 268 __ lw(t0, MemOperand(a0, Deoptimizer::output_offset())); // t0 is output_.
269 __ sll(a1, a1, kPointerSizeLog2); // Count to offset. 269 __ sll(a1, a1, kPointerSizeLog2); // Count to offset.
270 __ addu(a1, t0, a1); // a1 = one past the last FrameDescription**. 270 __ addu(a1, t0, a1); // a1 = one past the last FrameDescription**.
271 __ jmp(&outer_loop_header); 271 __ BranchShort(&outer_loop_header);
272 __ bind(&outer_push_loop); 272 __ bind(&outer_push_loop);
273 // Inner loop state: a2 = current FrameDescription*, a3 = loop index. 273 // Inner loop state: a2 = current FrameDescription*, a3 = loop index.
274 __ lw(a2, MemOperand(t0, 0)); // output_[ix] 274 __ lw(a2, MemOperand(t0, 0)); // output_[ix]
275 __ lw(a3, MemOperand(a2, FrameDescription::frame_size_offset())); 275 __ lw(a3, MemOperand(a2, FrameDescription::frame_size_offset()));
276 __ jmp(&inner_loop_header); 276 __ BranchShort(&inner_loop_header);
277 __ bind(&inner_push_loop); 277 __ bind(&inner_push_loop);
278 __ Subu(a3, a3, Operand(sizeof(uint32_t))); 278 __ Subu(a3, a3, Operand(sizeof(uint32_t)));
279 __ Addu(t2, a2, Operand(a3)); 279 __ Addu(t2, a2, Operand(a3));
280 __ lw(t3, MemOperand(t2, FrameDescription::frame_content_offset())); 280 __ lw(t3, MemOperand(t2, FrameDescription::frame_content_offset()));
281 __ push(t3); 281 __ push(t3);
282 __ bind(&inner_loop_header); 282 __ bind(&inner_loop_header);
283 __ BranchShort(&inner_push_loop, ne, a3, Operand(zero_reg)); 283 __ BranchShort(&inner_push_loop, ne, a3, Operand(zero_reg));
284 284
285 __ Addu(t0, t0, Operand(kPointerSize)); 285 __ Addu(t0, t0, Operand(kPointerSize));
286 __ bind(&outer_loop_header); 286 __ bind(&outer_loop_header);
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after
336 __ bind(&table_start); 336 __ bind(&table_start);
337 int kMaxEntriesBranchReach = (1 << (kImm16Bits - 2))/ 337 int kMaxEntriesBranchReach = (1 << (kImm16Bits - 2))/
338 (table_entry_size_ / Assembler::kInstrSize); 338 (table_entry_size_ / Assembler::kInstrSize);
339 339
340 if (count() <= kMaxEntriesBranchReach) { 340 if (count() <= kMaxEntriesBranchReach) {
341 // Common case. 341 // Common case.
342 for (int i = 0; i < count(); i++) { 342 for (int i = 0; i < count(); i++) {
343 Label start; 343 Label start;
344 __ bind(&start); 344 __ bind(&start);
345 DCHECK(is_int16(i)); 345 DCHECK(is_int16(i));
346 __ Branch(USE_DELAY_SLOT, &done); // Expose delay slot. 346 __ BranchShort(USE_DELAY_SLOT, &done); // Expose delay slot.
347 __ li(at, i); // In the delay slot. 347 __ li(at, i); // In the delay slot.
348 348
349 DCHECK_EQ(table_entry_size_, masm()->SizeOfCodeGeneratedSince(&start)); 349 DCHECK_EQ(table_entry_size_, masm()->SizeOfCodeGeneratedSince(&start));
350 } 350 }
351 351
352 DCHECK_EQ(masm()->SizeOfCodeGeneratedSince(&table_start), 352 DCHECK_EQ(masm()->SizeOfCodeGeneratedSince(&table_start),
353 count() * table_entry_size_); 353 count() * table_entry_size_);
354 __ bind(&done); 354 __ bind(&done);
355 __ Push(at); 355 __ Push(at);
356 } else { 356 } else {
357 // Uncommon case, the branch cannot reach. 357 // Uncommon case, the branch cannot reach.
358 // Create mini trampoline and adjust id constants to get proper value at 358 // Create mini trampoline and adjust id constants to get proper value at
359 // the end of table. 359 // the end of table.
360 for (int i = kMaxEntriesBranchReach; i > 1; i--) { 360 for (int i = kMaxEntriesBranchReach; i > 1; i--) {
361 Label start; 361 Label start;
362 __ bind(&start); 362 __ bind(&start);
363 DCHECK(is_int16(i)); 363 DCHECK(is_int16(i));
364 __ Branch(USE_DELAY_SLOT, &trampoline_jump); // Expose delay slot. 364 __ BranchShort(USE_DELAY_SLOT, &trampoline_jump); // Expose delay slot.
365 __ li(at, - i); // In the delay slot. 365 __ li(at, - i); // In the delay slot.
366 DCHECK_EQ(table_entry_size_, masm()->SizeOfCodeGeneratedSince(&start)); 366 DCHECK_EQ(table_entry_size_, masm()->SizeOfCodeGeneratedSince(&start));
367 } 367 }
368 // Entry with id == kMaxEntriesBranchReach - 1. 368 // Entry with id == kMaxEntriesBranchReach - 1.
369 __ bind(&trampoline_jump); 369 __ bind(&trampoline_jump);
370 __ Branch(USE_DELAY_SLOT, &done_special); 370 __ BranchShort(USE_DELAY_SLOT, &done_special);
371 __ li(at, -1); 371 __ li(at, -1);
372 372
373 for (int i = kMaxEntriesBranchReach ; i < count(); i++) { 373 for (int i = kMaxEntriesBranchReach ; i < count(); i++) {
374 Label start; 374 Label start;
375 __ bind(&start); 375 __ bind(&start);
376 DCHECK(is_int16(i)); 376 DCHECK(is_int16(i));
377 __ Branch(USE_DELAY_SLOT, &done); // Expose delay slot. 377 __ BranchShort(USE_DELAY_SLOT, &done); // Expose delay slot.
378 __ li(at, i); // In the delay slot. 378 __ li(at, i); // In the delay slot.
379 } 379 }
380 380
381 DCHECK_EQ(masm()->SizeOfCodeGeneratedSince(&table_start), 381 DCHECK_EQ(masm()->SizeOfCodeGeneratedSince(&table_start),
382 count() * table_entry_size_); 382 count() * table_entry_size_);
383 __ bind(&done_special); 383 __ bind(&done_special);
384 __ addiu(at, at, kMaxEntriesBranchReach); 384 __ addiu(at, at, kMaxEntriesBranchReach);
385 __ bind(&done); 385 __ bind(&done);
386 __ Push(at); 386 __ Push(at);
387 } 387 }
(...skipping 13 matching lines...) Expand all
401 void FrameDescription::SetCallerConstantPool(unsigned offset, intptr_t value) { 401 void FrameDescription::SetCallerConstantPool(unsigned offset, intptr_t value) {
402 // No out-of-line constant pool support. 402 // No out-of-line constant pool support.
403 UNREACHABLE(); 403 UNREACHABLE();
404 } 404 }
405 405
406 406
407 #undef __ 407 #undef __
408 408
409 409
410 } } // namespace v8::internal 410 } } // namespace v8::internal
OLDNEW
« no previous file with comments | « src/mips/constants-mips.h ('k') | src/mips/lithium-codegen-mips.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698