blob: 084e49cb45a5445ba4b6116d8e4da7960fa74845 [file] [log] [blame]
// Copyright 2011 Google Inc. All Rights Reserved.
#ifndef ART_SRC_RUNTIME_H_
#define ART_SRC_RUNTIME_H_
#include <stdio.h>
#include <iosfwd>
#include <string>
#include <utility>
#include <vector>
#include <jni.h>
#include "heap.h"
#include "globals.h"
#include "macros.h"
#include "stringpiece.h"
#include "unordered_set.h"
namespace art {
template<class T> class PrimitiveArray;
typedef PrimitiveArray<int8_t> ByteArray;
class ClassLinker;
class DexFile;
class Heap;
class InternTable;
class JavaVMExt;
class SignalCatcher;
class String;
class ThreadList;
class Runtime {
public:
typedef std::vector<std::pair<StringPiece, const void*> > Options;
class ParsedOptions {
public:
// returns null if problem parsing and ignore_unrecognized is false
static ParsedOptions* Create(const Options& options, bool ignore_unrecognized);
std::string boot_class_path_string_;
std::vector<const DexFile*> boot_class_path_;
std::string class_path_string_;
std::vector<const DexFile*> class_path_;
const char* boot_image_;
std::vector<const char*> images_;
bool check_jni_;
std::string jni_trace_;
size_t heap_initial_size_;
size_t heap_maximum_size_;
size_t stack_size_;
jint (*hook_vfprintf_)(FILE* stream, const char* format, va_list ap);
void (*hook_exit_)(jint status);
void (*hook_abort_)();
std::tr1::unordered_set<std::string> verbose_;
std::vector<std::string> properties_;
bool IsVerbose(const std::string& key) const {
return verbose_.find(key) != verbose_.end();
}
private:
ParsedOptions() {}
};
// Creates and initializes a new runtime.
static Runtime* Create(const Options& options, bool ignore_unrecognized);
// Starts a runtime, which may cause threads to be started and code to run.
void Start();
bool IsStarted();
static Runtime* Current() {
return instance_;
}
// Compiles a dex file.
static void Compile(const StringPiece& filename);
// Aborts semi-cleanly. Used in the implementation of LOG(FATAL), which most
// callers should prefer.
// This isn't marked ((noreturn)) because then gcc will merge multiple calls
// in a single function together. This reduces code size slightly, but means
// that the native stack trace we get may point at the wrong call site.
static void Abort(const char* file, int line);
// Attaches the current native thread to the runtime.
void AttachCurrentThread(const char* name, bool as_daemon);
void CallExitHook(jint status);
// Detaches the current native thread from the runtime.
void DetachCurrentThread();
void Dump(std::ostream& os);
~Runtime();
const std::string& GetBootClassPath() const {
return boot_class_path_;
}
ClassLinker* GetClassLinker() const {
return class_linker_;
}
const std::string& GetClassPath() const {
return class_path_;
}
size_t GetDefaultStackSize() const {
return default_stack_size_;
}
InternTable* GetInternTable() const {
return intern_table_;
}
JavaVMExt* GetJavaVM() const {
return java_vm_;
}
const std::vector<std::string>& GetProperties() const {
return properties_;
}
ThreadList* GetThreadList() const {
return thread_list_;
}
const char* GetVersion() const {
return "2.0.0";
}
void VisitRoots(Heap::RootVisitor* visitor, void* arg) const;
bool HasJniStubArray() const {
return jni_stub_array_ != NULL;
}
ByteArray* GetJniStubArray() const {
CHECK(jni_stub_array_ != NULL);
return jni_stub_array_;
}
void SetJniStubArray(ByteArray* jni_stub_array) {
CHECK(jni_stub_array != NULL);
CHECK(jni_stub_array_ == NULL || jni_stub_array_ == jni_stub_array);
jni_stub_array_ = jni_stub_array;
}
private:
static void PlatformAbort(const char*, int);
Runtime();
void BlockSignals();
bool Init(const Options& options, bool ignore_unrecognized);
void InitLibraries();
void RegisterRuntimeNativeMethods(JNIEnv*);
std::string boot_class_path_;
std::string class_path_;
std::vector<std::string> properties_;
// The default stack size for managed threads created by the runtime.
size_t default_stack_size_;
ThreadList* thread_list_;
InternTable* intern_table_;
ClassLinker* class_linker_;
SignalCatcher* signal_catcher_;
JavaVMExt* java_vm_;
ByteArray* jni_stub_array_;
bool started_;
// Hooks supported by JNI_CreateJavaVM
jint (*vfprintf_)(FILE* stream, const char* format, va_list ap);
void (*exit_)(jint status);
void (*abort_)();
// A pointer to the active runtime or NULL.
static Runtime* instance_;
DISALLOW_COPY_AND_ASSIGN(Runtime);
};
} // namespace art
#endif // ART_SRC_RUNTIME_H_