* Merged with 62ddb0d81064.
[cacao.git] / src / vm / vm.hpp
1 /* src/vm/vm.hpp - basic JVM functions
2
3    Copyright (C) 1996-2005, 2006, 2007, 2008
4    CACAOVM - Verein zur Foerderung der freien virtuellen Maschine CACAO
5
6    This file is part of CACAO.
7
8    This program is free software; you can redistribute it and/or
9    modify it under the terms of the GNU General Public License as
10    published by the Free Software Foundation; either version 2, or (at
11    your option) any later version.
12
13    This program is distributed in the hope that it will be useful, but
14    WITHOUT ANY WARRANTY; without even the implied warranty of
15    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
16    General Public License for more details.
17
18    You should have received a copy of the GNU General Public License
19    along with this program; if not, write to the Free Software
20    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
21    02110-1301, USA.
22
23 */
24
25
26 #ifndef _VM_HPP
27 #define _VM_HPP
28
29 #include "config.h"
30
31 #include <stdarg.h>
32 #include <stdint.h>
33
34 // We need the JNI types for the VM class.
35 #include "native/jni.hpp"
36
37 #ifdef __cplusplus
38
39 /**
40  * Represent an instance of a VM.
41  */
42 class VM {
43 private:
44         // This is _the_ VM instance.
45         static VM* _vm;
46
47         // JNI variables.
48         JavaVM* _javavm;
49         JNIEnv* _jnienv;
50
51         // VM variables.
52         bool    _initializing;
53         bool    _created;
54         bool    _exiting;
55         int64_t _starttime;
56
57 public:
58         // Constructor, Destructor.
59         VM(JavaVMInitArgs*);
60         ~VM();
61
62         // Static methods.
63         static bool create(JavaVM** p_vm, void** p_env, void* vm_args);
64         static VM*  get_current() { return _vm; }
65
66         // Getters for private members.
67         JavaVM* get_javavm()      { return _javavm; }
68         JNIEnv* get_jnienv()      { return _jnienv; }
69         bool    is_initializing() { return _initializing; }
70         bool    is_created()      { return _created; }
71         bool    is_exiting()      { return _exiting; }
72         int64_t get_starttime()   { return _starttime; }
73
74         // Instance functions.
75         void abort(const char* text, ...);
76         void abort_errnum(int errnum, const char* text, ...);
77         void abort_errno(const char* text, ...);
78 };
79
80 #else
81
82 JavaVM* VM_get_javavm();
83 JNIEnv* VM_get_jnienv();
84 bool    VM_is_initializing();
85 bool    VM_is_created();
86 int64_t VM_get_starttime();
87
88 #endif
89
90
91 // Includes.
92 #include "vm/global.h"
93 #include "vm/method.h"
94
95
96 /* These C methods are the exported interface. ********************************/
97
98 #ifdef __cplusplus
99 extern "C" {
100 #endif
101
102 bool VM_create(JavaVM** p_vm, void** p_env, void* vm_args);
103
104 #ifdef __cplusplus
105 }
106 #endif
107
108
109 /* export global variables ****************************************************/
110
111 #if defined(ENABLE_INTRP)
112 extern uint8_t* intrp_main_stack;
113 #endif
114
115
116 /* function prototypes ********************************************************/
117
118 #ifdef __cplusplus
119 extern "C" {
120 #endif
121
122 void usage(void);
123
124 bool vm_create(JavaVMInitArgs *vm_args);
125 void vm_run(JavaVM *vm, JavaVMInitArgs *vm_args);
126 int32_t   vm_destroy(JavaVM *vm);
127 void vm_exit(int32_t status);
128 void vm_shutdown(int32_t status);
129
130 void vm_exit_handler(void);
131
132 void vm_abort_disassemble(void *pc, int count, const char *text, ...);
133
134 /* Java method calling functions */
135
136 java_handle_t *vm_call_method(methodinfo *m, java_handle_t *o, ...);
137 java_handle_t *vm_call_method_valist(methodinfo *m, java_handle_t *o,
138                                                                                  va_list ap);
139 java_handle_t *vm_call_method_jvalue(methodinfo *m, java_handle_t *o,
140                                                                                  const jvalue *args);
141
142 int32_t vm_call_method_int(methodinfo *m, java_handle_t *o, ...);
143 int32_t vm_call_method_int_valist(methodinfo *m, java_handle_t *o, va_list ap);
144 int32_t vm_call_method_int_jvalue(methodinfo *m, java_handle_t *o, const jvalue *args);
145
146 int64_t vm_call_method_long(methodinfo *m, java_handle_t *o, ...);
147 int64_t vm_call_method_long_valist(methodinfo *m, java_handle_t *o, va_list ap);
148 int64_t vm_call_method_long_jvalue(methodinfo *m, java_handle_t *o, const jvalue *args);
149
150 float   vm_call_method_float(methodinfo *m, java_handle_t *o, ...);
151 float   vm_call_method_float_valist(methodinfo *m, java_handle_t *o, va_list ap);
152 float   vm_call_method_float_jvalue(methodinfo *m, java_handle_t *o, const jvalue *args);
153
154 double  vm_call_method_double(methodinfo *m, java_handle_t *o, ...);
155 double  vm_call_method_double_valist(methodinfo *m, java_handle_t *o, va_list ap);
156 double  vm_call_method_double_jvalue(methodinfo *m, java_handle_t *o, const jvalue *args);
157
158 java_handle_t *vm_call_method_objectarray(methodinfo *m, java_handle_t *o, java_handle_objectarray_t *params);
159
160
161 // Legacy C interface.
162 void vm_abort(const char* text, ...);
163 void vm_abort_errnum(int errnum, const char* text, ...);
164 void vm_abort_errno(const char* text, ...);
165
166 #ifdef __cplusplus
167 }
168 #endif
169
170 #endif // _VM_HPP
171
172
173 /*
174  * These are local overrides for various environment variables in Emacs.
175  * Please do not remove this and leave it at the end of the file, where
176  * Emacs will automagically detect them.
177  * ---------------------------------------------------------------------
178  * Local variables:
179  * mode: c++
180  * indent-tabs-mode: t
181  * c-basic-offset: 4
182  * tab-width: 4
183  * End:
184  * vim:noexpandtab:sw=4:ts=4:
185  */