Merge branch 'master' of oss.readytalk.com:/var/local/git/avian

This commit is contained in:
Joel Dice 2009-07-10 09:57:29 -06:00
commit ab5ba9c954
10 changed files with 106 additions and 28 deletions

View File

@ -7,7 +7,7 @@
There is NO WARRANTY for this software. See license.txt for There is NO WARRANTY for this software. See license.txt for
details. */ details. */
#include "math.h" #include "math.h"
#include "stdlib.h" #include "stdlib.h"
#include "sys/time.h" #include "sys/time.h"
@ -32,11 +32,13 @@
# define SO_PREFIX "" # define SO_PREFIX ""
#else #else
# define SO_PREFIX "lib" # define SO_PREFIX "lib"
#include "sys/utsname.h"
#include "sys/wait.h" #include "sys/wait.h"
#endif #endif
#ifdef __APPLE__ #ifdef __APPLE__
# define SO_SUFFIX ".jnilib" # define SO_SUFFIX ".jnilib"
#include <CoreServices/CoreServices.h>
#elif defined WIN32 #elif defined WIN32
# define SO_SUFFIX ".dll" # define SO_SUFFIX ".dll"
#else #else
@ -349,6 +351,14 @@ Java_java_lang_System_getProperty(JNIEnv* e, jclass, jstring name,
r = e->NewStringUTF("\\"); r = e->NewStringUTF("\\");
} else if (strcmp(chars, "os.name") == 0) { } else if (strcmp(chars, "os.name") == 0) {
r = e->NewStringUTF("Windows"); r = e->NewStringUTF("Windows");
} else if (strcmp(chars, "os.version") == 0) {
unsigned size = 32;
char buffer[size];
OSVERSIONINFO OSversion;
OSversion.dwOSVersionInfoSize=sizeof(OSVERSIONINFO);
::GetVersionEx(&OSversion);
snprintf(buffer, size, "%i.%i", (int)OSversion.dwMajorVersion, (int)OSversion.dwMinorVersion);
r = e->NewStringUTF(buffer);
} else if (strcmp(chars, "java.io.tmpdir") == 0) { } else if (strcmp(chars, "java.io.tmpdir") == 0) {
TCHAR buffer[MAX_PATH]; TCHAR buffer[MAX_PATH];
GetTempPath(MAX_PATH, buffer); GetTempPath(MAX_PATH, buffer);
@ -367,11 +377,27 @@ Java_java_lang_System_getProperty(JNIEnv* e, jclass, jstring name,
r = e->NewStringUTF("Mac OS X"); r = e->NewStringUTF("Mac OS X");
#else #else
r = e->NewStringUTF("Linux"); r = e->NewStringUTF("Linux");
#endif
} else if (strcmp(chars, "os.version") == 0) {
#ifdef __APPLE__
unsigned size = 32;
char buffer[size];
long minorVersion, majorVersion;
Gestalt(gestaltSystemVersionMajor, &majorVersion);
Gestalt(gestaltSystemVersionMinor, &minorVersion);
snprintf(buffer, size, "%ld.%ld", majorVersion, minorVersion);
r = e->NewStringUTF(buffer);
#else
struct utsname system_id;
uname(&system_id);
r = e->NewStringUTF(system_id.release);
#endif #endif
} else if (strcmp(chars, "java.io.tmpdir") == 0) { } else if (strcmp(chars, "java.io.tmpdir") == 0) {
r = e->NewStringUTF("/tmp"); r = e->NewStringUTF("/tmp");
} else if (strcmp(chars, "user.home") == 0) { } else if (strcmp(chars, "user.home") == 0) {
r = e->NewStringUTF(getenv("HOME")); r = e->NewStringUTF(getenv("HOME"));
} }
#endif #endif

View File

@ -97,10 +97,6 @@ public class LinkedList<T> implements List<T> {
return find(element) != null; return find(element) != null;
} }
public void addAll(Collection<T> c) {
for (T t: c) add(t);
}
public boolean add(T element) { public boolean add(T element) {
addLast(element); addLast(element);
return true; return true;

View File

@ -127,7 +127,7 @@ endif
ifeq ($(platform),darwin) ifeq ($(platform),darwin)
build-cflags = $(common-cflags) -fPIC -fvisibility=hidden -I$(src) build-cflags = $(common-cflags) -fPIC -fvisibility=hidden -I$(src)
lflags = $(common-lflags) -ldl -framework CoreFoundation lflags = $(common-lflags) -ldl -framework CoreFoundation -framework CoreServices
ifeq ($(bootimage),true) ifeq ($(bootimage),true)
bootimage-lflags = -Wl,-segprot,__BOOT,rwx,rwx bootimage-lflags = -Wl,-segprot,__BOOT,rwx,rwx
endif endif

View File

@ -27,6 +27,8 @@ search(Thread* t, object name, object (*op)(Thread*, object),
bool replaceDots) bool replaceDots)
{ {
if (LIKELY(name)) { if (LIKELY(name)) {
PROTECT(t, name);
object n = makeByteArray(t, stringLength(t, name) + 1); object n = makeByteArray(t, stringLength(t, name) + 1);
char* s = reinterpret_cast<char*>(&byteArrayBody(t, n, 0)); char* s = reinterpret_cast<char*>(&byteArrayBody(t, n, 0));
stringChars(t, name, s); stringChars(t, name, s);

View File

@ -271,7 +271,7 @@ class MyStackWalker: public Processor::StackWalker {
virtual void walk(Processor::StackVisitor* v) { virtual void walk(Processor::StackVisitor* v) {
for (MyStackWalker it(this); it.valid();) { for (MyStackWalker it(this); it.valid();) {
MyStackWalker walker(it); MyStackWalker walker(&it);
if (not v->visit(&walker)) { if (not v->visit(&walker)) {
break; break;
} }
@ -548,6 +548,7 @@ enum Event {
IpEvent, IpEvent,
MarkEvent, MarkEvent,
ClearEvent, ClearEvent,
InitEvent,
TraceEvent TraceEvent
}; };
@ -4183,24 +4184,25 @@ compile(MyThread* t, Frame* initialFrame, unsigned ip,
} }
} }
FILE* compileLog = 0;
void void
logCompile(MyThread* t, const void* code, unsigned size, const char* class_, logCompile(MyThread* t, const void* code, unsigned size, const char* class_,
const char* name, const char* spec) const char* name, const char* spec)
{ {
static FILE* log = 0;
static bool open = false; static bool open = false;
if (not open) { if (not open) {
open = true; open = true;
const char* path = findProperty(t, "avian.jit.log"); const char* path = findProperty(t, "avian.jit.log");
if (path) { if (path) {
log = fopen(path, "wb"); compileLog = fopen(path, "wb");
} else if (DebugCompile) { } else if (DebugCompile) {
log = stderr; compileLog = stderr;
} }
} }
if (log) { if (compileLog) {
fprintf(log, "%p %p %s.%s%s\n", fprintf(compileLog, "%p %p %s.%s%s\n",
code, static_cast<const uint8_t*>(code) + size, code, static_cast<const uint8_t*>(code) + size,
class_, name, spec); class_, name, spec);
} }
@ -4387,6 +4389,14 @@ calculateFrameMaps(MyThread* t, Context* context, uintptr_t* originalRoots,
clearBit(roots, i); clearBit(roots, i);
} break; } break;
case InitEvent: {
unsigned reference = context->eventLog.get2(eventIndex);
eventIndex += 2;
uintptr_t* tableRoots = context->rootTable + (reference * mapSize);
memcpy(roots, tableRoots, mapSize * BytesPerWord);
} break;
case TraceEvent: { case TraceEvent: {
TraceElement* te; context->eventLog.get(eventIndex, &te, BytesPerWord); TraceElement* te; context->eventLog.get(eventIndex, &te, BytesPerWord);
if (DebugFrameMaps) { if (DebugFrameMaps) {
@ -4710,16 +4720,8 @@ compile(MyThread* t, Allocator* allocator, Context* context)
uint8_t stackMap[codeMaxStack(t, methodCode(t, context->method))]; uint8_t stackMap[codeMaxStack(t, methodCode(t, context->method))];
Frame frame2(&frame, stackMap); Frame frame2(&frame, stackMap);
uintptr_t* roots = context->rootTable context->eventLog.append(InitEvent);
+ (start * frameMapSizeInWords(t, context->method)); context->eventLog.append2(start);
for (unsigned i = 0; i < localSize(t, context->method); ++ i) {
if (getBit(roots, i)) {
frame2.set(i, Frame::Object);
} else {
frame2.set(i, Frame::Integer);
}
}
for (unsigned i = 1; for (unsigned i = 1;
i < codeMaxStack(t, methodCode(t, context->method)); i < codeMaxStack(t, methodCode(t, context->method));
@ -5848,6 +5850,11 @@ class SegFaultHandler: public System::SignalHandler {
return true; return true;
} }
} }
if (compileLog) {
fflush(compileLog);
}
return false; return false;
} }

View File

@ -2591,7 +2591,7 @@ unreachable(Event* event)
for (Link* p = event->predecessors; p; p = p->nextPredecessor) { for (Link* p = event->predecessors; p; p = p->nextPredecessor) {
if (not p->predecessor->allExits()) return false; if (not p->predecessor->allExits()) return false;
} }
return true; return event->predecessors != 0;
} }
class ReturnEvent: public Event { class ReturnEvent: public Event {

View File

@ -34,6 +34,12 @@ const bool Verbose2 = false;
const bool Debug = false; const bool Debug = false;
const bool DebugFixies = false; const bool DebugFixies = false;
#ifdef NDEBUG
const bool DebugAllocation = false;
#else
const bool DebugAllocation = true;
#endif
#define ACQUIRE(x) MutexLock MAKE_NAME(monitorLock_) (x) #define ACQUIRE(x) MutexLock MAKE_NAME(monitorLock_) (x)
class MutexLock { class MutexLock {
@ -422,7 +428,9 @@ class Segment {
} }
void dispose() { void dispose() {
free(context, data, (footprint(capacity())) * BytesPerWord); if (data) {
free(context, data, (footprint(capacity())) * BytesPerWord);
}
data = 0; data = 0;
map = 0; map = 0;
} }
@ -1673,11 +1681,22 @@ void* tryAllocate(Context* c, unsigned size)
{ {
ACQUIRE(c->lock); ACQUIRE(c->lock);
if (DebugAllocation) {
size = pad(size) + 2 * BytesPerWord;
}
if (size + c->count < c->limit) { if (size + c->count < c->limit) {
void* p = c->system->tryAllocate(size); void* p = c->system->tryAllocate(size);
if (p) { if (p) {
c->count += size; c->count += size;
return p;
if (DebugAllocation) {
static_cast<uintptr_t*>(p)[0] = 0x22377322;
static_cast<uintptr_t*>(p)[(size / BytesPerWord) - 1] = 0x22377322;
return static_cast<uintptr_t*>(p) + 1;
} else {
return p;
}
} }
} }
return 0; return 0;
@ -1686,7 +1705,21 @@ void* tryAllocate(Context* c, unsigned size)
void free(Context* c, const void* p, unsigned size) { void free(Context* c, const void* p, unsigned size) {
ACQUIRE(c->lock); ACQUIRE(c->lock);
if (DebugAllocation) {
size = pad(size) + 2 * BytesPerWord;
memset(const_cast<void*>(p), 0xFE, size - (2 * BytesPerWord));
p = static_cast<const uintptr_t*>(p) - 1;
expect(c->system, static_cast<const uintptr_t*>(p)[0] == 0x22377322);
expect(c->system, static_cast<const uintptr_t*>(p)
[(size / BytesPerWord) - 1] == 0x22377322);
}
expect(c->system, c->count >= size); expect(c->system, c->count >= size);
c->system->free(p); c->system->free(p);
c->count -= size; c->count -= size;
} }

View File

@ -97,6 +97,14 @@ GetEnv(Machine* m, Thread** t, jint version)
} }
} }
jsize JNICALL
GetVersion(Thread* t)
{
ENTER(t, Thread::ActiveState);
return JNI_VERSION_1_6;
}
jsize JNICALL jsize JNICALL
GetStringLength(Thread* t, jstring s) GetStringLength(Thread* t, jstring s)
{ {
@ -1911,6 +1919,7 @@ populateJNITables(JavaVMVTable* vmTable, JNIEnvVTable* envTable)
memset(envTable, 0, sizeof(JNIEnvVTable)); memset(envTable, 0, sizeof(JNIEnvVTable));
envTable->GetVersion = ::GetVersion;
envTable->GetStringLength = ::GetStringLength; envTable->GetStringLength = ::GetStringLength;
envTable->GetStringChars = ::GetStringChars; envTable->GetStringChars = ::GetStringChars;
envTable->ReleaseStringChars = ::ReleaseStringChars; envTable->ReleaseStringChars = ::ReleaseStringChars;

View File

@ -94,6 +94,10 @@ const unsigned CompiledFlag = 1 << 1;
const unsigned ConstructorFlag = 1 << 2; const unsigned ConstructorFlag = 1 << 2;
const unsigned FastNative = 1 << 3; const unsigned FastNative = 1 << 3;
#ifndef JNI_VERSION_1_6
#define JNI_VERSION_1_6 0x00010006
#endif
typedef Machine JavaVM; typedef Machine JavaVM;
typedef Thread JNIEnv; typedef Thread JNIEnv;

View File

@ -772,7 +772,8 @@ struct MINIDUMP_USER_STREAM_INFORMATION;
struct MINIDUMP_CALLBACK_INFORMATION; struct MINIDUMP_CALLBACK_INFORMATION;
enum MINIDUMP_TYPE { enum MINIDUMP_TYPE {
MiniDumpNormal = 0 MiniDumpNormal = 0,
MiniDumpWithFullMemory = 2
}; };
typedef BOOL (*MiniDumpWriteDumpType) typedef BOOL (*MiniDumpWriteDumpType)
@ -812,7 +813,7 @@ dump(LPEXCEPTION_POINTERS e, const char* directory)
(GetCurrentProcess(), (GetCurrentProcess(),
GetCurrentProcessId(), GetCurrentProcessId(),
file, file,
MiniDumpNormal, MiniDumpWithFullMemory,
&exception, &exception,
0, 0,
0); 0);