Ignore:
Timestamp:
Nov 13, 2013, 11:39:30 PM (12 years ago)
Author:
[email protected]
Message:

Change callToJavaScript thunk into an offline assembled stub
https://bugs.webkit.org/show_bug.cgi?id=124251

Reviewed by Geoffrey Garen.

Changed callToJavaScript and throwNotCaught into stubs generated by the offline assembler.
Added popCalleeSaves and pushCalleeSaves pseudo ops to the offline assembler to handle
the saving and restoring of callee save registers. Fixed callFrameRegister differences
between arm traditional (r11) and arm Thumb2 (r7) in GPRInfo.h. Also fixed implementation
of pop & push in arm.rb.

Since the offline assembler and therefore the LLInt don't work on Windows, the Windows stubs
are handled as inline assembly in JITStubsX86.h and JITStubsMSVC64.asm.

  • dfg/DFGDriver.cpp:

(JSC::DFG::compileImpl):

  • jit/GPRInfo.h:

(JSC::GPRInfo::toIndex):
(JSC::GPRInfo::debugName):

  • jit/JITCode.cpp:

(JSC::JITCode::execute):

  • jit/JITExceptions.cpp:

(JSC::genericUnwind):

  • jit/JITStubs.h:
  • jit/JITStubsMSVC64.asm:
  • jit/JITStubsX86.h:
  • jit/ThunkGenerators.cpp:
  • jit/ThunkGenerators.h:
  • llint/LLIntThunks.h:
  • llint/LowLevelInterpreter.asm:
  • llint/LowLevelInterpreter32_64.asm:
  • llint/LowLevelInterpreter64.asm:
  • offlineasm/arm.rb:
  • offlineasm/arm64.rb:
  • offlineasm/instructions.rb:
  • offlineasm/mips.rb:
  • offlineasm/registers.rb:
  • offlineasm/sh4.rb:
  • offlineasm/x86.rb:
  • runtime/VM.cpp:

(JSC::VM::VM):

  • runtime/VM.h:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/Source/JavaScriptCore/jit/JITExceptions.cpp

    r158751 r159276  
    3131#include "CodeBlock.h"
    3232#include "Interpreter.h"
     33#include "JITStubs.h"
    3334#include "JSCJSValue.h"
     35#include "LLIntThunks.h"
    3436#include "VM.h"
    3537#include "Operations.h"
     
    5052        catchRoutine = ExecutableBase::catchRoutineFor(handler, catchPCForInterpreter);
    5153    } else
    52         catchRoutine = vm->getCTIStub(throwNotCaught).code().executableAddress();
     54        catchRoutine = FunctionPtr(LLInt::getCodePtr(returnFromJavaScript)).value();
    5355   
    5456    vm->callFrameForThrow = callFrame;
Note: See TracChangeset for help on using the changeset viewer.