Reviewers: Sven Panne, jarin, alph,

Message:
PTAL

Description:
CpuProfiler: ia32. put right address to the stack, so the callee would be able
to resolve it into the right deopt_info.

'from' is using for Code object lookup and will be used for
inline_id lookup. see https://codereview.chromium.org/1012633002
So we should be able to map it. Unfortunately I found no better
way to do that. This trick is much simpler on arm like platforms
because they use a special register for the return address.

BUG=chromium:452067
LOG=n

Please review this at https://codereview.chromium.org/1014783002/

Base URL: https://chromium.googlesource.com/v8/v8.git@master

Affected files (+26, -28 lines):
  M src/ia32/lithium-codegen-ia32.cc


Index: src/ia32/lithium-codegen-ia32.cc
diff --git a/src/ia32/lithium-codegen-ia32.cc b/src/ia32/lithium-codegen-ia32.cc index 979c5029bec18c07b3026f92ba5db35ced34e0bf..a09e0c5cab03964ec01ebb2b35fe022b1e0f0cb9 100644
--- a/src/ia32/lithium-codegen-ia32.cc
+++ b/src/ia32/lithium-codegen-ia32.cc
@@ -377,10 +377,11 @@ void LCodeGen::GenerateBodyInstructionPost(LInstruction* instr) { }


 bool LCodeGen::GenerateJumpTable() {
+  if (!jump_table_.length()) return !is_aborted();
+
   Label needs_frame;
-  if (jump_table_.length() > 0) {
-    Comment(";;; -------------------- Jump table --------------------");
-  }
+  Comment(";;; -------------------- Jump table --------------------");
+
   for (int i = 0; i < jump_table_.length(); i++) {
     Deoptimizer::JumpTableEntry* table_entry = &jump_table_[i];
     __ bind(&table_entry->label);
@@ -388,36 +389,33 @@ bool LCodeGen::GenerateJumpTable() {
     DeoptComment(table_entry->deopt_info);
     if (table_entry->needs_frame) {
       DCHECK(!info()->saves_caller_doubles());
-      __ push(Immediate(ExternalReference::ForDeoptEntry(entry)));
-      if (needs_frame.is_bound()) {
-        __ jmp(&needs_frame);
-      } else {
-        __ bind(&needs_frame);
-        __ push(MemOperand(ebp, StandardFrameConstants::kContextOffset));
- // This variant of deopt can only be used with stubs. Since we don't
-        // have a function pointer to install in the stack frame that we're
-        // building, install a special marker there instead.
-        DCHECK(info()->IsStub());
-        __ push(Immediate(Smi::FromInt(StackFrame::STUB)));
- // Push a PC inside the function so that the deopt code can find where
-        // the deopt comes from. It doesn't have to be the precise return
-        // address of a "calling" LAZY deopt, it only has to be somewhere
-        // inside the code body.
-        Label push_approx_pc;
-        __ call(&push_approx_pc);
-        __ bind(&push_approx_pc);
-        // Push the continuation which was stashed were the ebp should
-        // be. Replace it with the saved ebp.
-        __ push(MemOperand(esp, 3 * kPointerSize));
-        __ mov(MemOperand(esp, 4 * kPointerSize), ebp);
-        __ lea(ebp, MemOperand(esp, 4 * kPointerSize));
-        __ ret(0);  // Call the continuation without clobbering registers.
-      }
+      // Put deopt entry to the place where it will be used by ret(0)
+      __ mov(MemOperand(esp, -5 * kPointerSize),
+             Immediate(ExternalReference::ForDeoptEntry(entry)));
+      // Save pc to the stack for 'from' argument of deoptimizer.
+      __ call(&needs_frame);
     } else {
       if (info()->saves_caller_doubles()) RestoreCallerDoubles();
       __ call(entry, RelocInfo::RUNTIME_ENTRY);
     }
   }
+  if (needs_frame.is_linked()) {
+    __ bind(&needs_frame);
+    __ push(MemOperand(ebp, StandardFrameConstants::kContextOffset));
+    // This variant of deopt can only be used with stubs. Since we don't
+    // have a function pointer to install in the stack frame that we're
+    // building, install a special marker there instead.
+    DCHECK(info()->IsStub());
+    __ push(Immediate(Smi::FromInt(StackFrame::STUB)));
+ // Copy the saved pc to the place where it would be used by Deoptimizer.
+    __ push(MemOperand(esp, 2 * kPointerSize));
+    // Replace the original saved pc in the stack with ebp.
+    __ mov(MemOperand(esp, 3 * kPointerSize), ebp);
+    __ lea(ebp, MemOperand(esp, 3 * kPointerSize));
+    // Move esp on top of entry address that has been saved earlier.
+    __ sub(esp, Immediate(kPointerSize));
+    __ ret(0);  // Call the continuation without clobbering registers.
+  }
   return !is_aborted();
 }



--
--
v8-dev mailing list
v8-dev@googlegroups.com
http://groups.google.com/group/v8-dev
--- You received this message because you are subscribed to the Google Groups "v8-dev" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to v8-dev+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to