mirror of
https://github.com/corda/corda.git
synced 2025-01-22 12:28:11 +00:00
Merge remote-tracking branch 'github/master' into dicej
Conflicts: src/classpath-openjdk.cpp
This commit is contained in:
commit
9060a31348
@ -15,7 +15,7 @@
|
|||||||
#include "stdlib.h"
|
#include "stdlib.h"
|
||||||
#include "string.h"
|
#include "string.h"
|
||||||
|
|
||||||
#include "util/runtime-array.h"
|
#include <avian/util/runtime-array.h>
|
||||||
|
|
||||||
#undef JNIEXPORT
|
#undef JNIEXPORT
|
||||||
|
|
||||||
|
@ -12,6 +12,9 @@
|
|||||||
#define AVIAN_TOOLS_H_
|
#define AVIAN_TOOLS_H_
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
#include <avian/util/string.h>
|
||||||
|
|
||||||
#include "environment.h"
|
#include "environment.h"
|
||||||
|
|
||||||
namespace avian {
|
namespace avian {
|
||||||
@ -38,24 +41,12 @@ public:
|
|||||||
virtual void write(uint8_t byte);
|
virtual void write(uint8_t byte);
|
||||||
};
|
};
|
||||||
|
|
||||||
class String {
|
|
||||||
public:
|
|
||||||
const char* text;
|
|
||||||
size_t length;
|
|
||||||
|
|
||||||
String(const char* text);
|
|
||||||
|
|
||||||
inline String(const char* text, size_t length):
|
|
||||||
text(text),
|
|
||||||
length(length) {}
|
|
||||||
};
|
|
||||||
|
|
||||||
class SymbolInfo {
|
class SymbolInfo {
|
||||||
public:
|
public:
|
||||||
unsigned addr;
|
unsigned addr;
|
||||||
String name;
|
util::String name;
|
||||||
|
|
||||||
inline SymbolInfo(uint64_t addr, const String& name):
|
inline SymbolInfo(uint64_t addr, const util::String& name):
|
||||||
addr(addr),
|
addr(addr),
|
||||||
name(name) {}
|
name(name) {}
|
||||||
|
|
||||||
@ -78,7 +69,7 @@ public:
|
|||||||
|
|
||||||
class StringTable : public Buffer {
|
class StringTable : public Buffer {
|
||||||
public:
|
public:
|
||||||
unsigned add(String str);
|
unsigned add(util::String str);
|
||||||
};
|
};
|
||||||
|
|
||||||
template<class T>
|
template<class T>
|
@ -11,6 +11,9 @@
|
|||||||
#ifndef AVIAN_UTIL_ABORT_H
|
#ifndef AVIAN_UTIL_ABORT_H
|
||||||
#define AVIAN_UTIL_ABORT_H
|
#define AVIAN_UTIL_ABORT_H
|
||||||
|
|
||||||
|
namespace avian {
|
||||||
|
namespace util {
|
||||||
|
|
||||||
class Aborter {
|
class Aborter {
|
||||||
public:
|
public:
|
||||||
virtual void NO_RETURN abort() = 0;
|
virtual void NO_RETURN abort() = 0;
|
||||||
@ -38,4 +41,7 @@ inline void assert(T t, bool v) {
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
} // namespace util
|
||||||
|
} // namespace avian
|
||||||
|
|
||||||
#endif // AVIAN_UTIL_ABORT_H
|
#endif // AVIAN_UTIL_ABORT_H
|
53
include/avian/util/math.h
Normal file
53
include/avian/util/math.h
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
/* Copyright (c) 2008-2012, 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_UTIL_MATH_H
|
||||||
|
#define AVIAN_UTIL_MATH_H
|
||||||
|
|
||||||
|
namespace avian {
|
||||||
|
namespace util {
|
||||||
|
|
||||||
|
inline unsigned max(unsigned a, unsigned b) {
|
||||||
|
return (a > b ? a : b);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline unsigned min(unsigned a, unsigned b) {
|
||||||
|
return (a < b ? a : b);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline unsigned avg(unsigned a, unsigned b) {
|
||||||
|
return (a + b) / 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline unsigned ceilingDivide(unsigned n, unsigned d) {
|
||||||
|
return (n + d - 1) / d;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline bool powerOfTwo(unsigned n) {
|
||||||
|
for (; n > 2; n >>= 1) if (n & 1) return false;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline unsigned nextPowerOfTwo(unsigned n) {
|
||||||
|
unsigned r = 1;
|
||||||
|
while (r < n) r <<= 1;
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline unsigned log(unsigned n) {
|
||||||
|
unsigned r = 0;
|
||||||
|
for (unsigned i = 1; i < n; ++r) i <<= 1;
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace util
|
||||||
|
} // namespace avian
|
||||||
|
|
||||||
|
#endif // AVIAN_UTIL_MATH_H
|
@ -32,8 +32,8 @@ class RuntimeArray {
|
|||||||
|
|
||||||
#else // not _MSC_VER
|
#else // not _MSC_VER
|
||||||
|
|
||||||
# define RUNTIME_ARRAY(type, name, size) type name[size];
|
# define RUNTIME_ARRAY(type, name, size) type name##_body[size];
|
||||||
# define RUNTIME_ARRAY_BODY(name) name
|
# define RUNTIME_ARRAY_BODY(name) name##_body
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
@ -8,27 +8,37 @@
|
|||||||
There is NO WARRANTY for this software. See license.txt for
|
There is NO WARRANTY for this software. See license.txt for
|
||||||
details. */
|
details. */
|
||||||
|
|
||||||
#ifndef TOKENIZER_H
|
#ifndef AVIAN_UTIL_STRING_H
|
||||||
#define TOKENIZER_H
|
#define AVIAN_UTIL_STRING_H
|
||||||
|
|
||||||
namespace vm {
|
#include <string.h>
|
||||||
|
|
||||||
|
namespace avian {
|
||||||
|
namespace util {
|
||||||
|
|
||||||
|
class String {
|
||||||
|
public:
|
||||||
|
const char* text;
|
||||||
|
size_t length;
|
||||||
|
|
||||||
|
String(const char* text):
|
||||||
|
text(text),
|
||||||
|
length(strlen(text)) {}
|
||||||
|
|
||||||
|
inline String(const char* text, size_t length):
|
||||||
|
text(text),
|
||||||
|
length(length) {}
|
||||||
|
};
|
||||||
|
|
||||||
class Tokenizer {
|
class Tokenizer {
|
||||||
public:
|
public:
|
||||||
class Token {
|
|
||||||
public:
|
|
||||||
Token(const char* s, unsigned length): s(s), length(length) { }
|
|
||||||
|
|
||||||
const char* s;
|
|
||||||
unsigned length;
|
|
||||||
};
|
|
||||||
|
|
||||||
Tokenizer(const char* s, char delimiter):
|
Tokenizer(const char* s, char delimiter):
|
||||||
s(s), limit(0), delimiter(delimiter)
|
s(s), limit(0), delimiter(delimiter)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
Tokenizer(const char* s, unsigned length, char delimiter):
|
Tokenizer(String str, char delimiter):
|
||||||
s(s), limit(s + length), delimiter(delimiter)
|
s(str.text), limit(str.text + str.length), delimiter(delimiter)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
bool hasMore() {
|
bool hasMore() {
|
||||||
@ -36,10 +46,10 @@ class Tokenizer {
|
|||||||
return s != limit and *s != 0;
|
return s != limit and *s != 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
Token next() {
|
String next() {
|
||||||
const char* p = s;
|
const char* p = s;
|
||||||
while (s != limit and *s and *s != delimiter) ++s;
|
while (s != limit and *s and *s != delimiter) ++s;
|
||||||
return Token(p, s - p);
|
return String(p, s - p);
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* s;
|
const char* s;
|
||||||
@ -47,6 +57,7 @@ class Tokenizer {
|
|||||||
char delimiter;
|
char delimiter;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace
|
} // namespace util
|
||||||
|
} // namespace avain
|
||||||
|
|
||||||
#endif//TOKENIZER_H
|
#endif//AVIAN_UTIL_STRING_H
|
@ -11,11 +11,11 @@
|
|||||||
#ifndef AVIAN_CODEGEN_ASSEMBLER_H
|
#ifndef AVIAN_CODEGEN_ASSEMBLER_H
|
||||||
#define AVIAN_CODEGEN_ASSEMBLER_H
|
#define AVIAN_CODEGEN_ASSEMBLER_H
|
||||||
|
|
||||||
#include "system.h"
|
#include <avian/vm/system/system.h>
|
||||||
#include "zone.h"
|
#include "zone.h"
|
||||||
|
|
||||||
#include "codegen/lir.h"
|
#include <avian/vm/codegen/lir.h>
|
||||||
#include "codegen/promise.h"
|
#include <avian/vm/codegen/promise.h>
|
||||||
|
|
||||||
namespace avian {
|
namespace avian {
|
||||||
namespace codegen {
|
namespace codegen {
|
@ -11,7 +11,7 @@
|
|||||||
#ifndef AVIAN_CODEGEN_COMPILER_H
|
#ifndef AVIAN_CODEGEN_COMPILER_H
|
||||||
#define AVIAN_CODEGEN_COMPILER_H
|
#define AVIAN_CODEGEN_COMPILER_H
|
||||||
|
|
||||||
#include "system.h"
|
#include <avian/vm/system/system.h>
|
||||||
#include "zone.h"
|
#include "zone.h"
|
||||||
#include "assembler.h"
|
#include "assembler.h"
|
||||||
|
|
@ -11,7 +11,7 @@
|
|||||||
#ifndef AVIAN_CODEGEN_TARGETS_H
|
#ifndef AVIAN_CODEGEN_TARGETS_H
|
||||||
#define AVIAN_CODEGEN_TARGETS_H
|
#define AVIAN_CODEGEN_TARGETS_H
|
||||||
|
|
||||||
#include "codegen/assembler.h"
|
#include <avian/vm/codegen/assembler.h>
|
||||||
|
|
||||||
namespace avian {
|
namespace avian {
|
||||||
namespace codegen {
|
namespace codegen {
|
@ -11,7 +11,7 @@
|
|||||||
#ifndef HEAP_H
|
#ifndef HEAP_H
|
||||||
#define HEAP_H
|
#define HEAP_H
|
||||||
|
|
||||||
#include "system.h"
|
#include <avian/vm/system/system.h>
|
||||||
#include "allocator.h"
|
#include "allocator.h"
|
||||||
|
|
||||||
namespace vm {
|
namespace vm {
|
@ -13,11 +13,11 @@
|
|||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
#include "allocator.h"
|
#include "allocator.h"
|
||||||
#include "util/abort.h"
|
#include <avian/util/abort.h>
|
||||||
|
|
||||||
namespace vm {
|
namespace vm {
|
||||||
|
|
||||||
class System : public Aborter {
|
class System : public avian::util::Aborter {
|
||||||
public:
|
public:
|
||||||
typedef intptr_t Status;
|
typedef intptr_t Status;
|
||||||
|
|
||||||
@ -165,7 +165,7 @@ allocate(System* s, unsigned size)
|
|||||||
#define ACQUIRE_MONITOR(t, m) \
|
#define ACQUIRE_MONITOR(t, m) \
|
||||||
System::MonitorResource MAKE_NAME(monitorResource_) (t, m)
|
System::MonitorResource MAKE_NAME(monitorResource_) (t, m)
|
||||||
|
|
||||||
inline Aborter* getAborter(System* s) {
|
inline avian::util::Aborter* getAborter(System* s) {
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
42
makefile
42
makefile
@ -257,7 +257,7 @@ warnings = -Wall -Wextra -Werror -Wunused-parameter -Winit-self \
|
|||||||
target-cflags = -DTARGET_BYTES_PER_WORD=$(pointer-size)
|
target-cflags = -DTARGET_BYTES_PER_WORD=$(pointer-size)
|
||||||
|
|
||||||
common-cflags = $(warnings) -fno-rtti -fno-exceptions -I$(classpath-src) \
|
common-cflags = $(warnings) -fno-rtti -fno-exceptions -I$(classpath-src) \
|
||||||
"-I$(JAVA_HOME)/include" -idirafter $(src) -I$(build) $(classpath-cflags) \
|
"-I$(JAVA_HOME)/include" -idirafter $(src) -I$(build) -Iinclude $(classpath-cflags) \
|
||||||
-D__STDC_LIMIT_MACROS -D_JNI_IMPLEMENTATION_ -DAVIAN_VERSION=\"$(version)\" \
|
-D__STDC_LIMIT_MACROS -D_JNI_IMPLEMENTATION_ -DAVIAN_VERSION=\"$(version)\" \
|
||||||
-DAVIAN_INFO="\"$(info)\"" \
|
-DAVIAN_INFO="\"$(info)\"" \
|
||||||
-DUSE_ATOMIC_OPERATIONS -DAVIAN_JAVA_HOME=\"$(javahome)\" \
|
-DUSE_ATOMIC_OPERATIONS -DAVIAN_JAVA_HOME=\"$(javahome)\" \
|
||||||
@ -275,7 +275,7 @@ endif
|
|||||||
build-cflags = $(common-cflags) -fPIC -fvisibility=hidden \
|
build-cflags = $(common-cflags) -fPIC -fvisibility=hidden \
|
||||||
"-I$(JAVA_HOME)/include/linux" -I$(src) -pthread
|
"-I$(JAVA_HOME)/include/linux" -I$(src) -pthread
|
||||||
|
|
||||||
converter-cflags = -D__STDC_CONSTANT_MACROS -Isrc/binaryToObject -Isrc/ \
|
converter-cflags = -D__STDC_CONSTANT_MACROS -Iinclude/ -Isrc/ \
|
||||||
-fno-rtti -fno-exceptions \
|
-fno-rtti -fno-exceptions \
|
||||||
-DAVIAN_TARGET_ARCH=AVIAN_ARCH_UNKNOWN \
|
-DAVIAN_TARGET_ARCH=AVIAN_ARCH_UNKNOWN \
|
||||||
-DAVIAN_TARGET_FORMAT=AVIAN_FORMAT_UNKNOWN \
|
-DAVIAN_TARGET_FORMAT=AVIAN_FORMAT_UNKNOWN \
|
||||||
@ -982,10 +982,11 @@ generated-code = \
|
|||||||
$(build)/type-name-initializations.cpp \
|
$(build)/type-name-initializations.cpp \
|
||||||
$(build)/type-maps.cpp
|
$(build)/type-maps.cpp
|
||||||
|
|
||||||
vm-depends := $(generated-code) $(wildcard $(src)/*.h) $(wildcard $(src)/codegen/*.h) $(wildcard $(src)/codegen/compiler/*.h)
|
vm-depends := $(generated-code) \
|
||||||
|
$(shell find src include -name '*.h' -or -name '*.inc.cpp')
|
||||||
|
|
||||||
vm-sources = \
|
vm-sources = \
|
||||||
$(src)/$(system).cpp \
|
$(src)/vm/system/$(system).cpp \
|
||||||
$(src)/finder.cpp \
|
$(src)/finder.cpp \
|
||||||
$(src)/machine.cpp \
|
$(src)/machine.cpp \
|
||||||
$(src)/util.cpp \
|
$(src)/util.cpp \
|
||||||
@ -1062,7 +1063,7 @@ heapwalk-sources = $(src)/heapwalk.cpp
|
|||||||
heapwalk-objects = \
|
heapwalk-objects = \
|
||||||
$(call cpp-objects,$(heapwalk-sources),$(src),$(build))
|
$(call cpp-objects,$(heapwalk-sources),$(src),$(build))
|
||||||
|
|
||||||
unittest-objects = $(call cpp-objects,$(unittest-sources),$(unittest),$(build)/unittest/)
|
unittest-objects = $(call cpp-objects,$(unittest-sources),$(unittest),$(build)/unittest)
|
||||||
|
|
||||||
ifeq ($(heapdump),true)
|
ifeq ($(heapdump),true)
|
||||||
vm-sources += $(src)/heapdump.cpp
|
vm-sources += $(src)/heapdump.cpp
|
||||||
@ -1079,7 +1080,7 @@ ifeq ($(continuations),true)
|
|||||||
asmflags += -DAVIAN_CONTINUATIONS
|
asmflags += -DAVIAN_CONTINUATIONS
|
||||||
endif
|
endif
|
||||||
|
|
||||||
bootimage-generator-sources = $(src)/bootimage.cpp
|
bootimage-generator-sources = $(src)/tools/bootimage-generator/main.cpp
|
||||||
ifneq ($(lzma),)
|
ifneq ($(lzma),)
|
||||||
bootimage-generator-sources += $(src)/lzma-encode.cpp
|
bootimage-generator-sources += $(src)/lzma-encode.cpp
|
||||||
endif
|
endif
|
||||||
@ -1114,8 +1115,8 @@ boot-object = $(build)/boot.o
|
|||||||
|
|
||||||
generator-depends := $(wildcard $(src)/*.h)
|
generator-depends := $(wildcard $(src)/*.h)
|
||||||
generator-sources = \
|
generator-sources = \
|
||||||
$(src)/type-generator.cpp \
|
$(src)/tools/type-generator/main.cpp \
|
||||||
$(src)/$(build-system).cpp \
|
$(src)/vm/system/$(build-system).cpp \
|
||||||
$(src)/finder.cpp
|
$(src)/finder.cpp
|
||||||
|
|
||||||
ifneq ($(lzma),)
|
ifneq ($(lzma),)
|
||||||
@ -1169,18 +1170,20 @@ generator-lzma-objects = \
|
|||||||
$(call generator-c-objects,$(lzma-decode-sources),$(lzma)/C,$(build))
|
$(call generator-c-objects,$(lzma-decode-sources),$(lzma)/C,$(build))
|
||||||
generator = $(build)/generator
|
generator = $(build)/generator
|
||||||
|
|
||||||
converter-depends = \
|
all-depends = $(shell find include -name '*.h')
|
||||||
$(src)/binaryToObject/tools.h \
|
|
||||||
$(src)/binaryToObject/endianness.h
|
|
||||||
|
|
||||||
converter-sources = \
|
object-writer-depends = $(shell find $(src)/tools/object-writer -name '*.h')
|
||||||
$(src)/binaryToObject/tools.cpp \
|
object-writer-sources = $(shell find $(src)/tools/object-writer -name '*.cpp')
|
||||||
$(src)/binaryToObject/elf.cpp \
|
object-writer-objects = $(call cpp-objects,$(object-writer-sources),$(src),$(build))
|
||||||
$(src)/binaryToObject/mach-o.cpp \
|
|
||||||
$(src)/binaryToObject/pe.cpp
|
|
||||||
|
|
||||||
converter-tool-sources = \
|
binary-to-object-depends = $(shell find $(src)/tools/binary-to-object/ -name '*.h')
|
||||||
$(src)/binaryToObject/main.cpp
|
binary-to-object-sources = $(shell find $(src)/tools/binary-to-object/ -name '*.cpp')
|
||||||
|
binary-to-object-objects = $(call cpp-objects,$(binary-to-object-sources),$(src),$(build))
|
||||||
|
|
||||||
|
converter-sources = $(object-writer-sources)
|
||||||
|
|
||||||
|
converter-tool-depends = $(binary-to-object-depends) $(all-depends)
|
||||||
|
converter-tool-sources = $(binary-to-object-sources)
|
||||||
|
|
||||||
converter-objects = $(call cpp-objects,$(converter-sources),$(src),$(build))
|
converter-objects = $(call cpp-objects,$(converter-sources),$(src),$(build))
|
||||||
converter-tool-objects = $(call cpp-objects,$(converter-tool-sources),$(src),$(build))
|
converter-tool-objects = $(call cpp-objects,$(converter-tool-sources),$(src),$(build))
|
||||||
@ -1580,11 +1583,12 @@ $(boot-object): $(boot-source)
|
|||||||
$(boot-javahome-object): $(src)/boot-javahome.cpp
|
$(boot-javahome-object): $(src)/boot-javahome.cpp
|
||||||
$(compile-object)
|
$(compile-object)
|
||||||
|
|
||||||
$(converter-objects) $(converter-tool-objects): $(build)/binaryToObject/%.o: $(src)/binaryToObject/%.cpp $(converter-depends)
|
$(object-writer-objects) $(binary-to-object-objects): $(build)/%.o: $(src)/%.cpp $(binary-to-object-depends) $(object-writer-depends) $(all-depends)
|
||||||
@mkdir -p $(dir $(@))
|
@mkdir -p $(dir $(@))
|
||||||
$(build-cxx) $(converter-cflags) -c $(<) -o $(@)
|
$(build-cxx) $(converter-cflags) -c $(<) -o $(@)
|
||||||
|
|
||||||
$(converter): $(converter-objects) $(converter-tool-objects)
|
$(converter): $(converter-objects) $(converter-tool-objects)
|
||||||
|
@mkdir -p $(dir $(@))
|
||||||
$(build-cc) $(^) -g -o $(@)
|
$(build-cc) $(^) -g -o $(@)
|
||||||
|
|
||||||
$(lzma-encoder-objects): $(build)/lzma/%.o: $(src)/lzma/%.cpp
|
$(lzma-encoder-objects): $(build)/lzma/%.o: $(src)/lzma/%.cpp
|
||||||
|
@ -11,9 +11,11 @@
|
|||||||
#ifndef VECTOR_H
|
#ifndef VECTOR_H
|
||||||
#define VECTOR_H
|
#define VECTOR_H
|
||||||
|
|
||||||
#include "system.h"
|
#include <avian/vm/system/system.h>
|
||||||
#include "target.h"
|
#include "target.h"
|
||||||
|
|
||||||
|
#include <avian/util/math.h>
|
||||||
|
|
||||||
namespace vm {
|
namespace vm {
|
||||||
|
|
||||||
class Vector {
|
class Vector {
|
||||||
@ -51,8 +53,8 @@ class Vector {
|
|||||||
if (position + space > capacity) {
|
if (position + space > capacity) {
|
||||||
assert(s, minimumCapacity >= 0);
|
assert(s, minimumCapacity >= 0);
|
||||||
|
|
||||||
unsigned newCapacity = max
|
unsigned newCapacity = avian::util::max
|
||||||
(position + space, max(minimumCapacity, capacity * 2));
|
(position + space, avian::util::max(minimumCapacity, capacity * 2));
|
||||||
uint8_t* newData = static_cast<uint8_t*>
|
uint8_t* newData = static_cast<uint8_t*>
|
||||||
(allocator->allocate(newCapacity));
|
(allocator->allocate(newCapacity));
|
||||||
if (data) {
|
if (data) {
|
||||||
|
14
src/arm.h
14
src/arm.h
@ -13,7 +13,7 @@
|
|||||||
|
|
||||||
#include "types.h"
|
#include "types.h"
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
#include "util/runtime-array.h"
|
#include <avian/util/runtime-array.h>
|
||||||
|
|
||||||
#ifdef __APPLE__
|
#ifdef __APPLE__
|
||||||
# include "libkern/OSAtomic.h"
|
# include "libkern/OSAtomic.h"
|
||||||
@ -206,7 +206,7 @@ dynamicCall(void* function, uintptr_t* arguments, uint8_t* argumentTypes,
|
|||||||
++ stackIndex;
|
++ stackIndex;
|
||||||
}
|
}
|
||||||
|
|
||||||
memcpy(stack + stackIndex, arguments + ai, 8);
|
memcpy(RUNTIME_ARRAY_BODY(stack) + stackIndex, arguments + ai, 8);
|
||||||
stackIndex += 8 / BytesPerWord;
|
stackIndex += 8 / BytesPerWord;
|
||||||
}
|
}
|
||||||
ai += 8 / BytesPerWord;
|
ai += 8 / BytesPerWord;
|
||||||
@ -219,7 +219,7 @@ dynamicCall(void* function, uintptr_t* arguments, uint8_t* argumentTypes,
|
|||||||
} else if (vfpIndex < VfpCount) {
|
} else if (vfpIndex < VfpCount) {
|
||||||
vfpTable[vfpIndex++] = arguments[ai];
|
vfpTable[vfpIndex++] = arguments[ai];
|
||||||
} else {
|
} else {
|
||||||
stack[stackIndex++] = arguments[ai];
|
RUNTIME_ARRAY_BODY(stack)[stackIndex++] = arguments[ai];
|
||||||
}
|
}
|
||||||
++ ai;
|
++ ai;
|
||||||
break;
|
break;
|
||||||
@ -231,7 +231,7 @@ dynamicCall(void* function, uintptr_t* arguments, uint8_t* argumentTypes,
|
|||||||
and gprIndex + Alignment == GprCount)
|
and gprIndex + Alignment == GprCount)
|
||||||
{
|
{
|
||||||
gprTable[gprIndex++] = arguments[ai];
|
gprTable[gprIndex++] = arguments[ai];
|
||||||
stack[stackIndex++] = arguments[ai + 1];
|
RUNTIME_ARRAY_BODY(stack)[stackIndex++] = arguments[ai + 1];
|
||||||
} else {
|
} else {
|
||||||
if (gprIndex % Alignment) {
|
if (gprIndex % Alignment) {
|
||||||
++gprIndex;
|
++gprIndex;
|
||||||
@ -246,7 +246,7 @@ dynamicCall(void* function, uintptr_t* arguments, uint8_t* argumentTypes,
|
|||||||
++stackIndex;
|
++stackIndex;
|
||||||
}
|
}
|
||||||
|
|
||||||
memcpy(stack + stackIndex, arguments + ai, 8);
|
memcpy(RUNTIME_ARRAY_BODY(stack) + stackIndex, arguments + ai, 8);
|
||||||
stackIndex += 8 / BytesPerWord;
|
stackIndex += 8 / BytesPerWord;
|
||||||
}
|
}
|
||||||
ai += 8 / BytesPerWord;
|
ai += 8 / BytesPerWord;
|
||||||
@ -256,7 +256,7 @@ dynamicCall(void* function, uintptr_t* arguments, uint8_t* argumentTypes,
|
|||||||
if (gprIndex < GprCount) {
|
if (gprIndex < GprCount) {
|
||||||
gprTable[gprIndex++] = arguments[ai];
|
gprTable[gprIndex++] = arguments[ai];
|
||||||
} else {
|
} else {
|
||||||
stack[stackIndex++] = arguments[ai];
|
RUNTIME_ARRAY_BODY(stack)[stackIndex++] = arguments[ai];
|
||||||
}
|
}
|
||||||
++ ai;
|
++ ai;
|
||||||
} break;
|
} break;
|
||||||
@ -274,7 +274,7 @@ dynamicCall(void* function, uintptr_t* arguments, uint8_t* argumentTypes,
|
|||||||
|
|
||||||
unsigned stackSize = stackIndex*BytesPerWord + ((stackIndex & 1) << 2);
|
unsigned stackSize = stackIndex*BytesPerWord + ((stackIndex & 1) << 2);
|
||||||
return vmNativeCall
|
return vmNativeCall
|
||||||
(function, stackSize, stack, stackIndex * BytesPerWord,
|
(function, stackSize, RUNTIME_ARRAY_BODY(stack), stackIndex * BytesPerWord,
|
||||||
(gprIndex ? gprTable : 0),
|
(gprIndex ? gprTable : 0),
|
||||||
(vfpIndex ? vfpTable : 0), returnType);
|
(vfpIndex ? vfpTable : 0), returnType);
|
||||||
}
|
}
|
||||||
|
@ -9,13 +9,13 @@ const unsigned NAME(BootHeapOffset) = 1 << (NAME(BootShift) + 1);
|
|||||||
inline unsigned
|
inline unsigned
|
||||||
LABEL(codeMapSize)(unsigned codeSize)
|
LABEL(codeMapSize)(unsigned codeSize)
|
||||||
{
|
{
|
||||||
return ceilingDivide(codeSize, TargetBitsPerWord) * TargetBytesPerWord;
|
return avian::util::ceilingDivide(codeSize, TargetBitsPerWord) * TargetBytesPerWord;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline unsigned
|
inline unsigned
|
||||||
LABEL(heapMapSize)(unsigned heapSize)
|
LABEL(heapMapSize)(unsigned heapSize)
|
||||||
{
|
{
|
||||||
return ceilingDivide(heapSize, TargetBitsPerWord * TargetBytesPerWord)
|
return avian::util::ceilingDivide(heapSize, TargetBitsPerWord * TargetBytesPerWord)
|
||||||
* TargetBytesPerWord;
|
* TargetBytesPerWord;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -12,9 +12,12 @@
|
|||||||
#define BOOTIMAGE_H
|
#define BOOTIMAGE_H
|
||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
|
#include "java-common.h"
|
||||||
#include "target.h"
|
#include "target.h"
|
||||||
#include "machine.h"
|
#include "machine.h"
|
||||||
|
|
||||||
|
#include <avian/util/math.h>
|
||||||
|
|
||||||
namespace vm {
|
namespace vm {
|
||||||
|
|
||||||
class BootImage {
|
class BootImage {
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
#include "processor.h"
|
#include "processor.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
|
|
||||||
#include "util/runtime-array.h"
|
#include <avian/util/runtime-array.h>
|
||||||
|
|
||||||
using namespace vm;
|
using namespace vm;
|
||||||
|
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
#include "classpath-common.h"
|
#include "classpath-common.h"
|
||||||
#include "process.h"
|
#include "process.h"
|
||||||
|
|
||||||
#include "util/runtime-array.h"
|
#include <avian/util/runtime-array.h>
|
||||||
|
|
||||||
using namespace vm;
|
using namespace vm;
|
||||||
|
|
||||||
|
@ -11,9 +11,10 @@
|
|||||||
#ifndef CLASSPATH_COMMON_H
|
#ifndef CLASSPATH_COMMON_H
|
||||||
#define CLASSPATH_COMMON_H
|
#define CLASSPATH_COMMON_H
|
||||||
|
|
||||||
#include "tokenizer.h"
|
#include <avian/util/string.h>
|
||||||
|
#include <avian/util/runtime-array.h>
|
||||||
|
|
||||||
#include "util/runtime-array.h"
|
using namespace avian::util;
|
||||||
|
|
||||||
namespace vm {
|
namespace vm {
|
||||||
|
|
||||||
@ -217,13 +218,13 @@ loadLibrary(Thread* t, const char* path, const char* name, bool mapName,
|
|||||||
for (Tokenizer tokenizer(path, t->m->system->pathSeparator());
|
for (Tokenizer tokenizer(path, t->m->system->pathSeparator());
|
||||||
tokenizer.hasMore();)
|
tokenizer.hasMore();)
|
||||||
{
|
{
|
||||||
Tokenizer::Token token(tokenizer.next());
|
String token(tokenizer.next());
|
||||||
|
|
||||||
unsigned fullNameLength = token.length + 1 + nameLength;
|
unsigned fullNameLength = token.length + 1 + nameLength;
|
||||||
THREAD_RUNTIME_ARRAY(t, char, fullName, fullNameLength + 1);
|
THREAD_RUNTIME_ARRAY(t, char, fullName, fullNameLength + 1);
|
||||||
|
|
||||||
snprintf(RUNTIME_ARRAY_BODY(fullName), fullNameLength + 1,
|
snprintf(RUNTIME_ARRAY_BODY(fullName), fullNameLength + 1,
|
||||||
"%.*s/%s", token.length, token.s, name);
|
"%.*s/%s", token.length, token.text, name);
|
||||||
|
|
||||||
lib = loadLibrary(t, RUNTIME_ARRAY_BODY(fullName));
|
lib = loadLibrary(t, RUNTIME_ARRAY_BODY(fullName));
|
||||||
if (lib) break;
|
if (lib) break;
|
||||||
|
@ -339,7 +339,7 @@ makeClassNameString(Thread* t, object name)
|
|||||||
replace('/', '.', RUNTIME_ARRAY_BODY(s),
|
replace('/', '.', RUNTIME_ARRAY_BODY(s),
|
||||||
reinterpret_cast<char*>(&byteArrayBody(t, name, 0)));
|
reinterpret_cast<char*>(&byteArrayBody(t, name, 0)));
|
||||||
|
|
||||||
return makeString(t, "%s", s);
|
return makeString(t, "%s", RUNTIME_ARRAY_BODY(s));
|
||||||
}
|
}
|
||||||
|
|
||||||
object
|
object
|
||||||
@ -761,7 +761,8 @@ class MyClasspath : public Classpath {
|
|||||||
length);
|
length);
|
||||||
RUNTIME_ARRAY_BODY(packageName)[length] = 0;
|
RUNTIME_ARRAY_BODY(packageName)[length] = 0;
|
||||||
|
|
||||||
object key = vm::makeByteArray(t, "%s", packageName);
|
object key = vm::makeByteArray
|
||||||
|
(t, "%s", RUNTIME_ARRAY_BODY(packageName));
|
||||||
PROTECT(t, key);
|
PROTECT(t, key);
|
||||||
|
|
||||||
hashMapRemove
|
hashMapRemove
|
||||||
@ -781,7 +782,7 @@ class MyClasspath : public Classpath {
|
|||||||
&byteArrayBody(t, source, PrefixLength),
|
&byteArrayBody(t, source, PrefixLength),
|
||||||
sourceNameLength);
|
sourceNameLength);
|
||||||
|
|
||||||
source = vm::makeByteArray(t, "%s", sourceName);
|
source = vm::makeByteArray(t, "%s", RUNTIME_ARRAY_BODY(sourceName));
|
||||||
} else {
|
} else {
|
||||||
source = vm::makeByteArray(t, "avian-dummy-package-source");
|
source = vm::makeByteArray(t, "avian-dummy-package-source");
|
||||||
}
|
}
|
||||||
@ -1575,7 +1576,8 @@ getZipFileEntry(Thread* t, object method, uintptr_t* arguments)
|
|||||||
RUNTIME_ARRAY_BODY(p)[byteArrayLength(t, path) + 1] = 0;
|
RUNTIME_ARRAY_BODY(p)[byteArrayLength(t, path) + 1] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
return reinterpret_cast<int64_t>(find(file, p, byteArrayLength(t, path)));
|
return reinterpret_cast<int64_t>
|
||||||
|
(find(file, RUNTIME_ARRAY_BODY(p), byteArrayLength(t, path)));
|
||||||
} else {
|
} else {
|
||||||
int64_t entry = longValue
|
int64_t entry = longValue
|
||||||
(t, t->m->processor->invoke
|
(t, t->m->processor->invoke
|
||||||
@ -3269,8 +3271,8 @@ jvmInitProperties(Thread* t, uintptr_t* arguments)
|
|||||||
|
|
||||||
if (*p == '=') {
|
if (*p == '=') {
|
||||||
THREAD_RUNTIME_ARRAY(t, char, name, (p - start) + 1);
|
THREAD_RUNTIME_ARRAY(t, char, name, (p - start) + 1);
|
||||||
memcpy(name, start, p - start);
|
memcpy(RUNTIME_ARRAY_BODY(name), start, p - start);
|
||||||
name[p - start] = 0;
|
RUNTIME_ARRAY_BODY(name)[p - start] = 0;
|
||||||
local::setProperty
|
local::setProperty
|
||||||
(t, method, *properties, RUNTIME_ARRAY_BODY(name), p + 1);
|
(t, method, *properties, RUNTIME_ARRAY_BODY(name), p + 1);
|
||||||
}
|
}
|
||||||
@ -4654,6 +4656,86 @@ jvmInvokeMethod(Thread* t, uintptr_t* arguments)
|
|||||||
(t, jclassVmClass(t, jmethodClazz(t, *method))),
|
(t, jclassVmClass(t, jmethodClazz(t, *method))),
|
||||||
jmethodSlot(t, *method));
|
jmethodSlot(t, *method));
|
||||||
|
|
||||||
|
<<<<<<< HEAD
|
||||||
|
=======
|
||||||
|
if (methodFlags(t, vmMethod) & ACC_STATIC) {
|
||||||
|
instance = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((args == 0 ? 0 : objectArrayLength(t, *args))
|
||||||
|
!= methodParameterCount(t, vmMethod))
|
||||||
|
{
|
||||||
|
throwNew(t, Machine::IllegalArgumentExceptionType);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (methodParameterCount(t, vmMethod)) {
|
||||||
|
PROTECT(t, vmMethod);
|
||||||
|
|
||||||
|
unsigned specLength = byteArrayLength(t, methodSpec(t, vmMethod));
|
||||||
|
THREAD_RUNTIME_ARRAY(t, char, spec, specLength);
|
||||||
|
memcpy(RUNTIME_ARRAY_BODY(spec),
|
||||||
|
&byteArrayBody(t, methodSpec(t, vmMethod), 0), specLength);
|
||||||
|
unsigned i = 0;
|
||||||
|
for (MethodSpecIterator it(t, RUNTIME_ARRAY_BODY(spec)); it.hasNext();) {
|
||||||
|
object type;
|
||||||
|
bool objectType = false;
|
||||||
|
const char* p = it.next();
|
||||||
|
switch (*p) {
|
||||||
|
case 'Z': type = vm::type(t, Machine::BooleanType); break;
|
||||||
|
case 'B': type = vm::type(t, Machine::ByteType); break;
|
||||||
|
case 'S': type = vm::type(t, Machine::ShortType); break;
|
||||||
|
case 'C': type = vm::type(t, Machine::CharType); break;
|
||||||
|
case 'I': type = vm::type(t, Machine::IntType); break;
|
||||||
|
case 'F': type = vm::type(t, Machine::FloatType); break;
|
||||||
|
case 'J': type = vm::type(t, Machine::LongType); break;
|
||||||
|
case 'D': type = vm::type(t, Machine::DoubleType); break;
|
||||||
|
|
||||||
|
case 'L': ++ p;
|
||||||
|
case '[': {
|
||||||
|
objectType = true;
|
||||||
|
unsigned nameLength = it.s - p;
|
||||||
|
THREAD_RUNTIME_ARRAY(t, char, name, nameLength);
|
||||||
|
memcpy(RUNTIME_ARRAY_BODY(name), p, nameLength - 1);
|
||||||
|
RUNTIME_ARRAY_BODY(name)[nameLength - 1] = 0;
|
||||||
|
type = resolveClass
|
||||||
|
(t, classLoader(t, methodClass(t, vmMethod)),
|
||||||
|
RUNTIME_ARRAY_BODY(name));
|
||||||
|
} break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
abort();
|
||||||
|
}
|
||||||
|
|
||||||
|
object arg = objectArrayBody(t, *args, i++);
|
||||||
|
if ((arg == 0 and (not objectType))
|
||||||
|
or (arg and (not instanceOf(t, type, arg))))
|
||||||
|
{
|
||||||
|
// fprintf(stderr, "%s is not a %s\n", arg ? &byteArrayBody(t, className(t, objectClass(t, arg)), 0) : reinterpret_cast<const int8_t*>("<null>"), &byteArrayBody(t, className(t, type), 0));
|
||||||
|
|
||||||
|
throwNew(t, Machine::IllegalArgumentExceptionType);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned returnCode = methodReturnCode(t, vmMethod);
|
||||||
|
|
||||||
|
THREAD_RESOURCE0(t, {
|
||||||
|
if (t->exception) {
|
||||||
|
object exception = t->exception;
|
||||||
|
t->exception = makeThrowable
|
||||||
|
(t, Machine::InvocationTargetExceptionType, 0, 0, exception);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
object result;
|
||||||
|
if (args) {
|
||||||
|
result = t->m->processor->invokeArray
|
||||||
|
(t, vmMethod, instance ? *instance : 0, *args);
|
||||||
|
} else {
|
||||||
|
result = t->m->processor->invoke(t, vmMethod, instance ? *instance : 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
>>>>>>> github/master
|
||||||
return reinterpret_cast<uint64_t>
|
return reinterpret_cast<uint64_t>
|
||||||
(makeLocalReference
|
(makeLocalReference
|
||||||
(t, invoke
|
(t, invoke
|
||||||
|
@ -8,13 +8,13 @@
|
|||||||
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 "codegen/assembler.h"
|
#include <avian/vm/codegen/assembler.h>
|
||||||
#include "codegen/registers.h"
|
#include <avian/vm/codegen/registers.h>
|
||||||
|
|
||||||
#include "alloc-vector.h"
|
#include "alloc-vector.h"
|
||||||
#include "util/abort.h"
|
#include <avian/util/abort.h>
|
||||||
|
|
||||||
#include "util/runtime-array.h"
|
#include <avian/util/runtime-array.h>
|
||||||
|
|
||||||
#define CAST1(x) reinterpret_cast<UnaryOperationType>(x)
|
#define CAST1(x) reinterpret_cast<UnaryOperationType>(x)
|
||||||
#define CAST2(x) reinterpret_cast<BinaryOperationType>(x)
|
#define CAST2(x) reinterpret_cast<BinaryOperationType>(x)
|
||||||
@ -23,6 +23,7 @@
|
|||||||
|
|
||||||
using namespace vm;
|
using namespace vm;
|
||||||
using namespace avian::codegen;
|
using namespace avian::codegen;
|
||||||
|
using namespace avian::util;
|
||||||
|
|
||||||
namespace local {
|
namespace local {
|
||||||
|
|
||||||
@ -2236,14 +2237,6 @@ class MyArchitecture: public Assembler::Architecture {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual lir::BinaryOperation hasBinaryIntrinsic(Thread*, object) {
|
|
||||||
return lir::NoBinaryOperation;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual lir::TernaryOperation hasTernaryIntrinsic(Thread*, object) {
|
|
||||||
return lir::NoTernaryOperation;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual bool alwaysCondensed(lir::BinaryOperation) {
|
virtual bool alwaysCondensed(lir::BinaryOperation) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -10,11 +10,11 @@
|
|||||||
|
|
||||||
#include "target.h"
|
#include "target.h"
|
||||||
|
|
||||||
#include "util/runtime-array.h"
|
#include <avian/util/runtime-array.h>
|
||||||
|
|
||||||
#include "codegen/compiler.h"
|
#include <avian/vm/codegen/compiler.h>
|
||||||
#include "codegen/assembler.h"
|
#include <avian/vm/codegen/assembler.h>
|
||||||
#include "codegen/promise.h"
|
#include <avian/vm/codegen/promise.h>
|
||||||
|
|
||||||
#include "codegen/compiler/regalloc.h"
|
#include "codegen/compiler/regalloc.h"
|
||||||
#include "codegen/compiler/context.h"
|
#include "codegen/compiler/context.h"
|
||||||
|
@ -11,10 +11,12 @@
|
|||||||
#ifndef AVIAN_CODEGEN_COMPILER_CONTEXT_H
|
#ifndef AVIAN_CODEGEN_COMPILER_CONTEXT_H
|
||||||
#define AVIAN_CODEGEN_COMPILER_CONTEXT_H
|
#define AVIAN_CODEGEN_COMPILER_CONTEXT_H
|
||||||
|
|
||||||
#include "codegen/assembler.h"
|
#include <avian/vm/codegen/assembler.h>
|
||||||
#include "codegen/compiler.h"
|
#include <avian/vm/codegen/compiler.h>
|
||||||
|
|
||||||
#include "codegen/compiler/regalloc.h"
|
#include "regalloc.h"
|
||||||
|
|
||||||
|
using namespace avian::util;
|
||||||
|
|
||||||
namespace avian {
|
namespace avian {
|
||||||
namespace codegen {
|
namespace codegen {
|
||||||
|
@ -9,7 +9,8 @@
|
|||||||
details. */
|
details. */
|
||||||
|
|
||||||
#include "target.h"
|
#include "target.h"
|
||||||
#include "util/runtime-array.h"
|
#include <avian/util/runtime-array.h>
|
||||||
|
#include <avian/util/math.h>
|
||||||
|
|
||||||
#include "codegen/compiler/context.h"
|
#include "codegen/compiler/context.h"
|
||||||
#include "codegen/compiler/event.h"
|
#include "codegen/compiler/event.h"
|
||||||
@ -20,6 +21,8 @@
|
|||||||
#include "codegen/compiler/frame.h"
|
#include "codegen/compiler/frame.h"
|
||||||
#include "codegen/compiler/ir.h"
|
#include "codegen/compiler/ir.h"
|
||||||
|
|
||||||
|
using namespace avian::util;
|
||||||
|
|
||||||
namespace avian {
|
namespace avian {
|
||||||
namespace codegen {
|
namespace codegen {
|
||||||
namespace compiler {
|
namespace compiler {
|
||||||
@ -921,11 +924,11 @@ appendCombine(Context* c, lir::TernaryOperation type,
|
|||||||
intptr_t handler = c->client->getThunk
|
intptr_t handler = c->client->getThunk
|
||||||
(type, firstSize, resultSize, &threadParameter);
|
(type, firstSize, resultSize, &threadParameter);
|
||||||
|
|
||||||
unsigned stackSize = vm::ceilingDivide(secondSize, vm::TargetBytesPerWord)
|
unsigned stackSize = ceilingDivide(secondSize, vm::TargetBytesPerWord)
|
||||||
+ vm::ceilingDivide(firstSize, vm::TargetBytesPerWord);
|
+ ceilingDivide(firstSize, vm::TargetBytesPerWord);
|
||||||
|
|
||||||
compiler::push(c, vm::ceilingDivide(secondSize, vm::TargetBytesPerWord), second);
|
compiler::push(c, ceilingDivide(secondSize, vm::TargetBytesPerWord), second);
|
||||||
compiler::push(c, vm::ceilingDivide(firstSize, vm::TargetBytesPerWord), first);
|
compiler::push(c, ceilingDivide(firstSize, vm::TargetBytesPerWord), first);
|
||||||
|
|
||||||
if (threadParameter) {
|
if (threadParameter) {
|
||||||
++ stackSize;
|
++ stackSize;
|
||||||
@ -1047,7 +1050,7 @@ appendTranslate(Context* c, lir::BinaryOperation type, unsigned firstSize,
|
|||||||
if (thunk) {
|
if (thunk) {
|
||||||
Stack* oldStack = c->stack;
|
Stack* oldStack = c->stack;
|
||||||
|
|
||||||
compiler::push(c, vm::ceilingDivide(firstSize, vm::TargetBytesPerWord), first);
|
compiler::push(c, ceilingDivide(firstSize, vm::TargetBytesPerWord), first);
|
||||||
|
|
||||||
Stack* argumentStack = c->stack;
|
Stack* argumentStack = c->stack;
|
||||||
c->stack = oldStack;
|
c->stack = oldStack;
|
||||||
@ -1057,7 +1060,7 @@ appendTranslate(Context* c, lir::BinaryOperation type, unsigned firstSize,
|
|||||||
(c, lir::ValueGeneral, constantSite
|
(c, lir::ValueGeneral, constantSite
|
||||||
(c, c->client->getThunk(type, firstSize, resultSize))),
|
(c, c->client->getThunk(type, firstSize, resultSize))),
|
||||||
0, 0, result, resultSize, argumentStack,
|
0, 0, result, resultSize, argumentStack,
|
||||||
vm::ceilingDivide(firstSize, vm::TargetBytesPerWord), 0);
|
ceilingDivide(firstSize, vm::TargetBytesPerWord), 0);
|
||||||
} else {
|
} else {
|
||||||
append(c, new(c->zone)
|
append(c, new(c->zone)
|
||||||
TranslateEvent
|
TranslateEvent
|
||||||
@ -1404,8 +1407,8 @@ appendBranch(Context* c, lir::TernaryOperation type, unsigned size, Value* first
|
|||||||
|
|
||||||
assert(c, not threadParameter);
|
assert(c, not threadParameter);
|
||||||
|
|
||||||
compiler::push(c, vm::ceilingDivide(size, vm::TargetBytesPerWord), second);
|
compiler::push(c, ceilingDivide(size, vm::TargetBytesPerWord), second);
|
||||||
compiler::push(c, vm::ceilingDivide(size, vm::TargetBytesPerWord), first);
|
compiler::push(c, ceilingDivide(size, vm::TargetBytesPerWord), first);
|
||||||
|
|
||||||
Stack* argumentStack = c->stack;
|
Stack* argumentStack = c->stack;
|
||||||
c->stack = oldStack;
|
c->stack = oldStack;
|
||||||
@ -1414,7 +1417,7 @@ appendBranch(Context* c, lir::TernaryOperation type, unsigned size, Value* first
|
|||||||
appendCall
|
appendCall
|
||||||
(c, value
|
(c, value
|
||||||
(c, lir::ValueGeneral, constantSite(c, handler)), 0, 0, result, 4,
|
(c, lir::ValueGeneral, constantSite(c, handler)), 0, 0, result, 4,
|
||||||
argumentStack, vm::ceilingDivide(size, vm::TargetBytesPerWord) * 2, 0);
|
argumentStack, ceilingDivide(size, vm::TargetBytesPerWord) * 2, 0);
|
||||||
|
|
||||||
appendBranch(c, thunkBranch(c, type), 4, value
|
appendBranch(c, thunkBranch(c, type), 4, value
|
||||||
(c, lir::ValueGeneral, constantSite(c, static_cast<int64_t>(0))),
|
(c, lir::ValueGeneral, constantSite(c, static_cast<int64_t>(0))),
|
||||||
|
@ -13,15 +13,20 @@
|
|||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
|
|
||||||
#include "codegen/lir.h"
|
#include <avian/vm/codegen/lir.h>
|
||||||
#include "codegen/registers.h"
|
#include <avian/vm/codegen/registers.h>
|
||||||
|
|
||||||
class Aborter;
|
|
||||||
|
|
||||||
namespace avian {
|
namespace avian {
|
||||||
|
|
||||||
|
namespace util {
|
||||||
|
class Aborter;
|
||||||
|
} // namespace util
|
||||||
|
|
||||||
namespace codegen {
|
namespace codegen {
|
||||||
namespace compiler {
|
namespace compiler {
|
||||||
|
|
||||||
|
using namespace avian::util;
|
||||||
|
|
||||||
class Context;
|
class Context;
|
||||||
class Value;
|
class Value;
|
||||||
class SiteMask;
|
class SiteMask;
|
||||||
|
@ -11,9 +11,8 @@
|
|||||||
#ifndef AVIAN_CODEGEN_COMPILER_VALUE_H
|
#ifndef AVIAN_CODEGEN_COMPILER_VALUE_H
|
||||||
#define AVIAN_CODEGEN_COMPILER_VALUE_H
|
#define AVIAN_CODEGEN_COMPILER_VALUE_H
|
||||||
|
|
||||||
#include "codegen/lir.h"
|
#include <avian/vm/codegen/lir.h>
|
||||||
|
#include <avian/vm/codegen/compiler.h>
|
||||||
#include "codegen/compiler.h"
|
|
||||||
|
|
||||||
namespace avian {
|
namespace avian {
|
||||||
namespace codegen {
|
namespace codegen {
|
||||||
|
@ -8,11 +8,11 @@
|
|||||||
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 "codegen/assembler.h"
|
#include <avian/vm/codegen/assembler.h>
|
||||||
#include "codegen/registers.h"
|
#include <avian/vm/codegen/registers.h>
|
||||||
|
|
||||||
#include "alloc-vector.h"
|
#include "alloc-vector.h"
|
||||||
#include "util/abort.h"
|
#include <avian/util/abort.h>
|
||||||
|
|
||||||
#define CAST1(x) reinterpret_cast<UnaryOperationType>(x)
|
#define CAST1(x) reinterpret_cast<UnaryOperationType>(x)
|
||||||
#define CAST2(x) reinterpret_cast<BinaryOperationType>(x)
|
#define CAST2(x) reinterpret_cast<BinaryOperationType>(x)
|
||||||
@ -21,6 +21,7 @@
|
|||||||
|
|
||||||
using namespace vm;
|
using namespace vm;
|
||||||
using namespace avian::codegen;
|
using namespace avian::codegen;
|
||||||
|
using namespace avian::util;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
@ -2240,14 +2241,6 @@ class MyArchitecture: public Assembler::Architecture {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual lir::BinaryOperation hasBinaryIntrinsic(Thread*, object) {
|
|
||||||
return lir::NoBinaryOperation;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual lir::TernaryOperation hasTernaryIntrinsic(Thread*, object) {
|
|
||||||
return lir::NoTernaryOperation;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual bool alwaysCondensed(lir::BinaryOperation) {
|
virtual bool alwaysCondensed(lir::BinaryOperation) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -8,7 +8,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 "codegen/registers.h"
|
#include <avian/vm/codegen/registers.h>
|
||||||
|
|
||||||
namespace avian {
|
namespace avian {
|
||||||
namespace codegen {
|
namespace codegen {
|
||||||
|
@ -8,7 +8,8 @@
|
|||||||
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 "codegen/targets.h"
|
#include <avian/vm/codegen/targets.h>
|
||||||
|
|
||||||
#include "environment.h"
|
#include "environment.h"
|
||||||
|
|
||||||
namespace avian {
|
namespace avian {
|
||||||
|
@ -12,11 +12,11 @@
|
|||||||
#include "target.h"
|
#include "target.h"
|
||||||
#include "alloc-vector.h"
|
#include "alloc-vector.h"
|
||||||
|
|
||||||
#include "codegen/assembler.h"
|
#include <avian/vm/codegen/assembler.h>
|
||||||
#include "codegen/registers.h"
|
#include <avian/vm/codegen/registers.h>
|
||||||
|
|
||||||
#include "util/runtime-array.h"
|
#include <avian/util/runtime-array.h>
|
||||||
#include "util/abort.h"
|
#include <avian/util/abort.h>
|
||||||
|
|
||||||
#define CAST1(x) reinterpret_cast<UnaryOperationType>(x)
|
#define CAST1(x) reinterpret_cast<UnaryOperationType>(x)
|
||||||
#define CAST2(x) reinterpret_cast<BinaryOperationType>(x)
|
#define CAST2(x) reinterpret_cast<BinaryOperationType>(x)
|
||||||
@ -24,6 +24,7 @@
|
|||||||
|
|
||||||
using namespace vm;
|
using namespace vm;
|
||||||
using namespace avian::codegen;
|
using namespace avian::codegen;
|
||||||
|
using namespace avian::util;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
|
100
src/common.h
100
src/common.h
@ -296,24 +296,6 @@ const uintptr_t PointerMask
|
|||||||
|
|
||||||
const unsigned LikelyPageSizeInBytes = 4 * 1024;
|
const unsigned LikelyPageSizeInBytes = 4 * 1024;
|
||||||
|
|
||||||
inline unsigned
|
|
||||||
max(unsigned a, unsigned b)
|
|
||||||
{
|
|
||||||
return (a > b ? a : b);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline unsigned
|
|
||||||
min(unsigned a, unsigned b)
|
|
||||||
{
|
|
||||||
return (a < b ? a : b);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline unsigned
|
|
||||||
avg(unsigned a, unsigned b)
|
|
||||||
{
|
|
||||||
return (a + b) / 2;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline unsigned
|
inline unsigned
|
||||||
pad(unsigned n, unsigned alignment)
|
pad(unsigned n, unsigned alignment)
|
||||||
{
|
{
|
||||||
@ -338,35 +320,6 @@ padWord(uintptr_t n)
|
|||||||
return padWord(n, BytesPerWord);
|
return padWord(n, BytesPerWord);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline unsigned
|
|
||||||
ceilingDivide(unsigned n, unsigned d)
|
|
||||||
{
|
|
||||||
return (n + d - 1) / d;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline bool
|
|
||||||
powerOfTwo(unsigned n)
|
|
||||||
{
|
|
||||||
for (; n > 2; n >>= 1) if (n & 1) return false;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline unsigned
|
|
||||||
nextPowerOfTwo(unsigned n)
|
|
||||||
{
|
|
||||||
unsigned r = 1;
|
|
||||||
while (r < n) r <<= 1;
|
|
||||||
return r;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline unsigned
|
|
||||||
log(unsigned n)
|
|
||||||
{
|
|
||||||
unsigned r = 0;
|
|
||||||
for (unsigned i = 1; i < n; ++r) i <<= 1;
|
|
||||||
return r;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <class T>
|
template <class T>
|
||||||
inline unsigned
|
inline unsigned
|
||||||
wordOf(unsigned i)
|
wordOf(unsigned i)
|
||||||
@ -582,57 +535,6 @@ equal(const void* a, unsigned al, const void* b, unsigned bl)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class Machine;
|
|
||||||
class Thread;
|
|
||||||
|
|
||||||
struct Object { };
|
|
||||||
|
|
||||||
typedef Object* object;
|
|
||||||
|
|
||||||
typedef uint8_t jboolean;
|
|
||||||
typedef int8_t jbyte;
|
|
||||||
typedef uint16_t jchar;
|
|
||||||
typedef int16_t jshort;
|
|
||||||
typedef int32_t jint;
|
|
||||||
typedef int64_t jlong;
|
|
||||||
typedef float jfloat;
|
|
||||||
typedef double jdouble;
|
|
||||||
|
|
||||||
typedef jint jsize;
|
|
||||||
|
|
||||||
typedef object* jobject;
|
|
||||||
|
|
||||||
typedef jobject jclass;
|
|
||||||
typedef jobject jthrowable;
|
|
||||||
typedef jobject jstring;
|
|
||||||
typedef jobject jweak;
|
|
||||||
|
|
||||||
typedef jobject jarray;
|
|
||||||
typedef jarray jbooleanArray;
|
|
||||||
typedef jarray jbyteArray;
|
|
||||||
typedef jarray jcharArray;
|
|
||||||
typedef jarray jshortArray;
|
|
||||||
typedef jarray jintArray;
|
|
||||||
typedef jarray jlongArray;
|
|
||||||
typedef jarray jfloatArray;
|
|
||||||
typedef jarray jdoubleArray;
|
|
||||||
typedef jarray jobjectArray;
|
|
||||||
|
|
||||||
typedef uintptr_t jfieldID;
|
|
||||||
typedef uintptr_t jmethodID;
|
|
||||||
|
|
||||||
union jvalue {
|
|
||||||
jboolean z;
|
|
||||||
jbyte b;
|
|
||||||
jchar c;
|
|
||||||
jshort s;
|
|
||||||
jint i;
|
|
||||||
jlong j;
|
|
||||||
jfloat f;
|
|
||||||
jdouble d;
|
|
||||||
jobject l;
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace vm
|
} // namespace vm
|
||||||
|
|
||||||
#endif//COMMON_H
|
#endif // COMMON_H
|
||||||
|
@ -13,12 +13,13 @@
|
|||||||
#include "alloc-vector.h"
|
#include "alloc-vector.h"
|
||||||
#include "process.h"
|
#include "process.h"
|
||||||
#include "target.h"
|
#include "target.h"
|
||||||
#include "codegen/assembler.h"
|
|
||||||
#include "codegen/compiler.h"
|
|
||||||
#include "codegen/targets.h"
|
|
||||||
#include "arch.h"
|
#include "arch.h"
|
||||||
|
|
||||||
#include "util/runtime-array.h"
|
#include <avian/vm/codegen/assembler.h>
|
||||||
|
#include <avian/vm/codegen/compiler.h>
|
||||||
|
#include <avian/vm/codegen/targets.h>
|
||||||
|
|
||||||
|
#include <avian/util/runtime-array.h>
|
||||||
|
|
||||||
using namespace vm;
|
using namespace vm;
|
||||||
|
|
||||||
|
@ -8,15 +8,17 @@
|
|||||||
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 <avian/vm/system/system.h>
|
||||||
|
#include <avian/util/string.h>
|
||||||
|
#include <avian/util/runtime-array.h>
|
||||||
|
|
||||||
#include "zlib-custom.h"
|
#include "zlib-custom.h"
|
||||||
#include "system.h"
|
|
||||||
#include "tokenizer.h"
|
|
||||||
#include "finder.h"
|
#include "finder.h"
|
||||||
#include "lzma.h"
|
#include "lzma.h"
|
||||||
|
|
||||||
#include "util/runtime-array.h"
|
|
||||||
|
|
||||||
using namespace vm;
|
using namespace vm;
|
||||||
|
using namespace avian::util;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
@ -658,12 +660,12 @@ addTokens(System* s, Element** first, Element** last, Allocator* allocator,
|
|||||||
const char* jarName, unsigned jarNameBase, const char* tokens,
|
const char* jarName, unsigned jarNameBase, const char* tokens,
|
||||||
unsigned tokensLength, const char* bootLibrary)
|
unsigned tokensLength, const char* bootLibrary)
|
||||||
{
|
{
|
||||||
for (Tokenizer t(tokens, tokensLength, ' '); t.hasMore();) {
|
for (Tokenizer t(String(tokens, tokensLength), ' '); t.hasMore();) {
|
||||||
Tokenizer::Token token(t.next());
|
String token(t.next());
|
||||||
|
|
||||||
RUNTIME_ARRAY(char, n, jarNameBase + token.length + 1);
|
RUNTIME_ARRAY(char, n, jarNameBase + token.length + 1);
|
||||||
memcpy(RUNTIME_ARRAY_BODY(n), jarName, jarNameBase);
|
memcpy(RUNTIME_ARRAY_BODY(n), jarName, jarNameBase);
|
||||||
memcpy(RUNTIME_ARRAY_BODY(n) + jarNameBase, token.s, token.length);
|
memcpy(RUNTIME_ARRAY_BODY(n) + jarNameBase, token.text, token.length);
|
||||||
RUNTIME_ARRAY_BODY(n)[jarNameBase + token.length] = 0;
|
RUNTIME_ARRAY_BODY(n)[jarNameBase + token.length] = 0;
|
||||||
|
|
||||||
add(s, first, last, allocator, RUNTIME_ARRAY_BODY(n),
|
add(s, first, last, allocator, RUNTIME_ARRAY_BODY(n),
|
||||||
@ -813,9 +815,9 @@ parsePath(System* s, Allocator* allocator, const char* path,
|
|||||||
Element* first = 0;
|
Element* first = 0;
|
||||||
Element* last = 0;
|
Element* last = 0;
|
||||||
for (Tokenizer t(path, s->pathSeparator()); t.hasMore();) {
|
for (Tokenizer t(path, s->pathSeparator()); t.hasMore();) {
|
||||||
Tokenizer::Token token(t.next());
|
String token(t.next());
|
||||||
|
|
||||||
add(s, &first, &last, allocator, token.s, token.length, bootLibrary);
|
add(s, &first, &last, allocator, token.text, token.length, bootLibrary);
|
||||||
}
|
}
|
||||||
|
|
||||||
return first;
|
return first;
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
#define FINDER_H
|
#define FINDER_H
|
||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
#include "system.h"
|
#include <avian/vm/system/system.h>
|
||||||
#include "allocator.h"
|
#include "allocator.h"
|
||||||
|
|
||||||
namespace vm {
|
namespace vm {
|
||||||
|
@ -8,12 +8,15 @@
|
|||||||
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 "heap/heap.h"
|
#include <avian/vm/heap/heap.h>
|
||||||
#include "system.h"
|
#include <avian/vm/system/system.h>
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
#include "arch.h"
|
#include "arch.h"
|
||||||
|
|
||||||
|
#include <avian/util/math.h>
|
||||||
|
|
||||||
using namespace vm;
|
using namespace vm;
|
||||||
|
using namespace avian::util;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
|
@ -12,6 +12,7 @@
|
|||||||
#define HEAPWALK_H
|
#define HEAPWALK_H
|
||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
|
#include "java-common.h"
|
||||||
|
|
||||||
namespace vm {
|
namespace vm {
|
||||||
|
|
||||||
|
@ -9,14 +9,14 @@
|
|||||||
details. */
|
details. */
|
||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
#include "system.h"
|
#include <avian/vm/system/system.h>
|
||||||
#include "constants.h"
|
#include "constants.h"
|
||||||
#include "machine.h"
|
#include "machine.h"
|
||||||
#include "processor.h"
|
#include "processor.h"
|
||||||
#include "process.h"
|
#include "process.h"
|
||||||
#include "arch.h"
|
#include "arch.h"
|
||||||
|
|
||||||
#include "util/runtime-array.h"
|
#include <avian/util/runtime-array.h>
|
||||||
|
|
||||||
using namespace vm;
|
using namespace vm;
|
||||||
|
|
||||||
@ -2325,19 +2325,20 @@ interpret3(Thread* t, const int base)
|
|||||||
|
|
||||||
THREAD_RUNTIME_ARRAY(t, int32_t, counts, dimensions);
|
THREAD_RUNTIME_ARRAY(t, int32_t, counts, dimensions);
|
||||||
for (int i = dimensions - 1; i >= 0; --i) {
|
for (int i = dimensions - 1; i >= 0; --i) {
|
||||||
counts[i] = popInt(t);
|
RUNTIME_ARRAY_BODY(counts)[i] = popInt(t);
|
||||||
if (UNLIKELY(counts[i] < 0)) {
|
if (UNLIKELY(RUNTIME_ARRAY_BODY(counts)[i] < 0)) {
|
||||||
exception = makeThrowable
|
exception = makeThrowable
|
||||||
(t, Machine::NegativeArraySizeExceptionType, "%d", counts[i]);
|
(t, Machine::NegativeArraySizeExceptionType, "%d",
|
||||||
|
RUNTIME_ARRAY_BODY(counts)[i]);
|
||||||
goto throw_;
|
goto throw_;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
object array = makeArray(t, counts[0]);
|
object array = makeArray(t, RUNTIME_ARRAY_BODY(counts)[0]);
|
||||||
setObjectClass(t, array, class_);
|
setObjectClass(t, array, class_);
|
||||||
PROTECT(t, array);
|
PROTECT(t, array);
|
||||||
|
|
||||||
populateMultiArray(t, array, counts, 0, dimensions);
|
populateMultiArray(t, array, RUNTIME_ARRAY_BODY(counts), 0, dimensions);
|
||||||
|
|
||||||
pushObject(t, array);
|
pushObject(t, array);
|
||||||
} goto loop;
|
} goto loop;
|
||||||
|
69
src/java-common.h
Normal file
69
src/java-common.h
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
/* Copyright (c) 2008-2012, 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 JAVA_COMMON_H
|
||||||
|
#define JAVA_COMMON_H
|
||||||
|
|
||||||
|
namespace vm {
|
||||||
|
|
||||||
|
class Machine;
|
||||||
|
class Thread;
|
||||||
|
|
||||||
|
struct Object { };
|
||||||
|
|
||||||
|
typedef Object* object;
|
||||||
|
|
||||||
|
typedef uint8_t jboolean;
|
||||||
|
typedef int8_t jbyte;
|
||||||
|
typedef uint16_t jchar;
|
||||||
|
typedef int16_t jshort;
|
||||||
|
typedef int32_t jint;
|
||||||
|
typedef int64_t jlong;
|
||||||
|
typedef float jfloat;
|
||||||
|
typedef double jdouble;
|
||||||
|
|
||||||
|
typedef jint jsize;
|
||||||
|
|
||||||
|
typedef object* jobject;
|
||||||
|
|
||||||
|
typedef jobject jclass;
|
||||||
|
typedef jobject jthrowable;
|
||||||
|
typedef jobject jstring;
|
||||||
|
typedef jobject jweak;
|
||||||
|
|
||||||
|
typedef jobject jarray;
|
||||||
|
typedef jarray jbooleanArray;
|
||||||
|
typedef jarray jbyteArray;
|
||||||
|
typedef jarray jcharArray;
|
||||||
|
typedef jarray jshortArray;
|
||||||
|
typedef jarray jintArray;
|
||||||
|
typedef jarray jlongArray;
|
||||||
|
typedef jarray jfloatArray;
|
||||||
|
typedef jarray jdoubleArray;
|
||||||
|
typedef jarray jobjectArray;
|
||||||
|
|
||||||
|
typedef uintptr_t jfieldID;
|
||||||
|
typedef uintptr_t jmethodID;
|
||||||
|
|
||||||
|
union jvalue {
|
||||||
|
jboolean z;
|
||||||
|
jbyte b;
|
||||||
|
jchar c;
|
||||||
|
jshort s;
|
||||||
|
jint i;
|
||||||
|
jlong j;
|
||||||
|
jfloat f;
|
||||||
|
jdouble d;
|
||||||
|
jobject l;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace vm
|
||||||
|
|
||||||
|
#endif // JAVA_COMMON_H
|
@ -14,7 +14,7 @@
|
|||||||
#include "processor.h"
|
#include "processor.h"
|
||||||
#include "constants.h"
|
#include "constants.h"
|
||||||
|
|
||||||
#include "util/runtime-array.h"
|
#include <avian/util/runtime-array.h>
|
||||||
|
|
||||||
using namespace vm;
|
using namespace vm;
|
||||||
|
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
|
|
||||||
#include "lzma.h"
|
#include "lzma.h"
|
||||||
#include "C/Types.h"
|
#include "C/Types.h"
|
||||||
#include "system.h"
|
#include <avian/vm/system/system.h>
|
||||||
#include "allocator.h"
|
#include "allocator.h"
|
||||||
|
|
||||||
namespace vm {
|
namespace vm {
|
||||||
|
@ -11,7 +11,7 @@
|
|||||||
#ifndef LZMA_H
|
#ifndef LZMA_H
|
||||||
#define LZMA_H
|
#define LZMA_H
|
||||||
|
|
||||||
#include "system.h"
|
#include <avian/vm/system/system.h>
|
||||||
#include "allocator.h"
|
#include "allocator.h"
|
||||||
|
|
||||||
namespace vm {
|
namespace vm {
|
||||||
|
@ -11,13 +11,14 @@
|
|||||||
#include "jnienv.h"
|
#include "jnienv.h"
|
||||||
#include "machine.h"
|
#include "machine.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
#include "stream.h"
|
#include <avian/util/stream.h>
|
||||||
#include "constants.h"
|
#include "constants.h"
|
||||||
#include "processor.h"
|
#include "processor.h"
|
||||||
#include "arch.h"
|
#include "arch.h"
|
||||||
#include "lzma.h"
|
#include "lzma.h"
|
||||||
|
|
||||||
#include "util/runtime-array.h"
|
#include <avian/util/runtime-array.h>
|
||||||
|
#include <avian/util/math.h>
|
||||||
|
|
||||||
#if defined(PLATFORM_WINDOWS)
|
#if defined(PLATFORM_WINDOWS)
|
||||||
# define WIN32_LEAN_AND_MEAN
|
# define WIN32_LEAN_AND_MEAN
|
||||||
@ -25,6 +26,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
using namespace vm;
|
using namespace vm;
|
||||||
|
using namespace avian::util;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
@ -4796,13 +4798,13 @@ logTrace(FILE* f, const char* fmt, ...)
|
|||||||
|
|
||||||
RUNTIME_ARRAY(char, buffer, length + 1);
|
RUNTIME_ARRAY(char, buffer, length + 1);
|
||||||
va_start(a, fmt);
|
va_start(a, fmt);
|
||||||
vsnprintf(&buffer[0], length + 1, fmt, a);
|
vsnprintf(RUNTIME_ARRAY_BODY(buffer), length + 1, fmt, a);
|
||||||
va_end(a);
|
va_end(a);
|
||||||
buffer[length] = 0;
|
RUNTIME_ARRAY_BODY(buffer)[length] = 0;
|
||||||
|
|
||||||
::fprintf(f, "%s", &buffer[0]);
|
::fprintf(f, "%s", RUNTIME_ARRAY_BODY(buffer));
|
||||||
#ifdef PLATFORM_WINDOWS
|
#ifdef PLATFORM_WINDOWS
|
||||||
::OutputDebugStringA(&buffer[0]);
|
::OutputDebugStringA(RUNTIME_ARRAY_BODY(buffer));
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -12,13 +12,16 @@
|
|||||||
#define MACHINE_H
|
#define MACHINE_H
|
||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
#include "system.h"
|
#include "java-common.h"
|
||||||
#include "heap/heap.h"
|
#include <avian/vm/system/system.h>
|
||||||
|
#include <avian/vm/heap/heap.h>
|
||||||
#include "finder.h"
|
#include "finder.h"
|
||||||
#include "processor.h"
|
#include "processor.h"
|
||||||
#include "constants.h"
|
#include "constants.h"
|
||||||
#include "arch.h"
|
#include "arch.h"
|
||||||
|
|
||||||
|
using namespace avian::util;
|
||||||
|
|
||||||
#ifdef PLATFORM_WINDOWS
|
#ifdef PLATFORM_WINDOWS
|
||||||
# define JNICALL __stdcall
|
# define JNICALL __stdcall
|
||||||
#else
|
#else
|
||||||
@ -1614,7 +1617,8 @@ class ThreadRuntimeArray: public Thread::Resource {
|
|||||||
|
|
||||||
#else // not _MSC_VER
|
#else // not _MSC_VER
|
||||||
|
|
||||||
# define THREAD_RUNTIME_ARRAY(thread, type, name, size) type name[size];
|
# define THREAD_RUNTIME_ARRAY(thread, type, name, size) \
|
||||||
|
type name##_body[size];
|
||||||
|
|
||||||
#endif // not _MSC_VER
|
#endif // not _MSC_VER
|
||||||
|
|
||||||
|
@ -13,10 +13,10 @@
|
|||||||
#include "string.h"
|
#include "string.h"
|
||||||
#include "jni.h"
|
#include "jni.h"
|
||||||
|
|
||||||
#include "system.h"
|
#include <avian/vm/system/system.h>
|
||||||
#include "finder.h"
|
#include "finder.h"
|
||||||
|
|
||||||
#include "util/runtime-array.h"
|
#include <avian/util/runtime-array.h>
|
||||||
|
|
||||||
#if (defined __MINGW32__) || (defined _MSC_VER)
|
#if (defined __MINGW32__) || (defined _MSC_VER)
|
||||||
# define PATH_SEPARATOR ';'
|
# define PATH_SEPARATOR ';'
|
||||||
|
@ -10,7 +10,7 @@
|
|||||||
|
|
||||||
#include "process.h"
|
#include "process.h"
|
||||||
|
|
||||||
#include "util/runtime-array.h"
|
#include <avian/util/runtime-array.h>
|
||||||
|
|
||||||
using namespace vm;
|
using namespace vm;
|
||||||
|
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
#define PROCESS_H
|
#define PROCESS_H
|
||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
#include "system.h"
|
#include <avian/vm/system/system.h>
|
||||||
#include "machine.h"
|
#include "machine.h"
|
||||||
#include "constants.h"
|
#include "constants.h"
|
||||||
|
|
||||||
|
@ -12,8 +12,8 @@
|
|||||||
#define PROCESSOR_H
|
#define PROCESSOR_H
|
||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
#include "system.h"
|
#include <avian/vm/system/system.h>
|
||||||
#include "heap/heap.h"
|
#include <avian/vm/heap/heap.h>
|
||||||
#include "bootimage.h"
|
#include "bootimage.h"
|
||||||
#include "heapwalk.h"
|
#include "heapwalk.h"
|
||||||
#include "zone.h"
|
#include "zone.h"
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
#endif
|
#endif
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
|
|
||||||
#include "tools.h"
|
#include <avian/tools/object-writer/tools.h>
|
||||||
|
|
||||||
extern "C"
|
extern "C"
|
||||||
void __cxa_pure_virtual() {
|
void __cxa_pure_virtual() {
|
@ -8,16 +8,17 @@
|
|||||||
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 "heap/heap.h"
|
#include <avian/vm/heap/heap.h>
|
||||||
#include "heapwalk.h"
|
#include "heapwalk.h"
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
#include "machine.h"
|
#include "machine.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
#include "stream.h"
|
#include <avian/util/stream.h>
|
||||||
#include "codegen/assembler.h"
|
#include <avian/vm/codegen/assembler.h>
|
||||||
#include "codegen/promise.h"
|
#include <avian/vm/codegen/promise.h>
|
||||||
#include "target.h"
|
#include "target.h"
|
||||||
#include "binaryToObject/tools.h"
|
#include <avian/tools/object-writer/tools.h>
|
||||||
|
#include <avian/util/runtime-array.h>
|
||||||
#include "lzma.h"
|
#include "lzma.h"
|
||||||
|
|
||||||
// since we aren't linking against libstdc++, we must implement this
|
// since we aren't linking against libstdc++, we must implement this
|
||||||
@ -345,20 +346,20 @@ makeCodeImage(Thread* t, Zone* zone, BootImage* image, uint8_t* code,
|
|||||||
unsigned count = s.read2() - 1;
|
unsigned count = s.read2() - 1;
|
||||||
if (count) {
|
if (count) {
|
||||||
THREAD_RUNTIME_ARRAY(t, Type, types, count + 2);
|
THREAD_RUNTIME_ARRAY(t, Type, types, count + 2);
|
||||||
types[0] = Type_object;
|
RUNTIME_ARRAY_BODY(types)[0] = Type_object;
|
||||||
types[1] = Type_intptr_t;
|
RUNTIME_ARRAY_BODY(types)[1] = Type_intptr_t;
|
||||||
|
|
||||||
for (unsigned i = 2; i < count + 2; ++i) {
|
for (unsigned i = 2; i < count + 2; ++i) {
|
||||||
switch (s.read1()) {
|
switch (s.read1()) {
|
||||||
case CONSTANT_Class:
|
case CONSTANT_Class:
|
||||||
case CONSTANT_String:
|
case CONSTANT_String:
|
||||||
types[i] = Type_object;
|
RUNTIME_ARRAY_BODY(types)[i] = Type_object;
|
||||||
s.skip(2);
|
s.skip(2);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case CONSTANT_Integer:
|
case CONSTANT_Integer:
|
||||||
case CONSTANT_Float:
|
case CONSTANT_Float:
|
||||||
types[i] = Type_int32_t;
|
RUNTIME_ARRAY_BODY(types)[i] = Type_int32_t;
|
||||||
s.skip(4);
|
s.skip(4);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -366,24 +367,24 @@ makeCodeImage(Thread* t, Zone* zone, BootImage* image, uint8_t* code,
|
|||||||
case CONSTANT_Fieldref:
|
case CONSTANT_Fieldref:
|
||||||
case CONSTANT_Methodref:
|
case CONSTANT_Methodref:
|
||||||
case CONSTANT_InterfaceMethodref:
|
case CONSTANT_InterfaceMethodref:
|
||||||
types[i] = Type_object;
|
RUNTIME_ARRAY_BODY(types)[i] = Type_object;
|
||||||
s.skip(4);
|
s.skip(4);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case CONSTANT_Long:
|
case CONSTANT_Long:
|
||||||
types[i++] = Type_int64_t;
|
RUNTIME_ARRAY_BODY(types)[i++] = Type_int64_t;
|
||||||
types[i] = Type_int64_t_pad;
|
RUNTIME_ARRAY_BODY(types)[i] = Type_int64_t_pad;
|
||||||
s.skip(8);
|
s.skip(8);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case CONSTANT_Double:
|
case CONSTANT_Double:
|
||||||
types[i++] = Type_double;
|
RUNTIME_ARRAY_BODY(types)[i++] = Type_double;
|
||||||
types[i] = Type_double_pad;
|
RUNTIME_ARRAY_BODY(types)[i] = Type_double_pad;
|
||||||
s.skip(8);
|
s.skip(8);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case CONSTANT_Utf8:
|
case CONSTANT_Utf8:
|
||||||
types[i] = Type_object;
|
RUNTIME_ARRAY_BODY(types)[i] = Type_object;
|
||||||
s.skip(s.read2());
|
s.skip(s.read2());
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -403,7 +404,7 @@ makeCodeImage(Thread* t, Zone* zone, BootImage* image, uint8_t* code,
|
|||||||
map->targetFixedOffsets()[i * BytesPerWord]
|
map->targetFixedOffsets()[i * BytesPerWord]
|
||||||
= i * TargetBytesPerWord;
|
= i * TargetBytesPerWord;
|
||||||
|
|
||||||
init(new (map->fixedFields() + i) Field, types[i],
|
init(new (map->fixedFields() + i) Field, RUNTIME_ARRAY_BODY(types)[i],
|
||||||
i * BytesPerWord, BytesPerWord, i * TargetBytesPerWord,
|
i * BytesPerWord, BytesPerWord, i * TargetBytesPerWord,
|
||||||
TargetBytesPerWord);
|
TargetBytesPerWord);
|
||||||
}
|
}
|
||||||
@ -439,15 +440,15 @@ makeCodeImage(Thread* t, Zone* zone, BootImage* image, uint8_t* code,
|
|||||||
for (unsigned j = 0; j < map->fixedFieldCount; ++j) {
|
for (unsigned j = 0; j < map->fixedFieldCount; ++j) {
|
||||||
Field* f = map->fixedFields() + j;
|
Field* f = map->fixedFields() + j;
|
||||||
|
|
||||||
memberFields[memberIndex] = *f;
|
RUNTIME_ARRAY_BODY(memberFields)[memberIndex] = *f;
|
||||||
|
|
||||||
targetMemberOffset = f->targetOffset + f->targetSize;
|
targetMemberOffset = f->targetOffset + f->targetSize;
|
||||||
|
|
||||||
++ memberIndex;
|
++ memberIndex;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
init(new (&memberFields[0]) Field, Type_object, 0, BytesPerWord, 0,
|
init(new (RUNTIME_ARRAY_BODY(memberFields)) Field, Type_object, 0,
|
||||||
TargetBytesPerWord);
|
BytesPerWord, 0, TargetBytesPerWord);
|
||||||
|
|
||||||
memberIndex = 1;
|
memberIndex = 1;
|
||||||
buildMemberOffset = BytesPerWord;
|
buildMemberOffset = BytesPerWord;
|
||||||
@ -458,14 +459,16 @@ makeCodeImage(Thread* t, Zone* zone, BootImage* image, uint8_t* code,
|
|||||||
|
|
||||||
THREAD_RUNTIME_ARRAY(t, Field, staticFields, count + StaticHeader);
|
THREAD_RUNTIME_ARRAY(t, Field, staticFields, count + StaticHeader);
|
||||||
|
|
||||||
init(new (&staticFields[0]) Field, Type_object, 0, BytesPerWord, 0,
|
init(new (RUNTIME_ARRAY_BODY(staticFields)) Field, Type_object, 0,
|
||||||
|
BytesPerWord, 0, TargetBytesPerWord);
|
||||||
|
|
||||||
|
init(new (RUNTIME_ARRAY_BODY(staticFields) + 1) Field, Type_intptr_t,
|
||||||
|
BytesPerWord, BytesPerWord, TargetBytesPerWord,
|
||||||
TargetBytesPerWord);
|
TargetBytesPerWord);
|
||||||
|
|
||||||
init(new (&staticFields[1]) Field, Type_intptr_t, BytesPerWord,
|
init(new (RUNTIME_ARRAY_BODY(staticFields) + 2) Field, Type_object,
|
||||||
BytesPerWord, TargetBytesPerWord, TargetBytesPerWord);
|
BytesPerWord * 2, BytesPerWord, TargetBytesPerWord * 2,
|
||||||
|
TargetBytesPerWord);
|
||||||
init(new (&staticFields[2]) Field, Type_object, BytesPerWord * 2,
|
|
||||||
BytesPerWord, TargetBytesPerWord * 2, TargetBytesPerWord);
|
|
||||||
|
|
||||||
unsigned staticIndex = StaticHeader;
|
unsigned staticIndex = StaticHeader;
|
||||||
unsigned buildStaticOffset = BytesPerWord * StaticHeader;
|
unsigned buildStaticOffset = BytesPerWord * StaticHeader;
|
||||||
@ -514,8 +517,8 @@ makeCodeImage(Thread* t, Zone* zone, BootImage* image, uint8_t* code,
|
|||||||
|
|
||||||
buildStaticOffset = fieldOffset(t, field);
|
buildStaticOffset = fieldOffset(t, field);
|
||||||
|
|
||||||
init(new (&staticFields[staticIndex]) Field, type,
|
init(new (RUNTIME_ARRAY_BODY(staticFields) + staticIndex) Field,
|
||||||
buildStaticOffset, buildSize, targetStaticOffset,
|
type, buildStaticOffset, buildSize, targetStaticOffset,
|
||||||
targetSize);
|
targetSize);
|
||||||
|
|
||||||
targetStaticOffset += targetSize;
|
targetStaticOffset += targetSize;
|
||||||
@ -528,8 +531,8 @@ makeCodeImage(Thread* t, Zone* zone, BootImage* image, uint8_t* code,
|
|||||||
|
|
||||||
buildMemberOffset = fieldOffset(t, field);
|
buildMemberOffset = fieldOffset(t, field);
|
||||||
|
|
||||||
init(new (&memberFields[memberIndex]) Field, type,
|
init(new (RUNTIME_ARRAY_BODY(memberFields) + memberIndex) Field,
|
||||||
buildMemberOffset, buildSize, targetMemberOffset,
|
type, buildMemberOffset, buildSize, targetMemberOffset,
|
||||||
targetSize);
|
targetSize);
|
||||||
|
|
||||||
targetMemberOffset += targetSize;
|
targetMemberOffset += targetSize;
|
||||||
@ -551,7 +554,7 @@ makeCodeImage(Thread* t, Zone* zone, BootImage* image, uint8_t* code,
|
|||||||
ceilingDivide(targetMemberOffset, TargetBytesPerWord), memberIndex);
|
ceilingDivide(targetMemberOffset, TargetBytesPerWord), memberIndex);
|
||||||
|
|
||||||
for (unsigned i = 0; i < memberIndex; ++i) {
|
for (unsigned i = 0; i < memberIndex; ++i) {
|
||||||
Field* f = &memberFields[i];
|
Field* f = RUNTIME_ARRAY_BODY(memberFields) + i;
|
||||||
|
|
||||||
expect(t, f->buildOffset
|
expect(t, f->buildOffset
|
||||||
< map->buildFixedSizeInWords * BytesPerWord);
|
< map->buildFixedSizeInWords * BytesPerWord);
|
||||||
@ -575,7 +578,7 @@ makeCodeImage(Thread* t, Zone* zone, BootImage* image, uint8_t* code,
|
|||||||
TypeMap::SingletonKind);
|
TypeMap::SingletonKind);
|
||||||
|
|
||||||
for (unsigned i = 0; i < staticIndex; ++i) {
|
for (unsigned i = 0; i < staticIndex; ++i) {
|
||||||
Field* f = &staticFields[i];
|
Field* f = RUNTIME_ARRAY_BODY(staticFields) + i;
|
||||||
|
|
||||||
expect(t, f->buildOffset
|
expect(t, f->buildOffset
|
||||||
< map->buildFixedSizeInWords * BytesPerWord);
|
< map->buildFixedSizeInWords * BytesPerWord);
|
||||||
@ -1338,8 +1341,8 @@ writeBootImage2(Thread* t, OutputStream* bootimageOutput, OutputStream* codeOutp
|
|||||||
|
|
||||||
THREAD_RUNTIME_ARRAY(t, Field, fields, count);
|
THREAD_RUNTIME_ARRAY(t, Field, fields, count);
|
||||||
|
|
||||||
init(new (&fields[0]) Field, Type_object, 0, BytesPerWord, 0,
|
init(new (RUNTIME_ARRAY_BODY(fields)) Field, Type_object, 0,
|
||||||
TargetBytesPerWord);
|
BytesPerWord, 0, TargetBytesPerWord);
|
||||||
|
|
||||||
unsigned buildOffset = BytesPerWord;
|
unsigned buildOffset = BytesPerWord;
|
||||||
unsigned targetOffset = TargetBytesPerWord;
|
unsigned targetOffset = TargetBytesPerWord;
|
||||||
@ -1416,8 +1419,8 @@ writeBootImage2(Thread* t, OutputStream* bootimageOutput, OutputStream* codeOutp
|
|||||||
++ targetOffset;
|
++ targetOffset;
|
||||||
}
|
}
|
||||||
|
|
||||||
init(new (&fields[j]) Field, type, buildOffset, buildSize,
|
init(new (RUNTIME_ARRAY_BODY(fields) + j) Field, type, buildOffset,
|
||||||
targetOffset, targetSize);
|
buildSize, targetOffset, targetSize);
|
||||||
|
|
||||||
buildOffset += buildSize;
|
buildOffset += buildSize;
|
||||||
targetOffset += targetSize;
|
targetOffset += targetSize;
|
||||||
@ -1451,7 +1454,7 @@ writeBootImage2(Thread* t, OutputStream* bootimageOutput, OutputStream* codeOutp
|
|||||||
targetArrayElementSize, arrayElementType);
|
targetArrayElementSize, arrayElementType);
|
||||||
|
|
||||||
for (unsigned j = 0; j < fixedFieldCount; ++j) {
|
for (unsigned j = 0; j < fixedFieldCount; ++j) {
|
||||||
Field* f = &fields[j];
|
Field* f = RUNTIME_ARRAY_BODY(fields) + j;
|
||||||
|
|
||||||
expect(t, f->buildOffset
|
expect(t, f->buildOffset
|
||||||
< map->buildFixedSizeInWords * BytesPerWord);
|
< map->buildFixedSizeInWords * BytesPerWord);
|
@ -15,7 +15,7 @@
|
|||||||
|
|
||||||
#include "endianness.h"
|
#include "endianness.h"
|
||||||
|
|
||||||
#include "tools.h"
|
#include <avian/tools/object-writer/tools.h>
|
||||||
|
|
||||||
#define EI_NIDENT 16
|
#define EI_NIDENT 16
|
||||||
|
|
||||||
@ -72,6 +72,7 @@
|
|||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
using namespace avian::tools;
|
using namespace avian::tools;
|
||||||
|
using namespace avian::util;
|
||||||
|
|
||||||
template<class AddrTy>
|
template<class AddrTy>
|
||||||
struct ElfTypes {
|
struct ElfTypes {
|
@ -14,7 +14,7 @@
|
|||||||
|
|
||||||
#include "endianness.h"
|
#include "endianness.h"
|
||||||
|
|
||||||
#include "tools.h"
|
#include <avian/tools/object-writer/tools.h>
|
||||||
|
|
||||||
#define MH_MAGIC_64 0xfeedfacf
|
#define MH_MAGIC_64 0xfeedfacf
|
||||||
#define MH_MAGIC 0xfeedface
|
#define MH_MAGIC 0xfeedface
|
||||||
@ -43,6 +43,7 @@
|
|||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
using namespace avian::tools;
|
using namespace avian::tools;
|
||||||
|
using namespace avian::util;
|
||||||
|
|
||||||
typedef int cpu_type_t;
|
typedef int cpu_type_t;
|
||||||
typedef int cpu_subtype_t;
|
typedef int cpu_subtype_t;
|
@ -13,7 +13,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
#include "tools.h"
|
#include <avian/tools/object-writer/tools.h>
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
@ -86,6 +86,7 @@ pad(unsigned n)
|
|||||||
}
|
}
|
||||||
|
|
||||||
using namespace avian::tools;
|
using namespace avian::tools;
|
||||||
|
using namespace avian::util;
|
||||||
|
|
||||||
template<unsigned BytesPerWord, PlatformInfo::Architecture Architecture>
|
template<unsigned BytesPerWord, PlatformInfo::Architecture Architecture>
|
||||||
class WindowsPlatform : public Platform {
|
class WindowsPlatform : public Platform {
|
@ -13,16 +13,14 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include "tools.h"
|
#include <avian/tools/object-writer/tools.h>
|
||||||
|
|
||||||
|
using namespace avian::util;
|
||||||
|
|
||||||
namespace avian {
|
namespace avian {
|
||||||
|
|
||||||
namespace tools {
|
namespace tools {
|
||||||
|
|
||||||
String::String(const char* text):
|
|
||||||
text(text),
|
|
||||||
length(strlen(text)) {}
|
|
||||||
|
|
||||||
Buffer::Buffer():
|
Buffer::Buffer():
|
||||||
capacity(100),
|
capacity(100),
|
||||||
length(0),
|
length(0),
|
149
src/tools/type-generator/io.h
Normal file
149
src/tools/type-generator/io.h
Normal file
@ -0,0 +1,149 @@
|
|||||||
|
/* Copyright (c) 2008-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. */
|
||||||
|
|
||||||
|
#include "assert.h"
|
||||||
|
|
||||||
|
#ifndef AVIAN_TOOLS_TYPE_GENERATOR_IO_H
|
||||||
|
#define AVIAN_TOOLS_TYPE_GENERATOR_IO_H
|
||||||
|
|
||||||
|
namespace avian {
|
||||||
|
namespace tools {
|
||||||
|
namespace typegenerator {
|
||||||
|
|
||||||
|
class Input {
|
||||||
|
public:
|
||||||
|
virtual ~Input() { }
|
||||||
|
|
||||||
|
virtual void dispose() = 0;
|
||||||
|
|
||||||
|
virtual int peek() = 0;
|
||||||
|
|
||||||
|
virtual int read() = 0;
|
||||||
|
|
||||||
|
virtual unsigned line() = 0;
|
||||||
|
|
||||||
|
virtual unsigned column() = 0;
|
||||||
|
|
||||||
|
void skipSpace() {
|
||||||
|
bool quit = false;
|
||||||
|
while (not quit) {
|
||||||
|
int c = peek();
|
||||||
|
switch (c) {
|
||||||
|
case ' ': case '\t': case '\n':
|
||||||
|
read();
|
||||||
|
break;
|
||||||
|
|
||||||
|
default: quit = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
class FileInput : public Input {
|
||||||
|
public:
|
||||||
|
const char* file;
|
||||||
|
FILE* stream;
|
||||||
|
unsigned line_;
|
||||||
|
unsigned column_;
|
||||||
|
bool close;
|
||||||
|
|
||||||
|
FileInput(const char* file, FILE* stream = 0, bool close = true):
|
||||||
|
file(file), stream(stream), line_(1), column_(1), close(close)
|
||||||
|
{ }
|
||||||
|
|
||||||
|
virtual ~FileInput() {
|
||||||
|
dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual void dispose() {
|
||||||
|
if (stream and close) {
|
||||||
|
fclose(stream);
|
||||||
|
stream = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual int peek() {
|
||||||
|
int c = getc(stream);
|
||||||
|
ungetc(c, stream);
|
||||||
|
return c;
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual int read() {
|
||||||
|
int c = getc(stream);
|
||||||
|
if (c == '\n') {
|
||||||
|
++ line_;
|
||||||
|
column_ = 1;
|
||||||
|
} else {
|
||||||
|
++ column_;
|
||||||
|
}
|
||||||
|
return c;
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual unsigned line() {
|
||||||
|
return line_;
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual unsigned column() {
|
||||||
|
return column_;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
class Output {
|
||||||
|
public:
|
||||||
|
virtual ~Output() { }
|
||||||
|
|
||||||
|
virtual void dispose() = 0;
|
||||||
|
|
||||||
|
virtual void write(const char* s) = 0;
|
||||||
|
|
||||||
|
void write(int i) {
|
||||||
|
static const int Size = 32;
|
||||||
|
char s[Size];
|
||||||
|
int c UNUSED = ::snprintf(s, Size, "%d", i);
|
||||||
|
assert(c > 0 and c < Size);
|
||||||
|
write(s);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
class FileOutput : public Output {
|
||||||
|
public:
|
||||||
|
const char* file;
|
||||||
|
FILE* stream;
|
||||||
|
bool close;
|
||||||
|
|
||||||
|
FileOutput(const char* file, FILE* stream = 0, bool close = true):
|
||||||
|
file(file), stream(stream), close(close)
|
||||||
|
{ }
|
||||||
|
|
||||||
|
virtual ~FileOutput() {
|
||||||
|
dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual void dispose() {
|
||||||
|
if (stream and close) {
|
||||||
|
fclose(stream);
|
||||||
|
stream = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual void write(const char* s) {
|
||||||
|
fputs(s, stream);
|
||||||
|
}
|
||||||
|
|
||||||
|
const char* filename() {
|
||||||
|
return file;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace typegenerator
|
||||||
|
} // namespace tools
|
||||||
|
} // namespace avian
|
||||||
|
|
||||||
|
#endif // AVIAN_TOOLS_TYPE_GENERATOR_IO_H
|
@ -16,7 +16,10 @@
|
|||||||
|
|
||||||
#include "constants.h"
|
#include "constants.h"
|
||||||
#include "finder.h"
|
#include "finder.h"
|
||||||
#include "stream.h"
|
#include <avian/util/stream.h>
|
||||||
|
|
||||||
|
#include "io.h"
|
||||||
|
#include "sexpr.h"
|
||||||
|
|
||||||
#include "assert.h"
|
#include "assert.h"
|
||||||
|
|
||||||
@ -29,6 +32,7 @@ inline void operator delete(void*) { abort(); }
|
|||||||
extern "C" void __cxa_pure_virtual(void) { abort(); }
|
extern "C" void __cxa_pure_virtual(void) { abort(); }
|
||||||
|
|
||||||
using namespace vm;
|
using namespace vm;
|
||||||
|
using namespace avian::tools::typegenerator;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
@ -55,15 +59,6 @@ pad(unsigned n)
|
|||||||
return (extra ? n + BytesPerWord - extra : n);
|
return (extra ? n + BytesPerWord - extra : n);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <class T>
|
|
||||||
T*
|
|
||||||
allocate()
|
|
||||||
{
|
|
||||||
T* t = static_cast<T*>(malloc(sizeof(T)));
|
|
||||||
assert(t);
|
|
||||||
return t;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline bool
|
inline bool
|
||||||
equal(const char* a, const char* b)
|
equal(const char* a, const char* b)
|
||||||
{
|
{
|
||||||
@ -88,214 +83,6 @@ take(unsigned n, const char* c)
|
|||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
class Input {
|
|
||||||
public:
|
|
||||||
virtual ~Input() { }
|
|
||||||
|
|
||||||
virtual void dispose() = 0;
|
|
||||||
|
|
||||||
virtual int peek() = 0;
|
|
||||||
|
|
||||||
virtual int read() = 0;
|
|
||||||
|
|
||||||
virtual unsigned line() = 0;
|
|
||||||
|
|
||||||
virtual unsigned column() = 0;
|
|
||||||
|
|
||||||
void skipSpace() {
|
|
||||||
bool quit = false;
|
|
||||||
while (not quit) {
|
|
||||||
int c = peek();
|
|
||||||
switch (c) {
|
|
||||||
case ' ': case '\t': case '\n':
|
|
||||||
read();
|
|
||||||
break;
|
|
||||||
|
|
||||||
default: quit = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
class FileInput : public Input {
|
|
||||||
public:
|
|
||||||
const char* file;
|
|
||||||
FILE* stream;
|
|
||||||
unsigned line_;
|
|
||||||
unsigned column_;
|
|
||||||
bool close;
|
|
||||||
|
|
||||||
FileInput(const char* file, FILE* stream = 0, bool close = true):
|
|
||||||
file(file), stream(stream), line_(1), column_(1), close(close)
|
|
||||||
{ }
|
|
||||||
|
|
||||||
virtual ~FileInput() {
|
|
||||||
dispose();
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void dispose() {
|
|
||||||
if (stream and close) {
|
|
||||||
fclose(stream);
|
|
||||||
stream = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual int peek() {
|
|
||||||
int c = getc(stream);
|
|
||||||
ungetc(c, stream);
|
|
||||||
return c;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual int read() {
|
|
||||||
int c = getc(stream);
|
|
||||||
if (c == '\n') {
|
|
||||||
++ line_;
|
|
||||||
column_ = 1;
|
|
||||||
} else {
|
|
||||||
++ column_;
|
|
||||||
}
|
|
||||||
return c;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual unsigned line() {
|
|
||||||
return line_;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual unsigned column() {
|
|
||||||
return column_;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
class Output {
|
|
||||||
public:
|
|
||||||
virtual ~Output() { }
|
|
||||||
|
|
||||||
virtual void dispose() = 0;
|
|
||||||
|
|
||||||
virtual void write(const char* s) = 0;
|
|
||||||
|
|
||||||
void write(int i) {
|
|
||||||
static const int Size = 32;
|
|
||||||
char s[Size];
|
|
||||||
int c UNUSED = ::snprintf(s, Size, "%d", i);
|
|
||||||
assert(c > 0 and c < Size);
|
|
||||||
write(s);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
class FileOutput : public Output {
|
|
||||||
public:
|
|
||||||
const char* file;
|
|
||||||
FILE* stream;
|
|
||||||
bool close;
|
|
||||||
|
|
||||||
FileOutput(const char* file, FILE* stream = 0, bool close = true):
|
|
||||||
file(file), stream(stream), close(close)
|
|
||||||
{ }
|
|
||||||
|
|
||||||
virtual ~FileOutput() {
|
|
||||||
dispose();
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void dispose() {
|
|
||||||
if (stream and close) {
|
|
||||||
fclose(stream);
|
|
||||||
stream = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void write(const char* s) {
|
|
||||||
fputs(s, stream);
|
|
||||||
}
|
|
||||||
|
|
||||||
const char* filename() {
|
|
||||||
return file;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
class Object {
|
|
||||||
public:
|
|
||||||
typedef enum {
|
|
||||||
Scalar,
|
|
||||||
Array,
|
|
||||||
Method,
|
|
||||||
Type,
|
|
||||||
Pair,
|
|
||||||
Number,
|
|
||||||
Character,
|
|
||||||
String,
|
|
||||||
Eos
|
|
||||||
} ObjectType;
|
|
||||||
|
|
||||||
ObjectType type;
|
|
||||||
};
|
|
||||||
|
|
||||||
class Pair : public Object {
|
|
||||||
public:
|
|
||||||
Object* car;
|
|
||||||
Object* cdr;
|
|
||||||
|
|
||||||
static Pair* make(Object* car, Object* cdr) {
|
|
||||||
Pair* o = allocate<Pair>();
|
|
||||||
o->type = Object::Pair;
|
|
||||||
o->car = car;
|
|
||||||
o->cdr = cdr;
|
|
||||||
return o;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
Object*
|
|
||||||
cons(Object* car, Object* cdr)
|
|
||||||
{
|
|
||||||
return Pair::make(car, cdr);
|
|
||||||
}
|
|
||||||
|
|
||||||
Object*&
|
|
||||||
car(Object* o)
|
|
||||||
{
|
|
||||||
assert(o->type == Object::Pair);
|
|
||||||
return static_cast<Pair*>(o)->car;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
setCar(Object* o, Object* v)
|
|
||||||
{
|
|
||||||
assert(o->type == Object::Pair);
|
|
||||||
static_cast<Pair*>(o)->car = v;
|
|
||||||
}
|
|
||||||
|
|
||||||
Object*&
|
|
||||||
cdr(Object* o)
|
|
||||||
{
|
|
||||||
assert(o->type == Object::Pair);
|
|
||||||
return static_cast<Pair*>(o)->cdr;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
setCdr(Object* o, Object* v)
|
|
||||||
{
|
|
||||||
assert(o->type == Object::Pair);
|
|
||||||
static_cast<Pair*>(o)->cdr = v;
|
|
||||||
}
|
|
||||||
|
|
||||||
class List {
|
|
||||||
public:
|
|
||||||
Object* first;
|
|
||||||
Object* last;
|
|
||||||
|
|
||||||
List(): first(0), last(0) { }
|
|
||||||
|
|
||||||
void append(Object* o) {
|
|
||||||
Object* p = cons(o, 0);
|
|
||||||
if (last) {
|
|
||||||
setCdr(last, p);
|
|
||||||
last = p;
|
|
||||||
} else {
|
|
||||||
first = last = p;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
class Scalar : public Object {
|
class Scalar : public Object {
|
||||||
public:
|
public:
|
||||||
Object* owner;
|
Object* owner;
|
||||||
@ -2176,9 +1963,9 @@ main(int ac, char** av)
|
|||||||
fprintf(stderr, "unable to open %s: %s\n", av[2], strerror(errno));
|
fprintf(stderr, "unable to open %s: %s\n", av[2], strerror(errno));
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
local::FileInput in(0, inStream, false);
|
FileInput in(0, inStream, false);
|
||||||
|
|
||||||
local::Object* declarations = local::parse(finder, &in);
|
Object* declarations = local::parse(finder, &in);
|
||||||
|
|
||||||
finder->dispose();
|
finder->dispose();
|
||||||
system->dispose();
|
system->dispose();
|
||||||
@ -2188,7 +1975,7 @@ main(int ac, char** av)
|
|||||||
fprintf(stderr, "unable to open %s: %s\n", av[3], strerror(errno));
|
fprintf(stderr, "unable to open %s: %s\n", av[3], strerror(errno));
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
local::FileOutput out(0, outStream, false);
|
FileOutput out(0, outStream, false);
|
||||||
|
|
||||||
if (local::equal(av[4], "enums")) {
|
if (local::equal(av[4], "enums")) {
|
||||||
local::writeEnums(&out, declarations);
|
local::writeEnums(&out, declarations);
|
102
src/tools/type-generator/sexpr.h
Normal file
102
src/tools/type-generator/sexpr.h
Normal file
@ -0,0 +1,102 @@
|
|||||||
|
/* Copyright (c) 2008-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_TOOLS_TYPE_GENERATOR_SEXPR_H
|
||||||
|
#define AVIAN_TOOLS_TYPE_GENERATOR_SEXPR_H
|
||||||
|
|
||||||
|
namespace avian {
|
||||||
|
namespace tools {
|
||||||
|
namespace typegenerator {
|
||||||
|
|
||||||
|
template <class T>
|
||||||
|
inline T* allocate() {
|
||||||
|
T* t = static_cast<T*>(malloc(sizeof(T)));
|
||||||
|
assert(t);
|
||||||
|
return t;
|
||||||
|
}
|
||||||
|
|
||||||
|
class Object {
|
||||||
|
public:
|
||||||
|
typedef enum {
|
||||||
|
Scalar,
|
||||||
|
Array,
|
||||||
|
Method,
|
||||||
|
Type,
|
||||||
|
Pair,
|
||||||
|
Number,
|
||||||
|
Character,
|
||||||
|
String,
|
||||||
|
Eos
|
||||||
|
} ObjectType;
|
||||||
|
|
||||||
|
ObjectType type;
|
||||||
|
};
|
||||||
|
|
||||||
|
class Pair : public Object {
|
||||||
|
public:
|
||||||
|
Object* car;
|
||||||
|
Object* cdr;
|
||||||
|
|
||||||
|
static Pair* make(Object* car, Object* cdr) {
|
||||||
|
Pair* o = allocate<Pair>();
|
||||||
|
o->type = Object::Pair;
|
||||||
|
o->car = car;
|
||||||
|
o->cdr = cdr;
|
||||||
|
return o;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
inline Object* cons(Object* car, Object* cdr) {
|
||||||
|
return Pair::make(car, cdr);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline Object*& car(Object* o) {
|
||||||
|
assert(o->type == Object::Pair);
|
||||||
|
return static_cast<Pair*>(o)->car;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void setCar(Object* o, Object* v) {
|
||||||
|
assert(o->type == Object::Pair);
|
||||||
|
static_cast<Pair*>(o)->car = v;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline Object*& cdr(Object* o) {
|
||||||
|
assert(o->type == Object::Pair);
|
||||||
|
return static_cast<Pair*>(o)->cdr;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void setCdr(Object* o, Object* v) {
|
||||||
|
assert(o->type == Object::Pair);
|
||||||
|
static_cast<Pair*>(o)->cdr = v;
|
||||||
|
}
|
||||||
|
|
||||||
|
class List {
|
||||||
|
public:
|
||||||
|
Object* first;
|
||||||
|
Object* last;
|
||||||
|
|
||||||
|
List(): first(0), last(0) { }
|
||||||
|
|
||||||
|
void append(Object* o) {
|
||||||
|
Object* p = cons(o, 0);
|
||||||
|
if (last) {
|
||||||
|
setCdr(last, p);
|
||||||
|
last = p;
|
||||||
|
} else {
|
||||||
|
first = last = p;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace typegenerator
|
||||||
|
} // namespace tools
|
||||||
|
} // namespace avian
|
||||||
|
|
||||||
|
#endif // AVIAN_TOOLS_TYPE_GENERATOR_SEXPR_H
|
@ -49,12 +49,15 @@
|
|||||||
#include "dirent.h"
|
#include "dirent.h"
|
||||||
#include "sched.h"
|
#include "sched.h"
|
||||||
#include "arch.h"
|
#include "arch.h"
|
||||||
#include "system.h"
|
#include <avian/vm/system/system.h>
|
||||||
|
|
||||||
|
#include <avian/util/math.h>
|
||||||
|
|
||||||
|
|
||||||
#define ACQUIRE(x) MutexResource MAKE_NAME(mutexResource_) (x)
|
#define ACQUIRE(x) MutexResource MAKE_NAME(mutexResource_) (x)
|
||||||
|
|
||||||
using namespace vm;
|
using namespace vm;
|
||||||
|
using namespace avian::util;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
@ -24,8 +24,8 @@
|
|||||||
#undef min
|
#undef min
|
||||||
|
|
||||||
#include "arch.h"
|
#include "arch.h"
|
||||||
#include "system.h"
|
#include <avian/vm/system/system.h>
|
||||||
#include "util/runtime-array.h"
|
#include <avian/util/runtime-array.h>
|
||||||
|
|
||||||
#if defined(WINAPI_FAMILY)
|
#if defined(WINAPI_FAMILY)
|
||||||
|
|
||||||
@ -806,12 +806,12 @@ class MySystem: public System {
|
|||||||
Status status = 1;
|
Status status = 1;
|
||||||
size_t nameLen = strlen(name) * 2;
|
size_t nameLen = strlen(name) * 2;
|
||||||
RUNTIME_ARRAY(wchar_t, wideName, nameLen + 1);
|
RUNTIME_ARRAY(wchar_t, wideName, nameLen + 1);
|
||||||
MultiByteToWideChar(CP_UTF8, 0, name, -1, wideName, nameLen + 1);
|
MultiByteToWideChar(CP_UTF8, 0, name, -1, RUNTIME_ARRAY_BODY(wideName), nameLen + 1);
|
||||||
#if !defined(WINAPI_FAMILY) || WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP)
|
#if !defined(WINAPI_FAMILY) || WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP)
|
||||||
HANDLE file = CreateFileW(wideName, FILE_READ_DATA, FILE_SHARE_READ, 0,
|
HANDLE file = CreateFileW(RUNTIME_ARRAY_BODY(wideName), FILE_READ_DATA, FILE_SHARE_READ, 0,
|
||||||
OPEN_EXISTING, 0, 0);
|
OPEN_EXISTING, 0, 0);
|
||||||
#else
|
#else
|
||||||
HANDLE file = CreateFile2(wideName, GENERIC_READ, FILE_SHARE_READ,
|
HANDLE file = CreateFile2(RUNTIME_ARRAY_BODY(wideName), GENERIC_READ, FILE_SHARE_READ,
|
||||||
OPEN_EXISTING, 0);
|
OPEN_EXISTING, 0);
|
||||||
#endif
|
#endif
|
||||||
if (file != INVALID_HANDLE_VALUE) {
|
if (file != INVALID_HANDLE_VALUE) {
|
||||||
@ -883,10 +883,10 @@ class MySystem: public System {
|
|||||||
virtual FileType stat(const char* name, unsigned* length) {
|
virtual FileType stat(const char* name, unsigned* length) {
|
||||||
size_t nameLen = strlen(name) * 2;
|
size_t nameLen = strlen(name) * 2;
|
||||||
RUNTIME_ARRAY(wchar_t, wideName, nameLen + 1);
|
RUNTIME_ARRAY(wchar_t, wideName, nameLen + 1);
|
||||||
MultiByteToWideChar(CP_UTF8, 0, name, -1, wideName, nameLen + 1);
|
MultiByteToWideChar(CP_UTF8, 0, name, -1, RUNTIME_ARRAY_BODY(wideName), nameLen + 1);
|
||||||
WIN32_FILE_ATTRIBUTE_DATA data;
|
WIN32_FILE_ATTRIBUTE_DATA data;
|
||||||
if (GetFileAttributesExW
|
if (GetFileAttributesExW
|
||||||
(wideName, GetFileExInfoStandard, &data))
|
(RUNTIME_ARRAY_BODY(wideName), GetFileExInfoStandard, &data))
|
||||||
{
|
{
|
||||||
if (data.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY) {
|
if (data.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY) {
|
||||||
return TypeDirectory;
|
return TypeDirectory;
|
||||||
@ -935,12 +935,12 @@ class MySystem: public System {
|
|||||||
if (name) {
|
if (name) {
|
||||||
size_t nameLen = nameLength * 2;
|
size_t nameLen = nameLength * 2;
|
||||||
RUNTIME_ARRAY(wchar_t, wideName, nameLen + 1);
|
RUNTIME_ARRAY(wchar_t, wideName, nameLen + 1);
|
||||||
MultiByteToWideChar(CP_UTF8, 0, name, -1, wideName, nameLen + 1);
|
MultiByteToWideChar(CP_UTF8, 0, name, -1, RUNTIME_ARRAY_BODY(wideName), nameLen + 1);
|
||||||
|
|
||||||
#if !defined(WINAPI_FAMILY) || WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP)
|
#if !defined(WINAPI_FAMILY) || WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP)
|
||||||
handle = LoadLibraryW(wideName);
|
handle = LoadLibraryW(RUNTIME_ARRAY_BODY(wideName));
|
||||||
#else
|
#else
|
||||||
handle = LoadPackagedLibrary(wideName, 0);
|
handle = LoadPackagedLibrary(RUNTIME_ARRAY_BODY(wideName), 0);
|
||||||
#endif
|
#endif
|
||||||
} else {
|
} else {
|
||||||
#if !defined(WINAPI_FAMILY) || WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP)
|
#if !defined(WINAPI_FAMILY) || WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP)
|
@ -11,9 +11,11 @@
|
|||||||
#ifndef ZONE_H
|
#ifndef ZONE_H
|
||||||
#define ZONE_H
|
#define ZONE_H
|
||||||
|
|
||||||
#include "system.h"
|
#include <avian/vm/system/system.h>
|
||||||
#include "allocator.h"
|
#include "allocator.h"
|
||||||
|
|
||||||
|
#include <avian/util/math.h>
|
||||||
|
|
||||||
namespace vm {
|
namespace vm {
|
||||||
|
|
||||||
class Zone: public Allocator {
|
class Zone: public Allocator {
|
||||||
@ -59,8 +61,8 @@ class Zone: public Allocator {
|
|||||||
bool tryEnsure(unsigned space) {
|
bool tryEnsure(unsigned space) {
|
||||||
if (segment == 0 or segment->position + space > segment->size) {
|
if (segment == 0 or segment->position + space > segment->size) {
|
||||||
unsigned size = padToPage
|
unsigned size = padToPage
|
||||||
(max
|
(avian::util::max
|
||||||
(space, max
|
(space, avian::util::max
|
||||||
(minimumFootprint, segment == 0 ? 0 : segment->size * 2))
|
(minimumFootprint, segment == 0 ? 0 : segment->size * 2))
|
||||||
+ sizeof(Segment));
|
+ sizeof(Segment));
|
||||||
|
|
||||||
|
@ -11,13 +11,13 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
#include "heap/heap.h"
|
#include <avian/vm/heap/heap.h>
|
||||||
#include "system.h"
|
#include <avian/vm/system/system.h>
|
||||||
#include "target.h"
|
#include "target.h"
|
||||||
|
|
||||||
#include "codegen/assembler.h"
|
#include <avian/vm/codegen/assembler.h>
|
||||||
#include "codegen/targets.h"
|
#include <avian/vm/codegen/targets.h>
|
||||||
#include "codegen/lir.h"
|
#include <avian/vm/codegen/lir.h>
|
||||||
|
|
||||||
#include "test-harness.h"
|
#include "test-harness.h"
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user