12 |
#include <sys/time.h> |
#include <sys/time.h> |
13 |
#include <time.h> |
#include <time.h> |
14 |
#include <netinet/in.h> |
#include <netinet/in.h> |
15 |
|
#include <pthread.h> |
16 |
|
#include <signal.h> |
17 |
|
|
18 |
/* True/False definitions */ |
/* True/False definitions */ |
19 |
#ifndef FALSE |
#ifndef FALSE |
24 |
#define TRUE 1 |
#define TRUE 1 |
25 |
#endif |
#endif |
26 |
|
|
27 |
|
/* Host CPU Types */ |
28 |
|
#define CPU_x86 0 |
29 |
|
#define CPU_amd64 1 |
30 |
|
#define CPU_nojit 2 |
31 |
|
|
32 |
|
/* Number of host registers available for JIT */ |
33 |
|
#if JIT_CPU == CPU_x86 |
34 |
|
#define JIT_HOST_NREG 8 |
35 |
|
#elif JIT_CPU == CPU_amd64 |
36 |
|
#define JIT_HOST_NREG 16 |
37 |
|
#else |
38 |
|
#define JIT_HOST_NREG 0 |
39 |
|
#endif |
40 |
|
|
41 |
/* Endianness */ |
/* Endianness */ |
42 |
#define ARCH_BIG_ENDIAN 0x4321 |
#define ARCH_BIG_ENDIAN 0x4321 |
43 |
#define ARCH_LITTLE_ENDIAN 0x1234 |
#define ARCH_LITTLE_ENDIAN 0x1234 |
52 |
#define ARCH_BYTE_ORDER ARCH_LITTLE_ENDIAN |
#define ARCH_BYTE_ORDER ARCH_LITTLE_ENDIAN |
53 |
#elif defined(__x86_64__) |
#elif defined(__x86_64__) |
54 |
#define ARCH_BYTE_ORDER ARCH_LITTLE_ENDIAN |
#define ARCH_BYTE_ORDER ARCH_LITTLE_ENDIAN |
55 |
|
#elif defined(__ia64__) |
56 |
|
#define ARCH_BYTE_ORDER ARCH_LITTLE_ENDIAN |
57 |
#endif |
#endif |
58 |
|
|
59 |
#ifndef ARCH_BYTE_ORDER |
#ifndef ARCH_BYTE_ORDER |
93 |
|
|
94 |
#if __GNUC__ > 2 |
#if __GNUC__ > 2 |
95 |
/* http://kerneltrap.org/node/4705 */ |
/* http://kerneltrap.org/node/4705 */ |
96 |
#define likely(x) __builtin_expect((x),1) |
#define likely(x) __builtin_expect(!!(x),1) |
97 |
#define unlikely(x) __builtin_expect((x),0) |
#define unlikely(x) __builtin_expect((x),0) |
98 |
#else |
#else |
99 |
#define likely(x) (x) |
#define likely(x) (x) |
117 |
typedef m_uint64_t m_tmcnt_t; |
typedef m_uint64_t m_tmcnt_t; |
118 |
|
|
119 |
/* Forward declarations */ |
/* Forward declarations */ |
120 |
|
typedef struct cpu_gen cpu_gen_t; |
121 |
typedef struct vm_instance vm_instance_t; |
typedef struct vm_instance vm_instance_t; |
122 |
|
typedef struct vm_platform vm_platform_t; |
123 |
typedef struct mips64_jit_tcb mips64_jit_tcb_t; |
typedef struct mips64_jit_tcb mips64_jit_tcb_t; |
124 |
typedef struct ppc32_jit_tcb ppc32_jit_tcb_t; |
typedef struct ppc32_jit_tcb ppc32_jit_tcb_t; |
125 |
|
typedef struct jit_op jit_op_t; |
126 |
|
|
127 |
/* Translated block function pointer */ |
/* Translated block function pointer */ |
128 |
typedef void (*insn_tblock_fptr)(void); |
typedef void (*insn_tblock_fptr)(void); |
172 |
m_uint64_t len; |
m_uint64_t len; |
173 |
m_uint32_t cached; |
m_uint32_t cached; |
174 |
m_uint32_t tlb_index; |
m_uint32_t tlb_index; |
175 |
|
m_uint32_t offset; |
176 |
}mts_map_t; |
}mts_map_t; |
177 |
|
|
178 |
/* Invalid VTLB entry */ |
/* Invalid VTLB entry */ |
179 |
#define MTS_INV_ENTRY_MASK 0x00000001 |
#define MTS_INV_ENTRY_MASK 0x00000001 |
180 |
|
|
181 |
/* MTS entry flags */ |
/* MTS entry flags */ |
182 |
#define MTS_FLAG_DEV 0x000000001 /* Virtual device used */ |
#define MTS_FLAG_DEV 0x000000001 /* Virtual device used */ |
183 |
#define MTS_FLAG_COW 0x000000002 /* Copy-On-Write */ |
#define MTS_FLAG_COW 0x000000002 /* Copy-On-Write */ |
184 |
|
#define MTS_FLAG_EXEC 0x000000004 /* Exec page */ |
185 |
|
|
186 |
/* Virtual TLB entry (32-bit MMU) */ |
/* Virtual TLB entry (32-bit MMU) */ |
187 |
typedef struct mts32_entry mts32_entry_t; |
typedef struct mts32_entry mts32_entry_t; |
201 |
m_uint32_t flags; /* Flags */ |
m_uint32_t flags; /* Flags */ |
202 |
}__attribute__ ((aligned(16))); |
}__attribute__ ((aligned(16))); |
203 |
|
|
204 |
|
/* Host register allocation */ |
205 |
|
#define HREG_FLAG_ALLOC_LOCKED 1 |
206 |
|
#define HREG_FLAG_ALLOC_FORCED 2 |
207 |
|
|
208 |
|
struct hreg_map { |
209 |
|
int hreg,vreg; |
210 |
|
int flags; |
211 |
|
struct hreg_map *prev,*next; |
212 |
|
}; |
213 |
|
|
214 |
/* Global logfile */ |
/* Global logfile */ |
215 |
extern FILE *log_file; |
extern FILE *log_file; |
216 |
|
|
357 |
char *m_fgets(char *buffer,int size,FILE *fd); |
char *m_fgets(char *buffer,int size,FILE *fd); |
358 |
|
|
359 |
/* Read a file and returns it in a buffer */ |
/* Read a file and returns it in a buffer */ |
360 |
ssize_t m_read_file(char *filename,char **buffer); |
ssize_t m_read_file(char *filename,u_char **buffer); |
361 |
|
|
362 |
/* Allocate aligned memory */ |
/* Allocate aligned memory */ |
363 |
void *m_memalign(size_t boundary,size_t size); |
void *m_memalign(size_t boundary,size_t size); |
392 |
/* Byte-swap a memory block */ |
/* Byte-swap a memory block */ |
393 |
void mem_bswap32(void *ptr,size_t len); |
void mem_bswap32(void *ptr,size_t len); |
394 |
|
|
395 |
|
/* Reverse a byte */ |
396 |
|
m_uint8_t m_reverse_u8(m_uint8_t val); |
397 |
|
|
398 |
#endif |
#endif |