OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 548 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
559 return; | 559 return; |
560 } | 560 } |
561 | 561 |
562 if (FLAG_deopt_every_n_times != 0) { | 562 if (FLAG_deopt_every_n_times != 0) { |
563 Handle<SharedFunctionInfo> shared(info_->shared_info()); | 563 Handle<SharedFunctionInfo> shared(info_->shared_info()); |
564 Label no_deopt; | 564 Label no_deopt; |
565 __ pushfd(); | 565 __ pushfd(); |
566 __ push(eax); | 566 __ push(eax); |
567 __ push(ebx); | 567 __ push(ebx); |
568 __ mov(ebx, shared); | 568 __ mov(ebx, shared); |
569 __ mov(eax, FieldOperand(ebx, SharedFunctionInfo::kDeoptCounterOffset)); | 569 __ mov(eax, |
| 570 FieldOperand(ebx, SharedFunctionInfo::kStressDeoptCounterOffset)); |
570 __ sub(Operand(eax), Immediate(Smi::FromInt(1))); | 571 __ sub(Operand(eax), Immediate(Smi::FromInt(1))); |
571 __ j(not_zero, &no_deopt, Label::kNear); | 572 __ j(not_zero, &no_deopt, Label::kNear); |
572 if (FLAG_trap_on_deopt) __ int3(); | 573 if (FLAG_trap_on_deopt) __ int3(); |
573 __ mov(eax, Immediate(Smi::FromInt(FLAG_deopt_every_n_times))); | 574 __ mov(eax, Immediate(Smi::FromInt(FLAG_deopt_every_n_times))); |
574 __ mov(FieldOperand(ebx, SharedFunctionInfo::kDeoptCounterOffset), eax); | 575 __ mov(FieldOperand(ebx, SharedFunctionInfo::kStressDeoptCounterOffset), |
| 576 eax); |
575 __ pop(ebx); | 577 __ pop(ebx); |
576 __ pop(eax); | 578 __ pop(eax); |
577 __ popfd(); | 579 __ popfd(); |
578 __ jmp(entry, RelocInfo::RUNTIME_ENTRY); | 580 __ jmp(entry, RelocInfo::RUNTIME_ENTRY); |
579 | 581 |
580 __ bind(&no_deopt); | 582 __ bind(&no_deopt); |
581 __ mov(FieldOperand(ebx, SharedFunctionInfo::kDeoptCounterOffset), eax); | 583 __ mov(FieldOperand(ebx, SharedFunctionInfo::kStressDeoptCounterOffset), |
| 584 eax); |
582 __ pop(ebx); | 585 __ pop(ebx); |
583 __ pop(eax); | 586 __ pop(eax); |
584 __ popfd(); | 587 __ popfd(); |
585 } | 588 } |
586 | 589 |
587 if (cc == no_condition) { | 590 if (cc == no_condition) { |
588 if (FLAG_trap_on_deopt) __ int3(); | 591 if (FLAG_trap_on_deopt) __ int3(); |
589 __ jmp(entry, RelocInfo::RUNTIME_ENTRY); | 592 __ jmp(entry, RelocInfo::RUNTIME_ENTRY); |
590 } else { | 593 } else { |
591 if (FLAG_trap_on_deopt) { | 594 if (FLAG_trap_on_deopt) { |
(...skipping 4512 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
5104 FixedArray::kHeaderSize - kPointerSize)); | 5107 FixedArray::kHeaderSize - kPointerSize)); |
5105 __ bind(&done); | 5108 __ bind(&done); |
5106 } | 5109 } |
5107 | 5110 |
5108 | 5111 |
5109 #undef __ | 5112 #undef __ |
5110 | 5113 |
5111 } } // namespace v8::internal | 5114 } } // namespace v8::internal |
5112 | 5115 |
5113 #endif // V8_TARGET_ARCH_IA32 | 5116 #endif // V8_TARGET_ARCH_IA32 |
OLD | NEW |