Merge branch 'master' of github.com:ReadyTalk/avian

This commit is contained in:
Joel Dice 2012-06-26 10:50:22 -06:00
commit a96f34709c
7 changed files with 147 additions and 126 deletions

View File

@ -192,6 +192,8 @@ common-cflags = $(warnings) -fno-rtti -fno-exceptions \
-DUSE_ATOMIC_OPERATIONS -DAVIAN_JAVA_HOME=\"$(javahome)\" \ -DUSE_ATOMIC_OPERATIONS -DAVIAN_JAVA_HOME=\"$(javahome)\" \
-DAVIAN_EMBED_PREFIX=\"$(embed-prefix)\" $(target-cflags) -DAVIAN_EMBED_PREFIX=\"$(embed-prefix)\" $(target-cflags)
asmflags = $(target-cflags)
ifneq (,$(filter i386 x86_64,$(arch))) ifneq (,$(filter i386 x86_64,$(arch)))
ifeq ($(use-frame-pointer),true) ifeq ($(use-frame-pointer),true)
common-cflags += -fno-omit-frame-pointer -DAVIAN_USE_FRAME_POINTER common-cflags += -fno-omit-frame-pointer -DAVIAN_USE_FRAME_POINTER

View File

@ -9,6 +9,7 @@
details. */ details. */
#include "types.h" #include "types.h"
#include "target-fields.h"
.text .text
@ -22,14 +23,6 @@
# define GLOBAL(x) x # define GLOBAL(x) x
#endif #endif
#define THREAD_STACK 2148
#define THREAD_SCRATCH 2156
#define THREAD_CONTINUATION 2160
#define THREAD_EXCEPTION 44
#define THREAD_EXCEPTION_STACK_ADJUSTMENT 2164
#define THREAD_EXCEPTION_OFFSET 2168
#define THREAD_EXCEPTION_HANDLER 2172
#define CONTINUATION_NEXT 4 #define CONTINUATION_NEXT 4
#define CONTINUATION_ADDRESS 16 #define CONTINUATION_ADDRESS 16
#define CONTINUATION_RETURN_ADDRESS_OFFSET 20 #define CONTINUATION_RETURN_ADDRESS_OFFSET 20
@ -57,7 +50,7 @@ GLOBAL(vmInvoke):
ldr r4, [sp, #4] ldr r4, [sp, #4]
str r4, [sp, #-4]! str r4, [sp, #-4]!
str sp, [r0, #THREAD_SCRATCH] str sp, [r0, #TARGET_THREAD_SCRATCH]
// align stack, if necessary // align stack, if necessary
eor r4, sp, r3 eor r4, sp, r3
@ -88,7 +81,7 @@ LOCAL(vmInvoke_argumentTest):
.align 2 .align 2
GLOBAL(vmInvoke_returnAddress): GLOBAL(vmInvoke_returnAddress):
// restore stack pointer // restore stack pointer
ldr sp, [r8, #THREAD_SCRATCH] ldr sp, [r8, #TARGET_THREAD_SCRATCH]
// clear MyThread::stack to avoid confusing another thread calling // clear MyThread::stack to avoid confusing another thread calling
// java.lang.Thread.getStackTrace on this one. See // java.lang.Thread.getStackTrace on this one. See
@ -96,7 +89,7 @@ GLOBAL(vmInvoke_returnAddress):
// a reliable stack trace from a thread that might be interrupted at // a reliable stack trace from a thread that might be interrupted at
// any point in its execution. // any point in its execution.
mov r5, #0 mov r5, #0
str r5, [r8, #THREAD_STACK] str r5, [r8, #TARGET_THREAD_STACK]
.globl GLOBAL(vmInvoke_safeStack) .globl GLOBAL(vmInvoke_safeStack)
.align 2 .align 2
@ -104,7 +97,7 @@ GLOBAL(vmInvoke_safeStack):
#ifdef AVIAN_CONTINUATIONS #ifdef AVIAN_CONTINUATIONS
// call the next continuation, if any // call the next continuation, if any
ldr r5,[r8,#THREAD_CONTINUATION] ldr r5,[r8,#TARGET_THREAD_CONTINUATION]
cmp r5,#0 cmp r5,#0
beq LOCAL(vmInvoke_exit) beq LOCAL(vmInvoke_exit)
@ -138,10 +131,10 @@ LOCAL(vmInvoke_getAddress):
str r11,[sp,r7] str r11,[sp,r7]
ldr r7,[r5,#CONTINUATION_NEXT] ldr r7,[r5,#CONTINUATION_NEXT]
str r7,[r8,#THREAD_CONTINUATION] str r7,[r8,#TARGET_THREAD_CONTINUATION]
// call the continuation unless we're handling an exception // call the continuation unless we're handling an exception
ldr r7,[r8,#THREAD_EXCEPTION] ldr r7,[r8,#TARGET_THREAD_EXCEPTION]
cmp r7,#0 cmp r7,#0
bne LOCAL(vmInvoke_handleException) bne LOCAL(vmInvoke_handleException)
ldr r7,[r5,#CONTINUATION_ADDRESS] ldr r7,[r5,#CONTINUATION_ADDRESS]
@ -150,22 +143,22 @@ LOCAL(vmInvoke_getAddress):
LOCAL(vmInvoke_handleException): LOCAL(vmInvoke_handleException):
// we're handling an exception - call the exception handler instead // we're handling an exception - call the exception handler instead
mov r11,#0 mov r11,#0
str r11,[r8,#THREAD_EXCEPTION] str r11,[r8,#TARGET_THREAD_EXCEPTION]
ldr r11,[r8,#THREAD_EXCEPTION_STACK_ADJUSTMENT] ldr r11,[r8,#TARGET_THREAD_EXCEPTIONSTACKADJUSTMENT]
ldr r9,[sp] ldr r9,[sp]
neg r11,r11 neg r11,r11
str r9,[sp,r11]! str r9,[sp,r11]!
ldr r11,[r8,#THREAD_EXCEPTION_OFFSET] ldr r11,[r8,#TARGET_THREAD_EXCEPTIONOFFSET]
str r7,[sp,r11] str r7,[sp,r11]
ldr r7,[r8,#THREAD_EXCEPTION_HANDLER] ldr r7,[r8,#TARGET_THREAD_EXCEPTIONHANDLER]
bx r7 bx r7
LOCAL(vmInvoke_exit): LOCAL(vmInvoke_exit):
#endif // AVIAN_CONTINUATIONS #endif // AVIAN_CONTINUATIONS
mov ip, #0 mov ip, #0
str ip, [r8, #THREAD_STACK] str ip, [r8, #TARGET_THREAD_STACK]
// restore return type // restore return type
ldr ip, [sp], #4 ldr ip, [sp], #4

View File

@ -9,6 +9,7 @@
details. */ details. */
#include "types.h" #include "types.h"
#include "target-fields.h"
.text .text
@ -29,13 +30,6 @@
#define ARGUMENT_BASE BYTES_PER_WORD * LINKAGE_AREA #define ARGUMENT_BASE BYTES_PER_WORD * LINKAGE_AREA
#define THREAD_STACK 2148
#define THREAD_CONTINUATION 2160
#define THREAD_EXCEPTION 44
#define THREAD_EXCEPTION_STACK_ADJUSTMENT 2164
#define THREAD_EXCEPTION_OFFSET 2168
#define THREAD_EXCEPTION_HANDLER 2172
#define CONTINUATION_NEXT 4 #define CONTINUATION_NEXT 4
#define CONTINUATION_ADDRESS 16 #define CONTINUATION_ADDRESS 16
#define CONTINUATION_RETURN_ADDRESS_OFFSET 20 #define CONTINUATION_RETURN_ADDRESS_OFFSET 20
@ -121,14 +115,14 @@ GLOBAL(vmInvoke_returnAddress):
// a reliable stack trace from a thread that might be interrupted at // a reliable stack trace from a thread that might be interrupted at
// any point in its execution. // any point in its execution.
li r5,0 li r5,0
stw r5,THREAD_STACK(r13) stw r5,TARGET_THREAD_STACK(r13)
.globl GLOBAL(vmInvoke_safeStack) .globl GLOBAL(vmInvoke_safeStack)
GLOBAL(vmInvoke_safeStack): GLOBAL(vmInvoke_safeStack):
#ifdef AVIAN_CONTINUATIONS #ifdef AVIAN_CONTINUATIONS
// call the next continuation, if any // call the next continuation, if any
lwz r5,THREAD_CONTINUATION(r13) lwz r5,TARGET_THREAD_CONTINUATION(r13)
cmplwi r5,0 cmplwi r5,0
beq LOCAL(vmInvoke_exit) beq LOCAL(vmInvoke_exit)
@ -171,10 +165,10 @@ LOCAL(vmInvoke_getPC):
stw r7,0(r1) stw r7,0(r1)
lwz r7,CONTINUATION_NEXT(r5) lwz r7,CONTINUATION_NEXT(r5)
stw r7,THREAD_CONTINUATION(r13) stw r7,TARGET_THREAD_CONTINUATION(r13)
// call the continuation unless we're handling an exception // call the continuation unless we're handling an exception
lwz r7,THREAD_EXCEPTION(r13) lwz r7,TARGET_THREAD_EXCEPTION(r13)
cmpwi r7,0 cmpwi r7,0
bne LOCAL(vmInvoke_handleException) bne LOCAL(vmInvoke_handleException)
lwz r7,CONTINUATION_ADDRESS(r5) lwz r7,CONTINUATION_ADDRESS(r5)
@ -184,15 +178,15 @@ LOCAL(vmInvoke_getPC):
LOCAL(vmInvoke_handleException): LOCAL(vmInvoke_handleException):
// we're handling an exception - call the exception handler instead // we're handling an exception - call the exception handler instead
li r8,0 li r8,0
stw r8,THREAD_EXCEPTION(r13) stw r8,TARGET_THREAD_EXCEPTION(r13)
lwz r8,THREAD_EXCEPTION_STACK_ADJUSTMENT(r13) lwz r8,TARGET_THREAD_EXCEPTIONSTACKADJUSTMENT(r13)
lwz r9,0(r1) lwz r9,0(r1)
subfic r8,r8,0 subfic r8,r8,0
stwux r9,r1,r8 stwux r9,r1,r8
lwz r8,THREAD_EXCEPTION_OFFSET(r13) lwz r8,TARGET_THREAD_EXCEPTIONOFFSET(r13)
stwx r7,r1,r8 stwx r7,r1,r8
lwz r7,THREAD_EXCEPTION_HANDLER(r13) lwz r7,TARGET_THREAD_EXCEPTIONHANDLER(r13)
mtctr r7 mtctr r7
bctr bctr

View File

@ -9,6 +9,7 @@
details. */ details. */
#include "types.h" #include "types.h"
#include "target-fields.h"
#define LOCAL(x) .L##x #define LOCAL(x) .L##x
@ -23,9 +24,6 @@
#ifdef __x86_64__ #ifdef __x86_64__
#define THREAD_STACK 2224
#define THREAD_SCRATCH 2240
#ifdef AVIAN_USE_FRAME_POINTER #ifdef AVIAN_USE_FRAME_POINTER
# define ALIGNMENT_ADJUSTMENT 0 # define ALIGNMENT_ADJUSTMENT 0
#else #else
@ -53,7 +51,7 @@ GLOBAL(vmInvoke):
// remember this stack position, since we won't be able to rely on // remember this stack position, since we won't be able to rely on
// %rbp being restored when the call returns // %rbp being restored when the call returns
movq %rsp,THREAD_SCRATCH(%rcx) movq %rsp,TARGET_THREAD_SCRATCH(%rcx)
// save callee-saved registers // save callee-saved registers
movq %rbx,0(%rsp) movq %rbx,0(%rsp)
@ -90,14 +88,14 @@ LOCAL(vmInvoke_argumentTest):
.globl GLOBAL(vmInvoke_returnAddress) .globl GLOBAL(vmInvoke_returnAddress)
GLOBAL(vmInvoke_returnAddress): GLOBAL(vmInvoke_returnAddress):
// restore stack pointer // restore stack pointer
movq THREAD_SCRATCH(%rbx),%rsp movq TARGET_THREAD_SCRATCH(%rbx),%rsp
// clear MyThread::stack to avoid confusing another thread calling // clear MyThread::stack to avoid confusing another thread calling
// java.lang.Thread.getStackTrace on this one. See // java.lang.Thread.getStackTrace on this one. See
// MyProcess::getStackTrace in compile.cpp for details on how we get // MyProcess::getStackTrace in compile.cpp for details on how we get
// a reliable stack trace from a thread that might be interrupted at // a reliable stack trace from a thread that might be interrupted at
// any point in its execution. // any point in its execution.
movq $0,THREAD_STACK(%rbx) movq $0,TARGET_THREAD_STACK(%rbx)
.globl GLOBAL(vmInvoke_safeStack) .globl GLOBAL(vmInvoke_safeStack)
GLOBAL(vmInvoke_safeStack): GLOBAL(vmInvoke_safeStack):
@ -188,7 +186,7 @@ GLOBAL(vmInvoke):
// remember this stack position, since we won't be able to rely on // remember this stack position, since we won't be able to rely on
// %rbp being restored when the call returns // %rbp being restored when the call returns
movq %rsp,THREAD_SCRATCH(%rdi) movq %rsp,TARGET_THREAD_SCRATCH(%rdi)
// save callee-saved registers // save callee-saved registers
movq %rbx,0(%rsp) movq %rbx,0(%rsp)
@ -222,14 +220,14 @@ LOCAL(vmInvoke_argumentTest):
.globl GLOBAL(vmInvoke_returnAddress) .globl GLOBAL(vmInvoke_returnAddress)
GLOBAL(vmInvoke_returnAddress): GLOBAL(vmInvoke_returnAddress):
// restore stack pointer // restore stack pointer
movq THREAD_SCRATCH(%rbx),%rsp movq TARGET_THREAD_SCRATCH(%rbx),%rsp
// clear MyThread::stack to avoid confusing another thread calling // clear MyThread::stack to avoid confusing another thread calling
// java.lang.Thread.getStackTrace on this one. See // java.lang.Thread.getStackTrace on this one. See
// MyProcess::getStackTrace in compile.cpp for details on how we get // MyProcess::getStackTrace in compile.cpp for details on how we get
// a reliable stack trace from a thread that might be interrupted at // a reliable stack trace from a thread that might be interrupted at
// any point in its execution. // any point in its execution.
movq $0,THREAD_STACK(%rbx) movq $0,TARGET_THREAD_STACK(%rbx)
.globl GLOBAL(vmInvoke_safeStack) .globl GLOBAL(vmInvoke_safeStack)
GLOBAL(vmInvoke_safeStack): GLOBAL(vmInvoke_safeStack):
@ -299,9 +297,6 @@ LOCAL(vmJumpAndInvoke_argumentTest):
#elif defined __i386__ #elif defined __i386__
#define THREAD_STACK 2148
#define THREAD_SCRATCH 2156
#ifdef AVIAN_USE_FRAME_POINTER #ifdef AVIAN_USE_FRAME_POINTER
# define ALIGNMENT_ADJUSTMENT 0 # define ALIGNMENT_ADJUSTMENT 0
#else #else
@ -328,7 +323,7 @@ GLOBAL(vmInvoke):
// remember this stack position, since we won't be able to rely on // remember this stack position, since we won't be able to rely on
// %rbp being restored when the call returns // %rbp being restored when the call returns
movl 8(%ebp),%eax movl 8(%ebp),%eax
movl %esp,THREAD_SCRATCH(%eax) movl %esp,TARGET_THREAD_SCRATCH(%eax)
movl %ebx,0(%esp) movl %ebx,0(%esp)
movl %esi,4(%esp) movl %esi,4(%esp)
@ -360,14 +355,14 @@ LOCAL(vmInvoke_argumentTest):
.globl GLOBAL(vmInvoke_returnAddress) .globl GLOBAL(vmInvoke_returnAddress)
GLOBAL(vmInvoke_returnAddress): GLOBAL(vmInvoke_returnAddress):
// restore stack pointer // restore stack pointer
movl THREAD_SCRATCH(%ebx),%esp movl TARGET_THREAD_SCRATCH(%ebx),%esp
// clear MyThread::stack to avoid confusing another thread calling // clear MyThread::stack to avoid confusing another thread calling
// java.lang.Thread.getStackTrace on this one. See // java.lang.Thread.getStackTrace on this one. See
// MyProcess::getStackTrace in compile.cpp for details on how we get // MyProcess::getStackTrace in compile.cpp for details on how we get
// a reliable stack trace from a thread that might be interrupted at // a reliable stack trace from a thread that might be interrupted at
// any point in its execution. // any point in its execution.
movl $0,THREAD_STACK(%ebx) movl $0,TARGET_THREAD_STACK(%ebx)
.globl GLOBAL(vmInvoke_safeStack) .globl GLOBAL(vmInvoke_safeStack)
GLOBAL(vmInvoke_safeStack): GLOBAL(vmInvoke_safeStack):

View File

@ -1392,7 +1392,7 @@ class Frame {
return c->add return c->add
(TargetBytesPerWord, c->memory (TargetBytesPerWord, c->memory
(c->register_(t->arch->thread()), Compiler::AddressType, (c->register_(t->arch->thread()), Compiler::AddressType,
TargetThreadHeapImage), c->promiseConstant TARGET_THREAD_HEAPIMAGE), c->promiseConstant
(p, Compiler::AddressType)); (p, Compiler::AddressType));
} else { } else {
for (PoolElement* e = context->objectPool; e; e = e->next) { for (PoolElement* e = context->objectPool; e; e = e->next) {
@ -1622,7 +1622,7 @@ class Frame {
? c->add ? c->add
(TargetBytesPerWord, c->memory (TargetBytesPerWord, c->memory
(c->register_(t->arch->thread()), Compiler::AddressType, (c->register_(t->arch->thread()), Compiler::AddressType,
TargetThreadCodeImage), c->promiseConstant TARGET_THREAD_CODEIMAGE), c->promiseConstant
(new(&context->zone) (new(&context->zone)
OffsetPromise OffsetPromise
(p, - reinterpret_cast<intptr_t>(codeAllocator(t)->base)), (p, - reinterpret_cast<intptr_t>(codeAllocator(t)->base)),
@ -1932,8 +1932,7 @@ class Frame {
subroutine->handle = c->startSubroutine(); subroutine->handle = c->startSubroutine();
this->subroutine = subroutine; this->subroutine = subroutine;
SubroutineCall* call = new SubroutineCall* call = new(&context->zone)
(context->zone.allocate(sizeof(SubroutineCall)))
SubroutineCall(subroutine, returnAddress); SubroutineCall(subroutine, returnAddress);
context->eventLog.append(PushSubroutineEvent); context->eventLog.append(PushSubroutineEvent);
@ -3380,7 +3379,7 @@ compileDirectInvoke(MyThread* t, Frame* frame, object target, bool tailCall,
frame->absoluteAddressOperand(returnAddressPromise), frame->absoluteAddressOperand(returnAddressPromise),
TargetBytesPerWord, c->memory TargetBytesPerWord, c->memory
(c->register_(t->arch->thread()), Compiler::AddressType, (c->register_(t->arch->thread()), Compiler::AddressType,
TargetThreadTailAddress)); TARGET_THREAD_TAILADDRESS));
c->exit c->exit
(c->constant (c->constant
@ -5563,7 +5562,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip,
(context->bootContext ? c->add (context->bootContext ? c->add
(TargetBytesPerWord, c->memory (TargetBytesPerWord, c->memory
(c->register_(t->arch->thread()), Compiler::AddressType, (c->register_(t->arch->thread()), Compiler::AddressType,
TargetThreadCodeImage), address) TARGET_THREAD_CODEIMAGE), address)
: address); : address);
Compiler::State* state = c->saveState(); Compiler::State* state = c->saveState();
@ -6110,7 +6109,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip,
? c->add ? c->add
(TargetBytesPerWord, c->memory (TargetBytesPerWord, c->memory
(c->register_(t->arch->thread()), Compiler::AddressType, (c->register_(t->arch->thread()), Compiler::AddressType,
TargetThreadCodeImage), entry) TARGET_THREAD_CODEIMAGE), entry)
: entry, : entry,
TargetBytesPerWord)); TargetBytesPerWord));
@ -7033,7 +7032,7 @@ finish(MyThread* t, FixedAllocator* allocator, Context* context)
// of cycles if another thread compiles the same method in parallel, // of cycles if another thread compiles the same method in parallel,
// which might be mitigated by fine-grained, per-method locking): // which might be mitigated by fine-grained, per-method locking):
c->compile(context->leaf ? 0 : stackOverflowThunk(t), c->compile(context->leaf ? 0 : stackOverflowThunk(t),
TargetThreadStackLimit); TARGET_THREAD_STACKLIMIT);
// we must acquire the class lock here at the latest // we must acquire the class lock here at the latest
@ -8529,6 +8528,16 @@ public:
Processor::CompilationHandler* handler; Processor::CompilationHandler* handler;
}; };
template<class T, class C>
int checkConstant(MyThread* t, size_t expected, T C::* field, const char* name) {
size_t actual = reinterpret_cast<uint8_t*>(&(t->*field)) - reinterpret_cast<uint8_t*>(t);
if(expected != actual) {
fprintf(stderr, "constant mismatch (%s): \n\tconstant says: %d\n\tc++ compiler says: %d\n", name, (unsigned) expected, (unsigned) actual);
return 1;
}
return 0;
}
class MyProcessor: public Processor { class MyProcessor: public Processor {
public: public:
class Thunk { class Thunk {
@ -8605,38 +8614,25 @@ class MyProcessor: public Processor {
t->codeImage = codeImage; t->codeImage = codeImage;
t->thunkTable = thunkTable; t->thunkTable = thunkTable;
if (false) { int mismatches =
fprintf(stderr, "stack %d\n", checkConstant(t, TARGET_THREAD_EXCEPTION, &Thread::exception, "TARGET_THREAD_EXCEPTION") +
difference(&(t->stack), t)); checkConstant(t, TARGET_THREAD_EXCEPTIONSTACKADJUSTMENT, &MyThread::exceptionStackAdjustment, "TARGET_THREAD_EXCEPTIONSTACKADJUSTMENT") +
fprintf(stderr, "scratch %d\n", checkConstant(t, TARGET_THREAD_EXCEPTIONOFFSET, &MyThread::exceptionOffset, "TARGET_THREAD_EXCEPTIONOFFSET") +
difference(&(t->scratch), t)); checkConstant(t, TARGET_THREAD_EXCEPTIONHANDLER, &MyThread::exceptionHandler, "TARGET_THREAD_EXCEPTIONHANDLER") +
fprintf(stderr, "continuation %d\n", checkConstant(t, TARGET_THREAD_IP, &MyThread::ip, "TARGET_THREAD_IP") +
difference(&(t->continuation), t)); checkConstant(t, TARGET_THREAD_STACK, &MyThread::stack, "TARGET_THREAD_STACK") +
fprintf(stderr, "exception %d\n", checkConstant(t, TARGET_THREAD_NEWSTACK, &MyThread::newStack, "TARGET_THREAD_NEWSTACK") +
difference(&(t->exception), t)); checkConstant(t, TARGET_THREAD_TAILADDRESS, &MyThread::tailAddress, "TARGET_THREAD_TAILADDRESS") +
fprintf(stderr, "exceptionStackAdjustment %d\n", checkConstant(t, TARGET_THREAD_VIRTUALCALLTARGET, &MyThread::virtualCallTarget, "TARGET_THREAD_VIRTUALCALLTARGET") +
difference(&(t->exceptionStackAdjustment), t)); checkConstant(t, TARGET_THREAD_VIRTUALCALLINDEX, &MyThread::virtualCallIndex, "TARGET_THREAD_VIRTUALCALLINDEX") +
fprintf(stderr, "exceptionOffset %d\n", checkConstant(t, TARGET_THREAD_HEAPIMAGE, &MyThread::heapImage, "TARGET_THREAD_HEAPIMAGE") +
difference(&(t->exceptionOffset), t)); checkConstant(t, TARGET_THREAD_CODEIMAGE, &MyThread::codeImage, "TARGET_THREAD_CODEIMAGE") +
fprintf(stderr, "exceptionHandler %d\n", checkConstant(t, TARGET_THREAD_THUNKTABLE, &MyThread::thunkTable, "TARGET_THREAD_THUNKTABLE") +
difference(&(t->exceptionHandler), t)); checkConstant(t, TARGET_THREAD_STACKLIMIT, &MyThread::stackLimit, "TARGET_THREAD_STACKLIMIT");
fprintf(stderr, "tailAddress %d\n",
difference(&(t->tailAddress), t)); if(mismatches > 0) {
fprintf(stderr, "stackLimit %d\n", fprintf(stderr, "%d constant mismatches\n", mismatches);
difference(&(t->stackLimit), t)); abort(t);
fprintf(stderr, "ip %d\n",
difference(&(t->ip), t));
fprintf(stderr, "virtualCallTarget %d\n",
difference(&(t->virtualCallTarget), t));
fprintf(stderr, "virtualCallIndex %d\n",
difference(&(t->virtualCallIndex), t));
fprintf(stderr, "heapImage %d\n",
difference(&(t->heapImage), t));
fprintf(stderr, "codeImage %d\n",
difference(&(t->codeImage), t));
fprintf(stderr, "thunkTable %d\n",
difference(&(t->thunkTable), t));
exit(0);
} }
t->init(); t->init();
@ -9801,7 +9797,7 @@ compileCall(MyThread* t, Context* c, ThunkIndex index, bool call = true)
Assembler* a = c->assembler; Assembler* a = c->assembler;
if (processor(t)->bootImage) { if (processor(t)->bootImage) {
Assembler::Memory table(t->arch->thread(), TargetThreadThunkTable); Assembler::Memory table(t->arch->thread(), TARGET_THREAD_THUNKTABLE);
Assembler::Register scratch(t->arch->scratch()); Assembler::Register scratch(t->arch->scratch());
a->apply(Move, TargetBytesPerWord, MemoryOperand, &table, a->apply(Move, TargetBytesPerWord, MemoryOperand, &table,
TargetBytesPerWord, RegisterOperand, &scratch); TargetBytesPerWord, RegisterOperand, &scratch);
@ -9827,7 +9823,7 @@ compileThunks(MyThread* t, FixedAllocator* allocator)
{ Context context(t); { Context context(t);
Assembler* a = context.assembler; Assembler* a = context.assembler;
a->saveFrame(TargetThreadStack, TargetThreadIp); a->saveFrame(TARGET_THREAD_STACK, TARGET_THREAD_IP);
p->thunks.default_.frameSavedOffset = a->length(); p->thunks.default_.frameSavedOffset = a->length();
@ -9860,19 +9856,19 @@ compileThunks(MyThread* t, FixedAllocator* allocator)
TargetBytesPerWord, RegisterOperand, &class_); TargetBytesPerWord, RegisterOperand, &class_);
Assembler::Memory virtualCallTargetDst Assembler::Memory virtualCallTargetDst
(t->arch->thread(), TargetThreadVirtualCallTarget); (t->arch->thread(), TARGET_THREAD_VIRTUALCALLTARGET);
a->apply(Move, TargetBytesPerWord, RegisterOperand, &class_, a->apply(Move, TargetBytesPerWord, RegisterOperand, &class_,
TargetBytesPerWord, MemoryOperand, &virtualCallTargetDst); TargetBytesPerWord, MemoryOperand, &virtualCallTargetDst);
Assembler::Register index(t->arch->virtualCallIndex()); Assembler::Register index(t->arch->virtualCallIndex());
Assembler::Memory virtualCallIndex Assembler::Memory virtualCallIndex
(t->arch->thread(), TargetThreadVirtualCallIndex); (t->arch->thread(), TARGET_THREAD_VIRTUALCALLINDEX);
a->apply(Move, TargetBytesPerWord, RegisterOperand, &index, a->apply(Move, TargetBytesPerWord, RegisterOperand, &index,
TargetBytesPerWord, MemoryOperand, &virtualCallIndex); TargetBytesPerWord, MemoryOperand, &virtualCallIndex);
a->saveFrame(TargetThreadStack, TargetThreadIp); a->saveFrame(TARGET_THREAD_STACK, TARGET_THREAD_IP);
p->thunks.defaultVirtual.frameSavedOffset = a->length(); p->thunks.defaultVirtual.frameSavedOffset = a->length();
@ -9895,7 +9891,7 @@ compileThunks(MyThread* t, FixedAllocator* allocator)
{ Context context(t); { Context context(t);
Assembler* a = context.assembler; Assembler* a = context.assembler;
a->saveFrame(TargetThreadStack, TargetThreadIp); a->saveFrame(TARGET_THREAD_STACK, TARGET_THREAD_IP);
p->thunks.native.frameSavedOffset = a->length(); p->thunks.native.frameSavedOffset = a->length();
@ -9905,7 +9901,7 @@ compileThunks(MyThread* t, FixedAllocator* allocator)
compileCall(t, &context, invokeNativeIndex); compileCall(t, &context, invokeNativeIndex);
a->popFrameAndUpdateStackAndReturn a->popFrameAndUpdateStackAndReturn
(t->arch->alignFrameSize(1), TargetThreadNewStack); (t->arch->alignFrameSize(1), TARGET_THREAD_NEWSTACK);
p->thunks.native.length = a->endBlock(false)->resolve(0, 0); p->thunks.native.length = a->endBlock(false)->resolve(0, 0);
@ -9916,7 +9912,7 @@ compileThunks(MyThread* t, FixedAllocator* allocator)
{ Context context(t); { Context context(t);
Assembler* a = context.assembler; Assembler* a = context.assembler;
a->saveFrame(TargetThreadStack, TargetThreadIp); a->saveFrame(TARGET_THREAD_STACK, TARGET_THREAD_IP);
p->thunks.aioob.frameSavedOffset = a->length(); p->thunks.aioob.frameSavedOffset = a->length();
@ -9934,7 +9930,7 @@ compileThunks(MyThread* t, FixedAllocator* allocator)
{ Context context(t); { Context context(t);
Assembler* a = context.assembler; Assembler* a = context.assembler;
a->saveFrame(TargetThreadStack, TargetThreadIp); a->saveFrame(TARGET_THREAD_STACK, TARGET_THREAD_IP);
p->thunks.stackOverflow.frameSavedOffset = a->length(); p->thunks.stackOverflow.frameSavedOffset = a->length();
@ -9952,7 +9948,7 @@ compileThunks(MyThread* t, FixedAllocator* allocator)
{ { Context context(t); { { Context context(t);
Assembler* a = context.assembler; Assembler* a = context.assembler;
a->saveFrame(TargetThreadStack, TargetThreadIp); a->saveFrame(TARGET_THREAD_STACK, TARGET_THREAD_IP);
p->thunks.table.frameSavedOffset = a->length(); p->thunks.table.frameSavedOffset = a->length();
@ -9971,7 +9967,7 @@ compileThunks(MyThread* t, FixedAllocator* allocator)
Context context(t); \ Context context(t); \
Assembler* a = context.assembler; \ Assembler* a = context.assembler; \
\ \
a->saveFrame(TargetThreadStack, TargetThreadIp); \ a->saveFrame(TARGET_THREAD_STACK, TARGET_THREAD_IP); \
\ \
p->thunks.table.frameSavedOffset = a->length(); \ p->thunks.table.frameSavedOffset = a->length(); \
\ \

63
src/target-fields.h Normal file
View File

@ -0,0 +1,63 @@
/* Copyright (c) 2011, Avian Contributors
Permission to use, copy, modify, and/or distribute this software
for any purpose with or without fee is hereby granted, provided
that the above copyright notice and this permission notice appear
in all copies.
There is NO WARRANTY for this software. See license.txt for
details. */
#ifndef AVIAN_TARGET_FIELDS_H
#define AVIAN_TARGET_FIELDS_H
#ifdef TARGET_BYTES_PER_WORD
# if (TARGET_BYTES_PER_WORD == 8)
#define TARGET_THREAD_EXCEPTION 80
#define TARGET_THREAD_EXCEPTIONSTACKADJUSTMENT 2256
#define TARGET_THREAD_EXCEPTIONOFFSET 2264
#define TARGET_THREAD_EXCEPTIONHANDLER 2272
#define TARGET_THREAD_IP 2216
#define TARGET_THREAD_STACK 2224
#define TARGET_THREAD_NEWSTACK 2232
#define TARGET_THREAD_SCRATCH 2240
#define TARGET_THREAD_CONTINUATION 2248
#define TARGET_THREAD_TAILADDRESS 2280
#define TARGET_THREAD_VIRTUALCALLTARGET 2288
#define TARGET_THREAD_VIRTUALCALLINDEX 2296
#define TARGET_THREAD_HEAPIMAGE 2304
#define TARGET_THREAD_CODEIMAGE 2312
#define TARGET_THREAD_THUNKTABLE 2320
#define TARGET_THREAD_STACKLIMIT 2368
# elif (TARGET_BYTES_PER_WORD == 4)
#define TARGET_THREAD_EXCEPTION 44
#define TARGET_THREAD_EXCEPTIONSTACKADJUSTMENT 2164
#define TARGET_THREAD_EXCEPTIONOFFSET 2168
#define TARGET_THREAD_EXCEPTIONHANDLER 2172
#define TARGET_THREAD_IP 2144
#define TARGET_THREAD_STACK 2148
#define TARGET_THREAD_NEWSTACK 2152
#define TARGET_THREAD_SCRATCH 2156
#define TARGET_THREAD_CONTINUATION 2160
#define TARGET_THREAD_TAILADDRESS 2176
#define TARGET_THREAD_VIRTUALCALLTARGET 2180
#define TARGET_THREAD_VIRTUALCALLINDEX 2184
#define TARGET_THREAD_HEAPIMAGE 2188
#define TARGET_THREAD_CODEIMAGE 2192
#define TARGET_THREAD_THUNKTABLE 2196
#define TARGET_THREAD_STACKLIMIT 2220
# else
# error
# endif
#else
# error
#endif
#endif

View File

@ -11,6 +11,8 @@
#ifndef TARGET_H #ifndef TARGET_H
#define TARGET_H #define TARGET_H
#include "target-fields.h"
namespace vm { namespace vm {
template <class T> template <class T>
@ -90,19 +92,6 @@ targetVW(T v)
typedef uint64_t target_uintptr_t; typedef uint64_t target_uintptr_t;
typedef int64_t target_intptr_t; typedef int64_t target_intptr_t;
const unsigned TargetBytesPerWord = 8;
const unsigned TargetThreadIp = 2216;
const unsigned TargetThreadStack = 2224;
const unsigned TargetThreadNewStack = 2232;
const unsigned TargetThreadTailAddress = 2280;
const unsigned TargetThreadVirtualCallTarget = 2288;
const unsigned TargetThreadVirtualCallIndex = 2296;
const unsigned TargetThreadHeapImage = 2304;
const unsigned TargetThreadCodeImage = 2312;
const unsigned TargetThreadThunkTable = 2320;
const unsigned TargetThreadStackLimit = 2368;
const unsigned TargetClassFixedSize = 12; const unsigned TargetClassFixedSize = 12;
const unsigned TargetClassArrayElementSize = 14; const unsigned TargetClassArrayElementSize = 14;
const unsigned TargetClassVtable = 128; const unsigned TargetClassVtable = 128;
@ -121,19 +110,6 @@ targetVW(T v)
typedef uint32_t target_uintptr_t; typedef uint32_t target_uintptr_t;
typedef int32_t target_intptr_t; typedef int32_t target_intptr_t;
const unsigned TargetBytesPerWord = 4;
const unsigned TargetThreadIp = 2144;
const unsigned TargetThreadStack = 2148;
const unsigned TargetThreadNewStack = 2152;
const unsigned TargetThreadTailAddress = 2176;
const unsigned TargetThreadVirtualCallTarget = 2180;
const unsigned TargetThreadVirtualCallIndex = 2184;
const unsigned TargetThreadHeapImage = 2188;
const unsigned TargetThreadCodeImage = 2192;
const unsigned TargetThreadThunkTable = 2196;
const unsigned TargetThreadStackLimit = 2220;
const unsigned TargetClassFixedSize = 8; const unsigned TargetClassFixedSize = 8;
const unsigned TargetClassArrayElementSize = 10; const unsigned TargetClassArrayElementSize = 10;
const unsigned TargetClassVtable = 68; const unsigned TargetClassVtable = 68;
@ -147,6 +123,8 @@ const unsigned TargetFieldOffset = 8;
# error # error
#endif #endif
const unsigned TargetBytesPerWord = TARGET_BYTES_PER_WORD;
const unsigned TargetBitsPerWord = TargetBytesPerWord * 8; const unsigned TargetBitsPerWord = TargetBytesPerWord * 8;
const target_uintptr_t TargetPointerMask const target_uintptr_t TargetPointerMask