version 1.1.1.1, 2012/02/21 23:05:52
|
version 1.1.1.5, 2014/06/15 19:46:05
|
Line 1
|
Line 1
|
/* |
/* |
* Stack-less Just-In-Time compiler |
* Stack-less Just-In-Time compiler |
* |
* |
* Copyright 2009-2010 Zoltan Herczeg (hzmester@freemail.hu). All rights reserved. | * Copyright 2009-2012 Zoltan Herczeg (hzmester@freemail.hu). All rights reserved. |
* |
* |
* Redistribution and use in source and binary forms, with or without modification, are |
* Redistribution and use in source and binary forms, with or without modification, are |
* permitted provided that the following conditions are met: |
* permitted provided that the following conditions are met: |
Line 89
|
Line 89
|
((op) & (SLJIT_SET_E | SLJIT_SET_S | SLJIT_SET_U | SLJIT_SET_O | SLJIT_SET_C)) |
((op) & (SLJIT_SET_E | SLJIT_SET_S | SLJIT_SET_U | SLJIT_SET_O | SLJIT_SET_C)) |
|
|
#define GET_ALL_FLAGS(op) \ |
#define GET_ALL_FLAGS(op) \ |
((op) & (SLJIT_SET_E | SLJIT_SET_S | SLJIT_SET_U | SLJIT_SET_O | SLJIT_SET_C | SLJIT_KEEP_FLAGS)) | ((op) & (SLJIT_INT_OP | SLJIT_SET_E | SLJIT_SET_S | SLJIT_SET_U | SLJIT_SET_O | SLJIT_SET_C | SLJIT_KEEP_FLAGS)) |
|
|
|
#define TYPE_CAST_NEEDED(op) \ |
|
(((op) >= SLJIT_MOV_UB && (op) <= SLJIT_MOV_SH) || ((op) >= SLJIT_MOVU_UB && (op) <= SLJIT_MOVU_SH)) |
|
|
#define BUF_SIZE 4096 |
#define BUF_SIZE 4096 |
|
|
#if (defined SLJIT_32BIT_ARCHITECTURE && SLJIT_32BIT_ARCHITECTURE) |
#if (defined SLJIT_32BIT_ARCHITECTURE && SLJIT_32BIT_ARCHITECTURE) |
Line 105
|
Line 108
|
/* SLJIT_REWRITABLE_JUMP is 0x1000. */ |
/* SLJIT_REWRITABLE_JUMP is 0x1000. */ |
|
|
#if (defined SLJIT_CONFIG_X86_32 && SLJIT_CONFIG_X86_32) || (defined SLJIT_CONFIG_X86_64 && SLJIT_CONFIG_X86_64) |
#if (defined SLJIT_CONFIG_X86_32 && SLJIT_CONFIG_X86_32) || (defined SLJIT_CONFIG_X86_64 && SLJIT_CONFIG_X86_64) |
#define PATCH_MB 0x4 | # define PATCH_MB 0x4 |
#define PATCH_MW 0x8 | # define PATCH_MW 0x8 |
#if (defined SLJIT_CONFIG_X86_64 && SLJIT_CONFIG_X86_64) |
#if (defined SLJIT_CONFIG_X86_64 && SLJIT_CONFIG_X86_64) |
#define PATCH_MD 0x10 | # define PATCH_MD 0x10 |
#endif |
#endif |
#endif |
#endif |
|
|
#if (defined SLJIT_CONFIG_ARM_V5 && SLJIT_CONFIG_ARM_V5) || (defined SLJIT_CONFIG_ARM_V7 && SLJIT_CONFIG_ARM_V7) |
#if (defined SLJIT_CONFIG_ARM_V5 && SLJIT_CONFIG_ARM_V5) || (defined SLJIT_CONFIG_ARM_V7 && SLJIT_CONFIG_ARM_V7) |
#define IS_BL 0x4 | # define IS_BL 0x4 |
#define PATCH_B 0x8 | # define PATCH_B 0x8 |
#endif |
#endif |
|
|
#if (defined SLJIT_CONFIG_ARM_V5 && SLJIT_CONFIG_ARM_V5) |
#if (defined SLJIT_CONFIG_ARM_V5 && SLJIT_CONFIG_ARM_V5) |
#define CPOOL_SIZE 512 | # define CPOOL_SIZE 512 |
#endif |
#endif |
|
|
#if (defined SLJIT_CONFIG_ARM_THUMB2 && SLJIT_CONFIG_ARM_THUMB2) |
#if (defined SLJIT_CONFIG_ARM_THUMB2 && SLJIT_CONFIG_ARM_THUMB2) |
#define IS_CONDITIONAL 0x04 | # define IS_COND 0x04 |
#define IS_BL 0x08 | # define IS_BL 0x08 |
/* cannot be encoded as branch */ |
/* cannot be encoded as branch */ |
#define B_TYPE0 0x00 | # define B_TYPE0 0x00 |
/* conditional + imm8 */ |
/* conditional + imm8 */ |
#define B_TYPE1 0x10 | # define B_TYPE1 0x10 |
/* conditional + imm20 */ |
/* conditional + imm20 */ |
#define B_TYPE2 0x20 | # define B_TYPE2 0x20 |
/* IT + imm24 */ |
/* IT + imm24 */ |
#define B_TYPE3 0x30 | # define B_TYPE3 0x30 |
/* imm11 */ |
/* imm11 */ |
#define B_TYPE4 0x40 | # define B_TYPE4 0x40 |
/* imm24 */ |
/* imm24 */ |
#define B_TYPE5 0x50 | # define B_TYPE5 0x50 |
/* BL + imm24 */ |
/* BL + imm24 */ |
#define BL_TYPE6 0x60 | # define BL_TYPE6 0x60 |
/* 0xf00 cc code for branches */ |
/* 0xf00 cc code for branches */ |
#endif |
#endif |
|
|
#if (defined SLJIT_CONFIG_PPC_32 && SLJIT_CONFIG_PPC_32) || (defined SLJIT_CONFIG_PPC_64 && SLJIT_CONFIG_PPC_64) |
#if (defined SLJIT_CONFIG_PPC_32 && SLJIT_CONFIG_PPC_32) || (defined SLJIT_CONFIG_PPC_64 && SLJIT_CONFIG_PPC_64) |
#define UNCOND_B 0x04 | # define UNCOND_B 0x04 |
#define PATCH_B 0x08 | # define PATCH_B 0x08 |
#define ABSOLUTE_B 0x10 | # define ABSOLUTE_B 0x10 |
#endif |
#endif |
|
|
#if (defined SLJIT_CONFIG_MIPS_32 && SLJIT_CONFIG_MIPS_32) |
#if (defined SLJIT_CONFIG_MIPS_32 && SLJIT_CONFIG_MIPS_32) |
#define IS_MOVABLE 0x04 | # define IS_MOVABLE 0x04 |
#define IS_JAL 0x08 | # define IS_JAL 0x08 |
#define IS_BIT26_COND 0x10 | # define IS_BIT26_COND 0x10 |
#define IS_BIT16_COND 0x20 | # define IS_BIT16_COND 0x20 |
|
|
#define IS_COND (IS_BIT26_COND | IS_BIT16_COND) | # define IS_COND (IS_BIT26_COND | IS_BIT16_COND) |
|
|
#define PATCH_B 0x40 | # define PATCH_B 0x40 |
#define PATCH_J 0x80 | # define PATCH_J 0x80 |
|
|
/* instruction types */ |
/* instruction types */ |
#define UNMOVABLE_INS 0 | # define MOVABLE_INS 0 |
/* 1 - 31 last destination register */ |
/* 1 - 31 last destination register */ |
#define FCSR_FCC 32 |
|
/* no destination (i.e: store) */ |
/* no destination (i.e: store) */ |
#define MOVABLE_INS 33 | # define UNMOVABLE_INS 32 |
| /* FPU status register */ |
| # define FCSR_FCC 33 |
#endif |
#endif |
|
|
|
#if (defined SLJIT_CONFIG_TILEGX && SLJIT_CONFIG_TILEGX) |
|
# define IS_JAL 0x04 |
|
# define IS_COND 0x08 |
|
|
|
# define PATCH_B 0x10 |
|
# define PATCH_J 0x20 |
|
#endif |
|
|
|
#if (defined SLJIT_CONFIG_SPARC_32 && SLJIT_CONFIG_SPARC_32) |
|
# define IS_MOVABLE 0x04 |
|
# define IS_COND 0x08 |
|
# define IS_CALL 0x10 |
|
|
|
# define PATCH_B 0x20 |
|
# define PATCH_CALL 0x40 |
|
|
|
/* instruction types */ |
|
# define MOVABLE_INS 0 |
|
/* 1 - 31 last destination register */ |
|
/* no destination (i.e: store) */ |
|
# define UNMOVABLE_INS 32 |
|
|
|
# define DST_INS_MASK 0xff |
|
|
|
/* ICC_SET is the same as SET_FLAGS. */ |
|
# define ICC_IS_SET (1 << 23) |
|
# define FCC_IS_SET (1 << 24) |
|
#endif |
|
|
|
#if (defined SLJIT_CONFIG_X86_32 && SLJIT_CONFIG_X86_32) |
|
#define SLJIT_HAS_VARIABLE_LOCALS_OFFSET 1 |
|
#if !(defined SLJIT_X86_32_FASTCALL && SLJIT_X86_32_FASTCALL) |
|
#define FIXED_LOCALS_OFFSET (3 * sizeof(sljit_sw)) |
|
#endif |
|
#endif |
|
|
|
#if (defined SLJIT_CONFIG_X86_64 && SLJIT_CONFIG_X86_64) |
|
#define SLJIT_HAS_FIXED_LOCALS_OFFSET 1 |
|
#ifdef _WIN64 |
|
#define FIXED_LOCALS_OFFSET ((4 + 2) * sizeof(sljit_sw)) |
|
#else |
|
#define FIXED_LOCALS_OFFSET (sizeof(sljit_sw)) |
|
#endif |
|
#endif |
|
|
|
#if (defined SLJIT_CONFIG_PPC_32 && SLJIT_CONFIG_PPC_32) |
|
#define SLJIT_HAS_FIXED_LOCALS_OFFSET 1 |
|
#if (defined SLJIT_INDIRECT_CALL && SLJIT_INDIRECT_CALL) |
|
#define FIXED_LOCALS_OFFSET ((6 + 8) * sizeof(sljit_sw)) |
|
#else |
|
#define FIXED_LOCALS_OFFSET (2 * sizeof(sljit_sw)) |
|
#endif |
|
#endif |
|
|
|
#if (defined SLJIT_CONFIG_PPC_64 && SLJIT_CONFIG_PPC_64) |
|
#define SLJIT_HAS_FIXED_LOCALS_OFFSET 1 |
|
#define FIXED_LOCALS_OFFSET ((6 + 8) * sizeof(sljit_sw)) |
|
#endif |
|
|
|
#if (defined SLJIT_CONFIG_MIPS_32 && SLJIT_CONFIG_MIPS_32) |
|
#define SLJIT_HAS_FIXED_LOCALS_OFFSET 1 |
|
#define FIXED_LOCALS_OFFSET (4 * sizeof(sljit_sw)) |
|
#endif |
|
|
|
#if (defined SLJIT_CONFIG_SPARC_32 && SLJIT_CONFIG_SPARC_32) |
|
#define SLJIT_HAS_FIXED_LOCALS_OFFSET 1 |
|
#define FIXED_LOCALS_OFFSET (23 * sizeof(sljit_sw)) |
|
#endif |
|
|
|
#if (defined SLJIT_HAS_VARIABLE_LOCALS_OFFSET && SLJIT_HAS_VARIABLE_LOCALS_OFFSET) |
|
|
|
#define ADJUST_LOCAL_OFFSET(p, i) \ |
|
if ((p) == (SLJIT_MEM1(SLJIT_LOCALS_REG))) \ |
|
(i) += compiler->locals_offset; |
|
|
|
#elif (defined SLJIT_HAS_FIXED_LOCALS_OFFSET && SLJIT_HAS_FIXED_LOCALS_OFFSET) |
|
|
|
#define ADJUST_LOCAL_OFFSET(p, i) \ |
|
if ((p) == (SLJIT_MEM1(SLJIT_LOCALS_REG))) \ |
|
(i) += FIXED_LOCALS_OFFSET; |
|
|
|
#else |
|
|
|
#define ADJUST_LOCAL_OFFSET(p, i) |
|
|
|
#endif |
|
|
#endif /* !(defined SLJIT_CONFIG_UNSUPPORTED && SLJIT_CONFIG_UNSUPPORTED) */ |
#endif /* !(defined SLJIT_CONFIG_UNSUPPORTED && SLJIT_CONFIG_UNSUPPORTED) */ |
|
|
/* Utils can still be used even if SLJIT_CONFIG_UNSUPPORTED is set. */ |
/* Utils can still be used even if SLJIT_CONFIG_UNSUPPORTED is set. */ |
Line 187
|
Line 278
|
|
|
#if (defined SLJIT_CONFIG_ARM_V5 && SLJIT_CONFIG_ARM_V5) || ((defined SLJIT_SSE2 && SLJIT_SSE2) && ((defined SLJIT_CONFIG_X86_32 && SLJIT_CONFIG_X86_32) || (defined SLJIT_CONFIG_X86_64 && SLJIT_CONFIG_X86_64))) |
#if (defined SLJIT_CONFIG_ARM_V5 && SLJIT_CONFIG_ARM_V5) || ((defined SLJIT_SSE2 && SLJIT_SSE2) && ((defined SLJIT_CONFIG_X86_32 && SLJIT_CONFIG_X86_32) || (defined SLJIT_CONFIG_X86_64 && SLJIT_CONFIG_X86_64))) |
#define SLJIT_NEEDS_COMPILER_INIT 1 |
#define SLJIT_NEEDS_COMPILER_INIT 1 |
static int compiler_initialized = 0; | static sljit_si compiler_initialized = 0; |
/* A thread safe initialization. */ |
/* A thread safe initialization. */ |
static void init_compiler(void); |
static void init_compiler(void); |
#endif |
#endif |
|
|
|
|
SLJIT_API_FUNC_ATTRIBUTE struct sljit_compiler* sljit_create_compiler(void) |
SLJIT_API_FUNC_ATTRIBUTE struct sljit_compiler* sljit_create_compiler(void) |
{ |
{ |
struct sljit_compiler *compiler = (struct sljit_compiler*)SLJIT_MALLOC(sizeof(struct sljit_compiler)); |
struct sljit_compiler *compiler = (struct sljit_compiler*)SLJIT_MALLOC(sizeof(struct sljit_compiler)); |
Line 201 SLJIT_API_FUNC_ATTRIBUTE struct sljit_compiler* sljit_
|
Line 291 SLJIT_API_FUNC_ATTRIBUTE struct sljit_compiler* sljit_
|
SLJIT_ZEROMEM(compiler, sizeof(struct sljit_compiler)); |
SLJIT_ZEROMEM(compiler, sizeof(struct sljit_compiler)); |
|
|
SLJIT_COMPILE_ASSERT( |
SLJIT_COMPILE_ASSERT( |
sizeof(sljit_b) == 1 && sizeof(sljit_ub) == 1 | sizeof(sljit_sb) == 1 && sizeof(sljit_ub) == 1 |
&& sizeof(sljit_h) == 2 && sizeof(sljit_uh) == 2 | && sizeof(sljit_sh) == 2 && sizeof(sljit_uh) == 2 |
&& sizeof(sljit_i) == 4 && sizeof(sljit_ui) == 4 | && sizeof(sljit_si) == 4 && sizeof(sljit_ui) == 4 |
&& ((sizeof(sljit_w) == 4 && sizeof(sljit_uw) == 4) || (sizeof(sljit_w) == 8 && sizeof(sljit_uw) == 8)), | && (sizeof(sljit_p) == 4 || sizeof(sljit_p) == 8) |
| && sizeof(sljit_p) <= sizeof(sljit_sw) |
| && (sizeof(sljit_sw) == 4 || sizeof(sljit_sw) == 8) |
| && (sizeof(sljit_uw) == 4 || sizeof(sljit_uw) == 8), |
invalid_integer_types); |
invalid_integer_types); |
|
SLJIT_COMPILE_ASSERT(SLJIT_INT_OP == SLJIT_SINGLE_OP, |
|
int_op_and_single_op_must_be_the_same); |
|
SLJIT_COMPILE_ASSERT(SLJIT_REWRITABLE_JUMP != SLJIT_SINGLE_OP, |
|
rewritable_jump_and_single_op_must_not_be_the_same); |
|
|
/* Only the non-zero members must be set. */ |
/* Only the non-zero members must be set. */ |
compiler->error = SLJIT_SUCCESS; |
compiler->error = SLJIT_SUCCESS; |
Line 227 SLJIT_API_FUNC_ATTRIBUTE struct sljit_compiler* sljit_
|
Line 324 SLJIT_API_FUNC_ATTRIBUTE struct sljit_compiler* sljit_
|
compiler->abuf->next = NULL; |
compiler->abuf->next = NULL; |
compiler->abuf->used_size = 0; |
compiler->abuf->used_size = 0; |
|
|
compiler->temporaries = -1; | compiler->scratches = -1; |
compiler->generals = -1; | compiler->saveds = -1; |
|
|
#if (defined SLJIT_CONFIG_X86_32 && SLJIT_CONFIG_X86_32) |
#if (defined SLJIT_CONFIG_X86_32 && SLJIT_CONFIG_X86_32) |
compiler->args = -1; |
compiler->args = -1; |
Line 250 SLJIT_API_FUNC_ATTRIBUTE struct sljit_compiler* sljit_
|
Line 347 SLJIT_API_FUNC_ATTRIBUTE struct sljit_compiler* sljit_
|
compiler->delay_slot = UNMOVABLE_INS; |
compiler->delay_slot = UNMOVABLE_INS; |
#endif |
#endif |
|
|
|
#if (defined SLJIT_CONFIG_SPARC_32 && SLJIT_CONFIG_SPARC_32) |
|
compiler->delay_slot = UNMOVABLE_INS; |
|
#endif |
|
|
#if (defined SLJIT_NEEDS_COMPILER_INIT && SLJIT_NEEDS_COMPILER_INIT) |
#if (defined SLJIT_NEEDS_COMPILER_INIT && SLJIT_NEEDS_COMPILER_INIT) |
if (!compiler_initialized) { |
if (!compiler_initialized) { |
init_compiler(); |
init_compiler(); |
Line 291 SLJIT_API_FUNC_ATTRIBUTE void sljit_free_code(void* co
|
Line 392 SLJIT_API_FUNC_ATTRIBUTE void sljit_free_code(void* co
|
/* Remove thumb mode flag. */ |
/* Remove thumb mode flag. */ |
SLJIT_FREE_EXEC((void*)((sljit_uw)code & ~0x1)); |
SLJIT_FREE_EXEC((void*)((sljit_uw)code & ~0x1)); |
} |
} |
#elif (defined SLJIT_CONFIG_PPC_64 && SLJIT_CONFIG_PPC_64) | #elif (defined SLJIT_INDIRECT_CALL && SLJIT_INDIRECT_CALL) |
SLJIT_API_FUNC_ATTRIBUTE void sljit_free_code(void* code) |
SLJIT_API_FUNC_ATTRIBUTE void sljit_free_code(void* code) |
{ |
{ |
/* Resolve indirection. */ |
/* Resolve indirection. */ |
Line 329 SLJIT_API_FUNC_ATTRIBUTE void sljit_set_target(struct
|
Line 430 SLJIT_API_FUNC_ATTRIBUTE void sljit_set_target(struct
|
/* Private functions */ |
/* Private functions */ |
/* --------------------------------------------------------------------- */ |
/* --------------------------------------------------------------------- */ |
|
|
static void* ensure_buf(struct sljit_compiler *compiler, int size) | static void* ensure_buf(struct sljit_compiler *compiler, sljit_uw size) |
{ |
{ |
sljit_ub *ret; |
sljit_ub *ret; |
struct sljit_memory_fragment *new_frag; |
struct sljit_memory_fragment *new_frag; |
|
|
if (compiler->buf->used_size + size <= (int)(BUF_SIZE - sizeof(sljit_uw) - sizeof(void*))) { | SLJIT_ASSERT(size <= 256); |
| if (compiler->buf->used_size + size <= (BUF_SIZE - (sljit_uw)SLJIT_OFFSETOF(struct sljit_memory_fragment, memory))) { |
ret = compiler->buf->memory + compiler->buf->used_size; |
ret = compiler->buf->memory + compiler->buf->used_size; |
compiler->buf->used_size += size; |
compiler->buf->used_size += size; |
return ret; |
return ret; |
Line 347 static void* ensure_buf(struct sljit_compiler *compile
|
Line 449 static void* ensure_buf(struct sljit_compiler *compile
|
return new_frag->memory; |
return new_frag->memory; |
} |
} |
|
|
static void* ensure_abuf(struct sljit_compiler *compiler, int size) | static void* ensure_abuf(struct sljit_compiler *compiler, sljit_uw size) |
{ |
{ |
sljit_ub *ret; |
sljit_ub *ret; |
struct sljit_memory_fragment *new_frag; |
struct sljit_memory_fragment *new_frag; |
|
|
if (compiler->abuf->used_size + size <= (int)(ABUF_SIZE - sizeof(sljit_uw) - sizeof(void*))) { | SLJIT_ASSERT(size <= 256); |
| if (compiler->abuf->used_size + size <= (ABUF_SIZE - (sljit_uw)SLJIT_OFFSETOF(struct sljit_memory_fragment, memory))) { |
ret = compiler->abuf->memory + compiler->abuf->used_size; |
ret = compiler->abuf->memory + compiler->abuf->used_size; |
compiler->abuf->used_size += size; |
compiler->abuf->used_size += size; |
return ret; |
return ret; |
Line 365 static void* ensure_abuf(struct sljit_compiler *compil
|
Line 468 static void* ensure_abuf(struct sljit_compiler *compil
|
return new_frag->memory; |
return new_frag->memory; |
} |
} |
|
|
SLJIT_API_FUNC_ATTRIBUTE void* sljit_alloc_memory(struct sljit_compiler *compiler, int size) | SLJIT_API_FUNC_ATTRIBUTE void* sljit_alloc_memory(struct sljit_compiler *compiler, sljit_si size) |
{ |
{ |
CHECK_ERROR_PTR(); |
CHECK_ERROR_PTR(); |
|
|
Line 408 static SLJIT_INLINE void set_label(struct sljit_label
|
Line 511 static SLJIT_INLINE void set_label(struct sljit_label
|
compiler->last_label = label; |
compiler->last_label = label; |
} |
} |
|
|
static SLJIT_INLINE void set_jump(struct sljit_jump *jump, struct sljit_compiler *compiler, int flags) | static SLJIT_INLINE void set_jump(struct sljit_jump *jump, struct sljit_compiler *compiler, sljit_si flags) |
{ |
{ |
jump->next = NULL; |
jump->next = NULL; |
jump->flags = flags; |
jump->flags = flags; |
Line 453 static SLJIT_INLINE void set_const(struct sljit_const
|
Line 556 static SLJIT_INLINE void set_const(struct sljit_const
|
case SLJIT_MUL: \ |
case SLJIT_MUL: \ |
SLJIT_ASSERT(!(op & (SLJIT_SET_E | SLJIT_SET_S | SLJIT_SET_U | SLJIT_SET_C))); \ |
SLJIT_ASSERT(!(op & (SLJIT_SET_E | SLJIT_SET_S | SLJIT_SET_U | SLJIT_SET_C))); \ |
break; \ |
break; \ |
case SLJIT_FCMP: \ | case SLJIT_CMPD: \ |
SLJIT_ASSERT(!(op & (SLJIT_INT_OP | SLJIT_SET_U | SLJIT_SET_O | SLJIT_SET_C | SLJIT_KEEP_FLAGS))); \ | SLJIT_ASSERT(!(op & (SLJIT_SET_U | SLJIT_SET_O | SLJIT_SET_C | SLJIT_KEEP_FLAGS))); \ |
SLJIT_ASSERT((op & (SLJIT_SET_E | SLJIT_SET_S))); \ |
SLJIT_ASSERT((op & (SLJIT_SET_E | SLJIT_SET_S))); \ |
break; \ |
break; \ |
case SLJIT_ADD: \ |
case SLJIT_ADD: \ |
Line 466 static SLJIT_INLINE void set_const(struct sljit_const
|
Line 569 static SLJIT_INLINE void set_const(struct sljit_const
|
case SLJIT_SUBC: \ |
case SLJIT_SUBC: \ |
SLJIT_ASSERT(!(op & (SLJIT_SET_E | SLJIT_SET_S | SLJIT_SET_U | SLJIT_SET_O))); \ |
SLJIT_ASSERT(!(op & (SLJIT_SET_E | SLJIT_SET_S | SLJIT_SET_U | SLJIT_SET_O))); \ |
break; \ |
break; \ |
default: \ | case SLJIT_BREAKPOINT: \ |
| case SLJIT_NOP: \ |
| case SLJIT_UMUL: \ |
| case SLJIT_SMUL: \ |
| case SLJIT_MOV: \ |
| case SLJIT_MOV_P: \ |
| case SLJIT_MOVU: \ |
| case SLJIT_MOVU_P: \ |
/* Nothing allowed */ \ |
/* Nothing allowed */ \ |
SLJIT_ASSERT(!(op & (SLJIT_INT_OP | SLJIT_SET_E | SLJIT_SET_S | SLJIT_SET_U | SLJIT_SET_O | SLJIT_SET_C | SLJIT_KEEP_FLAGS))); \ |
SLJIT_ASSERT(!(op & (SLJIT_INT_OP | SLJIT_SET_E | SLJIT_SET_S | SLJIT_SET_U | SLJIT_SET_O | SLJIT_SET_C | SLJIT_KEEP_FLAGS))); \ |
break; \ |
break; \ |
|
default: \ |
|
/* Only SLJIT_INT_OP or SLJIT_SINGLE_OP is allowed. */ \ |
|
SLJIT_ASSERT(!(op & (SLJIT_SET_E | SLJIT_SET_S | SLJIT_SET_U | SLJIT_SET_O | SLJIT_SET_C | SLJIT_KEEP_FLAGS))); \ |
|
break; \ |
} |
} |
|
|
#define FUNCTION_CHECK_IS_REG(r) \ |
#define FUNCTION_CHECK_IS_REG(r) \ |
((r) == SLJIT_UNUSED || (r) == SLJIT_LOCALS_REG || \ | ((r) == SLJIT_UNUSED || \ |
((r) >= SLJIT_TEMPORARY_REG1 && (r) <= SLJIT_TEMPORARY_REG3 && (r) <= SLJIT_TEMPORARY_REG1 - 1 + compiler->temporaries) || \ | ((r) >= SLJIT_SCRATCH_REG1 && (r) <= SLJIT_SCRATCH_REG1 - 1 + compiler->scratches) || \ |
((r) >= SLJIT_GENERAL_REG1 && (r) <= SLJIT_GENERAL_REG3 && (r) <= SLJIT_GENERAL_REG1 - 1 + compiler->generals)) \ | ((r) >= SLJIT_SAVED_REG1 && (r) <= SLJIT_SAVED_REG1 - 1 + compiler->saveds)) |
|
|
#define FUNCTION_CHECK_SRC(p, i) \ |
#define FUNCTION_CHECK_SRC(p, i) \ |
SLJIT_ASSERT(compiler->temporaries != -1 && compiler->generals != -1); \ | SLJIT_ASSERT(compiler->scratches != -1 && compiler->saveds != -1); \ |
if (((p) >= SLJIT_TEMPORARY_REG1 && (p) <= SLJIT_TEMPORARY_REG1 - 1 + compiler->temporaries) || \ | if (FUNCTION_CHECK_IS_REG(p)) \ |
((p) >= SLJIT_GENERAL_REG1 && (p) <= SLJIT_GENERAL_REG1 - 1 + compiler->generals) || \ | SLJIT_ASSERT((i) == 0 && (p) != SLJIT_UNUSED); \ |
(p) == SLJIT_LOCALS_REG) \ | |
SLJIT_ASSERT(i == 0); \ | |
else if ((p) == SLJIT_IMM) \ |
else if ((p) == SLJIT_IMM) \ |
; \ |
; \ |
|
else if ((p) == (SLJIT_MEM1(SLJIT_LOCALS_REG))) \ |
|
SLJIT_ASSERT((i) >= 0 && (i) < compiler->logical_local_size); \ |
else if ((p) & SLJIT_MEM) { \ |
else if ((p) & SLJIT_MEM) { \ |
SLJIT_ASSERT(FUNCTION_CHECK_IS_REG((p) & 0xf)); \ |
SLJIT_ASSERT(FUNCTION_CHECK_IS_REG((p) & 0xf)); \ |
if ((p) & 0xf0) { \ |
if ((p) & 0xf0) { \ |
SLJIT_ASSERT(FUNCTION_CHECK_IS_REG(((p) >> 4) & 0xf)); \ |
SLJIT_ASSERT(FUNCTION_CHECK_IS_REG(((p) >> 4) & 0xf)); \ |
SLJIT_ASSERT(((p) & 0xf0) != (SLJIT_LOCALS_REG << 4) && !(i & ~0x3)); \ | SLJIT_ASSERT(!((i) & ~0x3)); \ |
} else \ | } \ |
SLJIT_ASSERT((((p) >> 4) & 0xf) == 0); \ | |
SLJIT_ASSERT(((p) >> 9) == 0); \ |
SLJIT_ASSERT(((p) >> 9) == 0); \ |
} \ |
} \ |
else \ |
else \ |
SLJIT_ASSERT_STOP(); |
SLJIT_ASSERT_STOP(); |
|
|
#define FUNCTION_CHECK_DST(p, i) \ |
#define FUNCTION_CHECK_DST(p, i) \ |
SLJIT_ASSERT(compiler->temporaries != -1 && compiler->generals != -1); \ | SLJIT_ASSERT(compiler->scratches != -1 && compiler->saveds != -1); \ |
if (((p) >= SLJIT_TEMPORARY_REG1 && (p) <= SLJIT_TEMPORARY_REG1 - 1 + compiler->temporaries) || \ | if (FUNCTION_CHECK_IS_REG(p)) \ |
((p) >= SLJIT_GENERAL_REG1 && (p) <= SLJIT_GENERAL_REG1 - 1 + compiler->generals) || \ | SLJIT_ASSERT((i) == 0); \ |
(p) == SLJIT_UNUSED) \ | else if ((p) == (SLJIT_MEM1(SLJIT_LOCALS_REG))) \ |
SLJIT_ASSERT(i == 0); \ | SLJIT_ASSERT((i) >= 0 && (i) < compiler->logical_local_size); \ |
else if ((p) & SLJIT_MEM) { \ |
else if ((p) & SLJIT_MEM) { \ |
SLJIT_ASSERT(FUNCTION_CHECK_IS_REG((p) & 0xf)); \ |
SLJIT_ASSERT(FUNCTION_CHECK_IS_REG((p) & 0xf)); \ |
if ((p) & 0xf0) { \ |
if ((p) & 0xf0) { \ |
SLJIT_ASSERT(FUNCTION_CHECK_IS_REG(((p) >> 4) & 0xf)); \ |
SLJIT_ASSERT(FUNCTION_CHECK_IS_REG(((p) >> 4) & 0xf)); \ |
SLJIT_ASSERT(((p) & 0xf0) != (SLJIT_LOCALS_REG << 4) && !(i & ~0x3)); \ | SLJIT_ASSERT(!((i) & ~0x3)); \ |
} else \ | } \ |
SLJIT_ASSERT((((p) >> 4) & 0xf) == 0); \ | |
SLJIT_ASSERT(((p) >> 9) == 0); \ |
SLJIT_ASSERT(((p) >> 9) == 0); \ |
} \ |
} \ |
else \ |
else \ |
SLJIT_ASSERT_STOP(); |
SLJIT_ASSERT_STOP(); |
|
|
#define FUNCTION_FCHECK(p, i) \ |
#define FUNCTION_FCHECK(p, i) \ |
if ((p) >= SLJIT_FLOAT_REG1 && (p) <= SLJIT_FLOAT_REG4) \ | if ((p) >= SLJIT_FLOAT_REG1 && (p) <= SLJIT_FLOAT_REG6) \ |
SLJIT_ASSERT(i == 0); \ |
SLJIT_ASSERT(i == 0); \ |
else if ((p) & SLJIT_MEM) { \ |
else if ((p) & SLJIT_MEM) { \ |
SLJIT_ASSERT(FUNCTION_CHECK_IS_REG((p) & 0xf)); \ |
SLJIT_ASSERT(FUNCTION_CHECK_IS_REG((p) & 0xf)); \ |
Line 531 static SLJIT_INLINE void set_const(struct sljit_const
|
Line 643 static SLJIT_INLINE void set_const(struct sljit_const
|
SLJIT_ASSERT_STOP(); |
SLJIT_ASSERT_STOP(); |
|
|
#define FUNCTION_CHECK_OP1() \ |
#define FUNCTION_CHECK_OP1() \ |
if (GET_OPCODE(op) >= SLJIT_MOV && GET_OPCODE(op) <= SLJIT_MOVU_SI) { \ | if (GET_OPCODE(op) >= SLJIT_MOVU && GET_OPCODE(op) <= SLJIT_MOVU_P) { \ |
SLJIT_ASSERT(!GET_ALL_FLAGS(op)); \ | |
} \ | |
if (GET_OPCODE(op) >= SLJIT_MOVU && GET_OPCODE(op) <= SLJIT_MOVU_SI) { \ | |
SLJIT_ASSERT(!(src & SLJIT_MEM) || (src & 0xf) != SLJIT_LOCALS_REG); \ |
SLJIT_ASSERT(!(src & SLJIT_MEM) || (src & 0xf) != SLJIT_LOCALS_REG); \ |
SLJIT_ASSERT(!(dst & SLJIT_MEM) || (dst & 0xf) != SLJIT_LOCALS_REG); \ |
SLJIT_ASSERT(!(dst & SLJIT_MEM) || (dst & 0xf) != SLJIT_LOCALS_REG); \ |
if ((src & SLJIT_MEM) && (src & 0xf)) \ |
if ((src & SLJIT_MEM) && (src & 0xf)) \ |
Line 551 SLJIT_API_FUNC_ATTRIBUTE void sljit_compiler_verbose(s
|
Line 660 SLJIT_API_FUNC_ATTRIBUTE void sljit_compiler_verbose(s
|
} |
} |
|
|
static char* reg_names[] = { |
static char* reg_names[] = { |
(char*)"<noreg>", (char*)"tmp_r1", (char*)"tmp_r2", (char*)"tmp_r3", | (char*)"unused", (char*)"s1", (char*)"s2", (char*)"s3", |
(char*)"tmp_er1", (char*)"tmp_er2", (char*)"gen_r1", (char*)"gen_r2", | (char*)"se1", (char*)"se2", (char*)"p1", (char*)"p2", |
(char*)"gen_r3", (char*)"gen_er1", (char*)"gen_er2", (char*)"stack_r" | (char*)"p3", (char*)"pe1", (char*)"pe2", (char*)"lc" |
}; |
}; |
|
|
static char* freg_names[] = { |
static char* freg_names[] = { |
(char*)"<noreg>", (char*)"float_r1", (char*)"float_r2", (char*)"float_r3", (char*)"float_r4" | (char*)"unused", (char*)"f1", (char*)"f2", (char*)"f3", |
| (char*)"f4", (char*)"f5", (char*)"f6" |
}; |
}; |
|
|
#if (defined SLJIT_CONFIG_X86_64 && SLJIT_CONFIG_X86_64) || (defined SLJIT_CONFIG_PPC_64 && SLJIT_CONFIG_PPC_64) |
#if (defined SLJIT_CONFIG_X86_64 && SLJIT_CONFIG_X86_64) || (defined SLJIT_CONFIG_PPC_64 && SLJIT_CONFIG_PPC_64) |
#ifdef _WIN64 |
#ifdef _WIN64 |
#define SLJIT_PRINT_D "I64" | # define SLJIT_PRINT_D "I64" |
#else |
#else |
#define SLJIT_PRINT_D "l" | # define SLJIT_PRINT_D "l" |
#endif |
#endif |
#else |
#else |
#define SLJIT_PRINT_D "" | # define SLJIT_PRINT_D "" |
#endif |
#endif |
|
|
#define sljit_verbose_param(p, i) \ |
#define sljit_verbose_param(p, i) \ |
if ((p) & SLJIT_IMM) \ |
if ((p) & SLJIT_IMM) \ |
fprintf(compiler->verbose, "#%"SLJIT_PRINT_D"d", (i)); \ | fprintf(compiler->verbose, "#%" SLJIT_PRINT_D "d", (i)); \ |
else if ((p) & SLJIT_MEM) { \ |
else if ((p) & SLJIT_MEM) { \ |
if ((p) & 0xf) { \ |
if ((p) & 0xf) { \ |
if (i) { \ |
if (i) { \ |
if (((p) >> 4) & 0xf) \ |
if (((p) >> 4) & 0xf) \ |
fprintf(compiler->verbose, "[%s + %s * %d]", reg_names[(p) & 0xF], reg_names[((p) >> 4)& 0xF], 1 << (i)); \ |
fprintf(compiler->verbose, "[%s + %s * %d]", reg_names[(p) & 0xF], reg_names[((p) >> 4)& 0xF], 1 << (i)); \ |
else \ |
else \ |
fprintf(compiler->verbose, "[%s + #%"SLJIT_PRINT_D"d]", reg_names[(p) & 0xF], (i)); \ | fprintf(compiler->verbose, "[%s + #%" SLJIT_PRINT_D "d]", reg_names[(p) & 0xF], (i)); \ |
} \ |
} \ |
else { \ |
else { \ |
if (((p) >> 4) & 0xf) \ |
if (((p) >> 4) & 0xf) \ |
Line 589 static char* freg_names[] = {
|
Line 699 static char* freg_names[] = {
|
} \ |
} \ |
} \ |
} \ |
else \ |
else \ |
fprintf(compiler->verbose, "[#%"SLJIT_PRINT_D"d]", (i)); \ | fprintf(compiler->verbose, "[#%" SLJIT_PRINT_D "d]", (i)); \ |
} else \ |
} else \ |
fprintf(compiler->verbose, "%s", reg_names[p]); |
fprintf(compiler->verbose, "%s", reg_names[p]); |
#define sljit_verbose_fparam(p, i) \ |
#define sljit_verbose_fparam(p, i) \ |
Line 599 static char* freg_names[] = {
|
Line 709 static char* freg_names[] = {
|
if (((p) >> 4) & 0xf) \ |
if (((p) >> 4) & 0xf) \ |
fprintf(compiler->verbose, "[%s + %s * %d]", reg_names[(p) & 0xF], reg_names[((p) >> 4)& 0xF], 1 << (i)); \ |
fprintf(compiler->verbose, "[%s + %s * %d]", reg_names[(p) & 0xF], reg_names[((p) >> 4)& 0xF], 1 << (i)); \ |
else \ |
else \ |
fprintf(compiler->verbose, "[%s + #%"SLJIT_PRINT_D"d]", reg_names[(p) & 0xF], (i)); \ | fprintf(compiler->verbose, "[%s + #%" SLJIT_PRINT_D "d]", reg_names[(p) & 0xF], (i)); \ |
} \ |
} \ |
else { \ |
else { \ |
if (((p) >> 4) & 0xF) \ |
if (((p) >> 4) & 0xF) \ |
Line 609 static char* freg_names[] = {
|
Line 719 static char* freg_names[] = {
|
} \ |
} \ |
} \ |
} \ |
else \ |
else \ |
fprintf(compiler->verbose, "[#%"SLJIT_PRINT_D"d]", (i)); \ | fprintf(compiler->verbose, "[#%" SLJIT_PRINT_D "d]", (i)); \ |
} else \ |
} else \ |
fprintf(compiler->verbose, "%s", freg_names[p]); |
fprintf(compiler->verbose, "%s", freg_names[p]); |
|
|
static SLJIT_CONST char* op_names[] = { |
static SLJIT_CONST char* op_names[] = { |
/* op0 */ |
/* op0 */ |
(char*)"breakpoint", (char*)"nop", |
(char*)"breakpoint", (char*)"nop", |
|
(char*)"umul", (char*)"smul", (char*)"udiv", (char*)"sdiv", |
/* op1 */ |
/* op1 */ |
(char*)"mov", (char*)"mov.ub", (char*)"mov.sb", (char*)"mov.uh", |
(char*)"mov", (char*)"mov.ub", (char*)"mov.sb", (char*)"mov.uh", |
(char*)"mov.sh", (char*)"mov.ui", (char*)"mov.si", (char*)"movu", | (char*)"mov.sh", (char*)"mov.ui", (char*)"mov.si", (char*)"mov.p", |
(char*)"movu.ub", (char*)"movu.sb", (char*)"movu.uh", (char*)"movu.sh", | (char*)"movu", (char*)"movu.ub", (char*)"movu.sb", (char*)"movu.uh", |
(char*)"movu.ui", (char*)"movu.si", (char*)"not", (char*)"neg", | (char*)"movu.sh", (char*)"movu.ui", (char*)"movu.si", (char*)"movu.p", |
(char*)"clz", | (char*)"not", (char*)"neg", (char*)"clz", |
/* op2 */ |
/* op2 */ |
(char*)"add", (char*)"addc", (char*)"sub", (char*)"subc", |
(char*)"add", (char*)"addc", (char*)"sub", (char*)"subc", |
(char*)"mul", (char*)"and", (char*)"or", (char*)"xor", |
(char*)"mul", (char*)"and", (char*)"or", (char*)"xor", |
(char*)"shl", (char*)"lshr", (char*)"ashr", |
(char*)"shl", (char*)"lshr", (char*)"ashr", |
/* fop1 */ |
/* fop1 */ |
(char*)"fcmp", (char*)"fmov", (char*)"fneg", (char*)"fabs", | (char*)"cmp", (char*)"mov", (char*)"neg", (char*)"abs", |
/* fop2 */ |
/* fop2 */ |
(char*)"fadd", (char*)"fsub", (char*)"fmul", (char*)"fdiv" | (char*)"add", (char*)"sub", (char*)"mul", (char*)"div" |
}; |
}; |
|
|
static char* jump_names[] = { |
static char* jump_names[] = { |
(char*)"c_equal", (char*)"c_not_equal", | (char*)"equal", (char*)"not_equal", |
(char*)"c_less", (char*)"c_greater_equal", | (char*)"less", (char*)"greater_equal", |
(char*)"c_greater", (char*)"c_less_equal", | (char*)"greater", (char*)"less_equal", |
(char*)"c_sig_less", (char*)"c_sig_greater_equal", | (char*)"sig_less", (char*)"sig_greater_equal", |
(char*)"c_sig_greater", (char*)"c_sig_less_equal", | (char*)"sig_greater", (char*)"sig_less_equal", |
(char*)"c_overflow", (char*)"c_not_overflow", | (char*)"overflow", (char*)"not_overflow", |
(char*)"c_mul_overflow", (char*)"c_mul_not_overflow", | (char*)"mul_overflow", (char*)"mul_not_overflow", |
(char*)"c_float_equal", (char*)"c_float_not_equal", | (char*)"float_equal", (char*)"float_not_equal", |
(char*)"c_float_less", (char*)"c_float_greater_equal", | (char*)"float_less", (char*)"float_greater_equal", |
(char*)"c_float_greater", (char*)"c_float_less_equal", | (char*)"float_greater", (char*)"float_less_equal", |
(char*)"c_float_nan", (char*)"c_float_not_nan", | (char*)"float_unordered", (char*)"float_ordered", |
(char*)"jump", (char*)"fast_call", |
(char*)"jump", (char*)"fast_call", |
(char*)"call0", (char*)"call1", (char*)"call2", (char*)"call3" |
(char*)"call0", (char*)"call1", (char*)"call2", (char*)"call3" |
}; |
}; |
Line 673 static SLJIT_INLINE void check_sljit_generate_code(str
|
Line 784 static SLJIT_INLINE void check_sljit_generate_code(str
|
#endif |
#endif |
} |
} |
|
|
static SLJIT_INLINE void check_sljit_emit_enter(struct sljit_compiler *compiler, int args, int temporaries, int generals, int local_size) | static SLJIT_INLINE void check_sljit_emit_enter(struct sljit_compiler *compiler, sljit_si args, sljit_si scratches, sljit_si saveds, sljit_si local_size) |
{ |
{ |
/* If debug and verbose are disabled, all arguments are unused. */ |
/* If debug and verbose are disabled, all arguments are unused. */ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(args); |
SLJIT_UNUSED_ARG(args); |
SLJIT_UNUSED_ARG(temporaries); | SLJIT_UNUSED_ARG(scratches); |
SLJIT_UNUSED_ARG(generals); | SLJIT_UNUSED_ARG(saveds); |
SLJIT_UNUSED_ARG(local_size); |
SLJIT_UNUSED_ARG(local_size); |
|
|
SLJIT_ASSERT(args >= 0 && args <= 3); |
SLJIT_ASSERT(args >= 0 && args <= 3); |
SLJIT_ASSERT(temporaries >= 0 && temporaries <= SLJIT_NO_TMP_REGISTERS); | SLJIT_ASSERT(scratches >= 0 && scratches <= SLJIT_NO_TMP_REGISTERS); |
SLJIT_ASSERT(generals >= 0 && generals <= SLJIT_NO_GEN_REGISTERS); | SLJIT_ASSERT(saveds >= 0 && saveds <= SLJIT_NO_GEN_REGISTERS); |
SLJIT_ASSERT(args <= generals); | SLJIT_ASSERT(args <= saveds); |
SLJIT_ASSERT(local_size >= 0 && local_size <= SLJIT_MAX_LOCAL_SIZE); |
SLJIT_ASSERT(local_size >= 0 && local_size <= SLJIT_MAX_LOCAL_SIZE); |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
if (SLJIT_UNLIKELY(!!compiler->verbose)) |
if (SLJIT_UNLIKELY(!!compiler->verbose)) |
fprintf(compiler->verbose, " enter args=%d temporaries=%d generals=%d local_size=%d\n", args, temporaries, generals, local_size); | fprintf(compiler->verbose, " enter args=%d scratches=%d saveds=%d local_size=%d\n", args, scratches, saveds, local_size); |
#endif |
#endif |
} |
} |
|
|
static SLJIT_INLINE void check_sljit_fake_enter(struct sljit_compiler *compiler, int args, int temporaries, int generals, int local_size) | static SLJIT_INLINE void check_sljit_set_context(struct sljit_compiler *compiler, sljit_si args, sljit_si scratches, sljit_si saveds, sljit_si local_size) |
{ |
{ |
/* If debug and verbose are disabled, all arguments are unused. */ |
/* If debug and verbose are disabled, all arguments are unused. */ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(args); |
SLJIT_UNUSED_ARG(args); |
SLJIT_UNUSED_ARG(temporaries); | SLJIT_UNUSED_ARG(scratches); |
SLJIT_UNUSED_ARG(generals); | SLJIT_UNUSED_ARG(saveds); |
SLJIT_UNUSED_ARG(local_size); |
SLJIT_UNUSED_ARG(local_size); |
|
|
|
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) || (defined SLJIT_DEBUG && SLJIT_DEBUG) |
|
if (SLJIT_UNLIKELY(compiler->skip_checks)) { |
|
compiler->skip_checks = 0; |
|
return; |
|
} |
|
#endif |
|
|
SLJIT_ASSERT(args >= 0 && args <= 3); |
SLJIT_ASSERT(args >= 0 && args <= 3); |
SLJIT_ASSERT(temporaries >= 0 && temporaries <= SLJIT_NO_TMP_REGISTERS); | SLJIT_ASSERT(scratches >= 0 && scratches <= SLJIT_NO_TMP_REGISTERS); |
SLJIT_ASSERT(generals >= 0 && generals <= SLJIT_NO_GEN_REGISTERS); | SLJIT_ASSERT(saveds >= 0 && saveds <= SLJIT_NO_GEN_REGISTERS); |
SLJIT_ASSERT(args <= generals); | SLJIT_ASSERT(args <= saveds); |
SLJIT_ASSERT(local_size >= 0 && local_size <= SLJIT_MAX_LOCAL_SIZE); |
SLJIT_ASSERT(local_size >= 0 && local_size <= SLJIT_MAX_LOCAL_SIZE); |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
if (SLJIT_UNLIKELY(!!compiler->verbose)) |
if (SLJIT_UNLIKELY(!!compiler->verbose)) |
fprintf(compiler->verbose, " fake_enter args=%d temporaries=%d generals=%d local_size=%d\n", args, temporaries, generals, local_size); | fprintf(compiler->verbose, " set_context args=%d scratches=%d saveds=%d local_size=%d\n", args, scratches, saveds, local_size); |
#endif |
#endif |
} |
} |
|
|
static SLJIT_INLINE void check_sljit_emit_return(struct sljit_compiler *compiler, int src, sljit_w srcw) | static SLJIT_INLINE void check_sljit_emit_return(struct sljit_compiler *compiler, sljit_si op, sljit_si src, sljit_sw srcw) |
{ |
{ |
/* If debug and verbose are disabled, all arguments are unused. */ |
/* If debug and verbose are disabled, all arguments are unused. */ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
|
SLJIT_UNUSED_ARG(op); |
SLJIT_UNUSED_ARG(src); |
SLJIT_UNUSED_ARG(src); |
SLJIT_UNUSED_ARG(srcw); |
SLJIT_UNUSED_ARG(srcw); |
|
|
#if (defined SLJIT_DEBUG && SLJIT_DEBUG) |
#if (defined SLJIT_DEBUG && SLJIT_DEBUG) |
if (src != SLJIT_UNUSED) { | if (op != SLJIT_UNUSED) { |
| SLJIT_ASSERT(op >= SLJIT_MOV && op <= SLJIT_MOV_P); |
FUNCTION_CHECK_SRC(src, srcw); |
FUNCTION_CHECK_SRC(src, srcw); |
} |
} |
else |
else |
SLJIT_ASSERT(srcw == 0); | SLJIT_ASSERT(src == 0 && srcw == 0); |
#endif |
#endif |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
fprintf(compiler->verbose, " return "); | if (op == SLJIT_UNUSED) |
sljit_verbose_param(src, srcw); | fprintf(compiler->verbose, " return\n"); |
fprintf(compiler->verbose, "\n"); | else { |
| fprintf(compiler->verbose, " return %s ", op_names[op]); |
| sljit_verbose_param(src, srcw); |
| fprintf(compiler->verbose, "\n"); |
| } |
} |
} |
#endif |
#endif |
} |
} |
|
|
static SLJIT_INLINE void check_sljit_emit_fast_enter(struct sljit_compiler *compiler, int dst, sljit_w dstw, int args, int temporaries, int generals, int local_size) | static SLJIT_INLINE void check_sljit_emit_fast_enter(struct sljit_compiler *compiler, sljit_si dst, sljit_sw dstw) |
{ |
{ |
/* If debug and verbose are disabled, all arguments are unused. */ |
/* If debug and verbose are disabled, all arguments are unused. */ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(dst); |
SLJIT_UNUSED_ARG(dst); |
SLJIT_UNUSED_ARG(dstw); |
SLJIT_UNUSED_ARG(dstw); |
SLJIT_UNUSED_ARG(args); |
|
SLJIT_UNUSED_ARG(temporaries); |
|
SLJIT_UNUSED_ARG(generals); |
|
SLJIT_UNUSED_ARG(local_size); |
|
|
|
SLJIT_ASSERT(args >= 0 && args <= 3); |
|
SLJIT_ASSERT(temporaries >= 0 && temporaries <= SLJIT_NO_TMP_REGISTERS); |
|
SLJIT_ASSERT(generals >= 0 && generals <= SLJIT_NO_GEN_REGISTERS); |
|
SLJIT_ASSERT(args <= generals); |
|
SLJIT_ASSERT(local_size >= 0 && local_size <= SLJIT_MAX_LOCAL_SIZE); |
|
#if (defined SLJIT_DEBUG && SLJIT_DEBUG) |
#if (defined SLJIT_DEBUG && SLJIT_DEBUG) |
compiler->temporaries = temporaries; |
|
compiler->generals = generals; |
|
FUNCTION_CHECK_DST(dst, dstw); |
FUNCTION_CHECK_DST(dst, dstw); |
compiler->temporaries = -1; |
|
compiler->generals = -1; |
|
#endif |
#endif |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
fprintf(compiler->verbose, " fast_enter "); |
fprintf(compiler->verbose, " fast_enter "); |
sljit_verbose_param(dst, dstw); |
sljit_verbose_param(dst, dstw); |
fprintf(compiler->verbose, " args=%d temporaries=%d generals=%d local_size=%d\n", args, temporaries, generals, local_size); | fprintf(compiler->verbose, "\n"); |
} |
} |
#endif |
#endif |
} |
} |
|
|
static SLJIT_INLINE void check_sljit_emit_fast_return(struct sljit_compiler *compiler, int src, sljit_w srcw) | static SLJIT_INLINE void check_sljit_emit_fast_return(struct sljit_compiler *compiler, sljit_si src, sljit_sw srcw) |
{ |
{ |
/* If debug and verbose are disabled, all arguments are unused. */ |
/* If debug and verbose are disabled, all arguments are unused. */ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
Line 787 static SLJIT_INLINE void check_sljit_emit_fast_return(
|
Line 898 static SLJIT_INLINE void check_sljit_emit_fast_return(
|
#endif |
#endif |
} |
} |
|
|
static SLJIT_INLINE void check_sljit_emit_op0(struct sljit_compiler *compiler, int op) | static SLJIT_INLINE void check_sljit_emit_op0(struct sljit_compiler *compiler, sljit_si op) |
{ |
{ |
/* If debug and verbose are disabled, all arguments are unused. */ |
/* If debug and verbose are disabled, all arguments are unused. */ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(op); |
SLJIT_UNUSED_ARG(op); |
|
|
SLJIT_ASSERT(op >= SLJIT_BREAKPOINT && op <= SLJIT_NOP); | SLJIT_ASSERT((op >= SLJIT_BREAKPOINT && op <= SLJIT_SMUL) |
| || ((op & ~SLJIT_INT_OP) >= SLJIT_UDIV && (op & ~SLJIT_INT_OP) <= SLJIT_SDIV)); |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
if (SLJIT_UNLIKELY(!!compiler->verbose)) |
if (SLJIT_UNLIKELY(!!compiler->verbose)) |
fprintf(compiler->verbose, " %s\n", op_names[op]); | fprintf(compiler->verbose, " %s%s\n", !(op & SLJIT_INT_OP) ? "" : "i", op_names[GET_OPCODE(op)]); |
#endif |
#endif |
} |
} |
|
|
static SLJIT_INLINE void check_sljit_emit_op1(struct sljit_compiler *compiler, int op, | static SLJIT_INLINE void check_sljit_emit_op1(struct sljit_compiler *compiler, sljit_si op, |
int dst, sljit_w dstw, | sljit_si dst, sljit_sw dstw, |
int src, sljit_w srcw) | sljit_si src, sljit_sw srcw) |
{ |
{ |
/* If debug and verbose are disabled, all arguments are unused. */ |
/* If debug and verbose are disabled, all arguments are unused. */ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
Line 812 static SLJIT_INLINE void check_sljit_emit_op1(struct s
|
Line 924 static SLJIT_INLINE void check_sljit_emit_op1(struct s
|
SLJIT_UNUSED_ARG(src); |
SLJIT_UNUSED_ARG(src); |
SLJIT_UNUSED_ARG(srcw); |
SLJIT_UNUSED_ARG(srcw); |
|
|
|
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) || (defined SLJIT_DEBUG && SLJIT_DEBUG) |
|
if (SLJIT_UNLIKELY(compiler->skip_checks)) { |
|
compiler->skip_checks = 0; |
|
return; |
|
} |
|
#endif |
|
|
SLJIT_ASSERT(GET_OPCODE(op) >= SLJIT_MOV && GET_OPCODE(op) <= SLJIT_CLZ); |
SLJIT_ASSERT(GET_OPCODE(op) >= SLJIT_MOV && GET_OPCODE(op) <= SLJIT_CLZ); |
#if (defined SLJIT_DEBUG && SLJIT_DEBUG) |
#if (defined SLJIT_DEBUG && SLJIT_DEBUG) |
FUNCTION_CHECK_OP(); |
FUNCTION_CHECK_OP(); |
Line 822 static SLJIT_INLINE void check_sljit_emit_op1(struct s
|
Line 941 static SLJIT_INLINE void check_sljit_emit_op1(struct s
|
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
fprintf(compiler->verbose, " %s%s%s%s%s%s%s%s ", !(op & SLJIT_INT_OP) ? "" : "i", op_names[GET_OPCODE(op)], |
fprintf(compiler->verbose, " %s%s%s%s%s%s%s%s ", !(op & SLJIT_INT_OP) ? "" : "i", op_names[GET_OPCODE(op)], |
!(op & SLJIT_SET_E) ? "" : "E", !(op & SLJIT_SET_S) ? "" : "S", !(op & SLJIT_SET_U) ? "" : "U", !(op & SLJIT_SET_O) ? "" : "O", !(op & SLJIT_SET_C) ? "" : "C", !(op & SLJIT_KEEP_FLAGS) ? "" : "K"); | !(op & SLJIT_SET_E) ? "" : ".e", !(op & SLJIT_SET_S) ? "" : ".s", !(op & SLJIT_SET_U) ? "" : ".u", |
| !(op & SLJIT_SET_O) ? "" : ".o", !(op & SLJIT_SET_C) ? "" : ".c", !(op & SLJIT_KEEP_FLAGS) ? "" : ".k"); |
sljit_verbose_param(dst, dstw); |
sljit_verbose_param(dst, dstw); |
fprintf(compiler->verbose, ", "); |
fprintf(compiler->verbose, ", "); |
sljit_verbose_param(src, srcw); |
sljit_verbose_param(src, srcw); |
Line 831 static SLJIT_INLINE void check_sljit_emit_op1(struct s
|
Line 951 static SLJIT_INLINE void check_sljit_emit_op1(struct s
|
#endif |
#endif |
} |
} |
|
|
static SLJIT_INLINE void check_sljit_emit_op2(struct sljit_compiler *compiler, int op, | static SLJIT_INLINE void check_sljit_emit_op2(struct sljit_compiler *compiler, sljit_si op, |
int dst, sljit_w dstw, | sljit_si dst, sljit_sw dstw, |
int src1, sljit_w src1w, | sljit_si src1, sljit_sw src1w, |
int src2, sljit_w src2w) | sljit_si src2, sljit_sw src2w) |
{ |
{ |
/* If debug and verbose are disabled, all arguments are unused. */ |
/* If debug and verbose are disabled, all arguments are unused. */ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
Line 863 static SLJIT_INLINE void check_sljit_emit_op2(struct s
|
Line 983 static SLJIT_INLINE void check_sljit_emit_op2(struct s
|
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
fprintf(compiler->verbose, " %s%s%s%s%s%s%s%s ", !(op & SLJIT_INT_OP) ? "" : "i", op_names[GET_OPCODE(op)], |
fprintf(compiler->verbose, " %s%s%s%s%s%s%s%s ", !(op & SLJIT_INT_OP) ? "" : "i", op_names[GET_OPCODE(op)], |
!(op & SLJIT_SET_E) ? "" : "E", !(op & SLJIT_SET_S) ? "" : "S", !(op & SLJIT_SET_U) ? "" : "U", !(op & SLJIT_SET_O) ? "" : "O", !(op & SLJIT_SET_C) ? "" : "C", !(op & SLJIT_KEEP_FLAGS) ? "" : "K"); | !(op & SLJIT_SET_E) ? "" : ".e", !(op & SLJIT_SET_S) ? "" : ".s", !(op & SLJIT_SET_U) ? "" : ".u", |
| !(op & SLJIT_SET_O) ? "" : ".o", !(op & SLJIT_SET_C) ? "" : ".c", !(op & SLJIT_KEEP_FLAGS) ? "" : ".k"); |
sljit_verbose_param(dst, dstw); |
sljit_verbose_param(dst, dstw); |
fprintf(compiler->verbose, ", "); |
fprintf(compiler->verbose, ", "); |
sljit_verbose_param(src1, src1w); |
sljit_verbose_param(src1, src1w); |
Line 874 static SLJIT_INLINE void check_sljit_emit_op2(struct s
|
Line 995 static SLJIT_INLINE void check_sljit_emit_op2(struct s
|
#endif |
#endif |
} |
} |
|
|
static SLJIT_INLINE void check_sljit_emit_fop1(struct sljit_compiler *compiler, int op, | static SLJIT_INLINE void check_sljit_get_register_index(sljit_si reg) |
int dst, sljit_w dstw, | |
int src, sljit_w srcw) | |
{ |
{ |
|
SLJIT_UNUSED_ARG(reg); |
|
SLJIT_ASSERT(reg > 0 && reg <= SLJIT_NO_REGISTERS); |
|
} |
|
|
|
static SLJIT_INLINE void check_sljit_get_float_register_index(sljit_si reg) |
|
{ |
|
SLJIT_UNUSED_ARG(reg); |
|
SLJIT_ASSERT(reg > 0 && reg <= SLJIT_NO_FLOAT_REGISTERS); |
|
} |
|
|
|
static SLJIT_INLINE void check_sljit_emit_op_custom(struct sljit_compiler *compiler, |
|
void *instruction, sljit_si size) |
|
{ |
|
SLJIT_UNUSED_ARG(compiler); |
|
SLJIT_UNUSED_ARG(instruction); |
|
SLJIT_UNUSED_ARG(size); |
|
SLJIT_ASSERT(instruction); |
|
} |
|
|
|
static SLJIT_INLINE void check_sljit_emit_fop1(struct sljit_compiler *compiler, sljit_si op, |
|
sljit_si dst, sljit_sw dstw, |
|
sljit_si src, sljit_sw srcw) |
|
{ |
/* If debug and verbose are disabled, all arguments are unused. */ |
/* If debug and verbose are disabled, all arguments are unused. */ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(op); |
SLJIT_UNUSED_ARG(op); |
Line 886 static SLJIT_INLINE void check_sljit_emit_fop1(struct
|
Line 1028 static SLJIT_INLINE void check_sljit_emit_fop1(struct
|
SLJIT_UNUSED_ARG(src); |
SLJIT_UNUSED_ARG(src); |
SLJIT_UNUSED_ARG(srcw); |
SLJIT_UNUSED_ARG(srcw); |
|
|
|
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) || (defined SLJIT_DEBUG && SLJIT_DEBUG) |
|
if (SLJIT_UNLIKELY(compiler->skip_checks)) { |
|
compiler->skip_checks = 0; |
|
return; |
|
} |
|
#endif |
|
|
SLJIT_ASSERT(sljit_is_fpu_available()); |
SLJIT_ASSERT(sljit_is_fpu_available()); |
SLJIT_ASSERT(GET_OPCODE(op) >= SLJIT_FCMP && GET_OPCODE(op) <= SLJIT_FABS); | SLJIT_ASSERT(GET_OPCODE(op) >= SLJIT_CMPD && GET_OPCODE(op) <= SLJIT_ABSD); |
#if (defined SLJIT_DEBUG && SLJIT_DEBUG) |
#if (defined SLJIT_DEBUG && SLJIT_DEBUG) |
FUNCTION_CHECK_OP(); |
FUNCTION_CHECK_OP(); |
FUNCTION_FCHECK(src, srcw); |
FUNCTION_FCHECK(src, srcw); |
Line 895 static SLJIT_INLINE void check_sljit_emit_fop1(struct
|
Line 1044 static SLJIT_INLINE void check_sljit_emit_fop1(struct
|
#endif |
#endif |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
fprintf(compiler->verbose, " %s%s%s ", op_names[GET_OPCODE(op)], | fprintf(compiler->verbose, " %s%s%s%s ", op_names[GET_OPCODE(op)], (op & SLJIT_SINGLE_OP) ? "s" : "d", |
!(op & SLJIT_SET_E) ? "" : "E", !(op & SLJIT_SET_S) ? "" : "S"); | !(op & SLJIT_SET_E) ? "" : ".e", !(op & SLJIT_SET_S) ? "" : ".s"); |
sljit_verbose_fparam(dst, dstw); |
sljit_verbose_fparam(dst, dstw); |
fprintf(compiler->verbose, ", "); |
fprintf(compiler->verbose, ", "); |
sljit_verbose_fparam(src, srcw); |
sljit_verbose_fparam(src, srcw); |
Line 905 static SLJIT_INLINE void check_sljit_emit_fop1(struct
|
Line 1054 static SLJIT_INLINE void check_sljit_emit_fop1(struct
|
#endif |
#endif |
} |
} |
|
|
static SLJIT_INLINE void check_sljit_emit_fop2(struct sljit_compiler *compiler, int op, | static SLJIT_INLINE void check_sljit_emit_fop2(struct sljit_compiler *compiler, sljit_si op, |
int dst, sljit_w dstw, | sljit_si dst, sljit_sw dstw, |
int src1, sljit_w src1w, | sljit_si src1, sljit_sw src1w, |
int src2, sljit_w src2w) | sljit_si src2, sljit_sw src2w) |
{ |
{ |
/* If debug and verbose are disabled, all arguments are unused. */ |
/* If debug and verbose are disabled, all arguments are unused. */ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
Line 921 static SLJIT_INLINE void check_sljit_emit_fop2(struct
|
Line 1070 static SLJIT_INLINE void check_sljit_emit_fop2(struct
|
SLJIT_UNUSED_ARG(src2w); |
SLJIT_UNUSED_ARG(src2w); |
|
|
SLJIT_ASSERT(sljit_is_fpu_available()); |
SLJIT_ASSERT(sljit_is_fpu_available()); |
SLJIT_ASSERT(GET_OPCODE(op) >= SLJIT_FADD && GET_OPCODE(op) <= SLJIT_FDIV); | SLJIT_ASSERT(GET_OPCODE(op) >= SLJIT_ADDD && GET_OPCODE(op) <= SLJIT_DIVD); |
#if (defined SLJIT_DEBUG && SLJIT_DEBUG) |
#if (defined SLJIT_DEBUG && SLJIT_DEBUG) |
FUNCTION_CHECK_OP(); |
FUNCTION_CHECK_OP(); |
FUNCTION_FCHECK(src1, src1w); |
FUNCTION_FCHECK(src1, src1w); |
Line 930 static SLJIT_INLINE void check_sljit_emit_fop2(struct
|
Line 1079 static SLJIT_INLINE void check_sljit_emit_fop2(struct
|
#endif |
#endif |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
fprintf(compiler->verbose, " %s ", op_names[GET_OPCODE(op)]); | fprintf(compiler->verbose, " %s%s ", op_names[GET_OPCODE(op)], (op & SLJIT_SINGLE_OP) ? "s" : "d"); |
sljit_verbose_fparam(dst, dstw); |
sljit_verbose_fparam(dst, dstw); |
fprintf(compiler->verbose, ", "); |
fprintf(compiler->verbose, ", "); |
sljit_verbose_fparam(src1, src1w); |
sljit_verbose_fparam(src1, src1w); |
Line 952 static SLJIT_INLINE void check_sljit_emit_label(struct
|
Line 1101 static SLJIT_INLINE void check_sljit_emit_label(struct
|
#endif |
#endif |
} |
} |
|
|
static SLJIT_INLINE void check_sljit_emit_jump(struct sljit_compiler *compiler, int type) | static SLJIT_INLINE void check_sljit_emit_jump(struct sljit_compiler *compiler, sljit_si type) |
{ |
{ |
/* If debug and verbose are disabled, all arguments are unused. */ |
/* If debug and verbose are disabled, all arguments are unused. */ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
Line 969 static SLJIT_INLINE void check_sljit_emit_jump(struct
|
Line 1118 static SLJIT_INLINE void check_sljit_emit_jump(struct
|
SLJIT_ASSERT((type & 0xff) >= SLJIT_C_EQUAL && (type & 0xff) <= SLJIT_CALL3); |
SLJIT_ASSERT((type & 0xff) >= SLJIT_C_EQUAL && (type & 0xff) <= SLJIT_CALL3); |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
if (SLJIT_UNLIKELY(!!compiler->verbose)) |
if (SLJIT_UNLIKELY(!!compiler->verbose)) |
fprintf(compiler->verbose, " jump%s <%s>\n", !(type & SLJIT_REWRITABLE_JUMP) ? "" : "R", jump_names[type & 0xff]); | fprintf(compiler->verbose, " jump%s.%s\n", !(type & SLJIT_REWRITABLE_JUMP) ? "" : ".r", jump_names[type & 0xff]); |
#endif |
#endif |
} |
} |
|
|
static SLJIT_INLINE void check_sljit_emit_cmp(struct sljit_compiler *compiler, int type, | static SLJIT_INLINE void check_sljit_emit_cmp(struct sljit_compiler *compiler, sljit_si type, |
int src1, sljit_w src1w, | sljit_si src1, sljit_sw src1w, |
int src2, sljit_w src2w) | sljit_si src2, sljit_sw src2w) |
{ |
{ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(type); |
SLJIT_UNUSED_ARG(type); |
Line 984 static SLJIT_INLINE void check_sljit_emit_cmp(struct s
|
Line 1133 static SLJIT_INLINE void check_sljit_emit_cmp(struct s
|
SLJIT_UNUSED_ARG(src2); |
SLJIT_UNUSED_ARG(src2); |
SLJIT_UNUSED_ARG(src2w); |
SLJIT_UNUSED_ARG(src2w); |
|
|
SLJIT_ASSERT(!(type & ~(0xff | SLJIT_INT_OP | SLJIT_REWRITABLE_JUMP))); | SLJIT_ASSERT(!(type & ~(0xff | SLJIT_REWRITABLE_JUMP | SLJIT_INT_OP))); |
SLJIT_ASSERT((type & 0xff) >= SLJIT_C_EQUAL && (type & 0xff) <= SLJIT_C_SIG_LESS_EQUAL); |
SLJIT_ASSERT((type & 0xff) >= SLJIT_C_EQUAL && (type & 0xff) <= SLJIT_C_SIG_LESS_EQUAL); |
#if (defined SLJIT_DEBUG && SLJIT_DEBUG) |
#if (defined SLJIT_DEBUG && SLJIT_DEBUG) |
FUNCTION_CHECK_SRC(src1, src1w); |
FUNCTION_CHECK_SRC(src1, src1w); |
Line 992 static SLJIT_INLINE void check_sljit_emit_cmp(struct s
|
Line 1141 static SLJIT_INLINE void check_sljit_emit_cmp(struct s
|
#endif |
#endif |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
fprintf(compiler->verbose, " %scmp%s <%s> ", !(type & SLJIT_INT_OP) ? "" : "i", !(type & SLJIT_REWRITABLE_JUMP) ? "" : "R", jump_names[type & 0xff]); | fprintf(compiler->verbose, " %scmp%s.%s ", !(type & SLJIT_INT_OP) ? "" : "i", !(type & SLJIT_REWRITABLE_JUMP) ? "" : ".r", jump_names[type & 0xff]); |
sljit_verbose_param(src1, src1w); |
sljit_verbose_param(src1, src1w); |
fprintf(compiler->verbose, ", "); |
fprintf(compiler->verbose, ", "); |
sljit_verbose_param(src2, src2w); |
sljit_verbose_param(src2, src2w); |
Line 1001 static SLJIT_INLINE void check_sljit_emit_cmp(struct s
|
Line 1150 static SLJIT_INLINE void check_sljit_emit_cmp(struct s
|
#endif |
#endif |
} |
} |
|
|
static SLJIT_INLINE void check_sljit_emit_ijump(struct sljit_compiler *compiler, int type, int src, sljit_w srcw) | static SLJIT_INLINE void check_sljit_emit_fcmp(struct sljit_compiler *compiler, sljit_si type, |
| sljit_si src1, sljit_sw src1w, |
| sljit_si src2, sljit_sw src2w) |
{ |
{ |
|
SLJIT_UNUSED_ARG(compiler); |
|
SLJIT_UNUSED_ARG(type); |
|
SLJIT_UNUSED_ARG(src1); |
|
SLJIT_UNUSED_ARG(src1w); |
|
SLJIT_UNUSED_ARG(src2); |
|
SLJIT_UNUSED_ARG(src2w); |
|
|
|
SLJIT_ASSERT(sljit_is_fpu_available()); |
|
SLJIT_ASSERT(!(type & ~(0xff | SLJIT_REWRITABLE_JUMP | SLJIT_SINGLE_OP))); |
|
SLJIT_ASSERT((type & 0xff) >= SLJIT_C_FLOAT_EQUAL && (type & 0xff) <= SLJIT_C_FLOAT_ORDERED); |
|
#if (defined SLJIT_DEBUG && SLJIT_DEBUG) |
|
FUNCTION_FCHECK(src1, src1w); |
|
FUNCTION_FCHECK(src2, src2w); |
|
#endif |
|
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
|
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
|
fprintf(compiler->verbose, " %scmp%s.%s ", (type & SLJIT_SINGLE_OP) ? "s" : "d", |
|
!(type & SLJIT_REWRITABLE_JUMP) ? "" : ".r", jump_names[type & 0xff]); |
|
sljit_verbose_fparam(src1, src1w); |
|
fprintf(compiler->verbose, ", "); |
|
sljit_verbose_fparam(src2, src2w); |
|
fprintf(compiler->verbose, "\n"); |
|
} |
|
#endif |
|
} |
|
|
|
static SLJIT_INLINE void check_sljit_emit_ijump(struct sljit_compiler *compiler, sljit_si type, sljit_si src, sljit_sw srcw) |
|
{ |
/* If debug and verbose are disabled, all arguments are unused. */ |
/* If debug and verbose are disabled, all arguments are unused. */ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(type); |
SLJIT_UNUSED_ARG(type); |
SLJIT_UNUSED_ARG(src); |
SLJIT_UNUSED_ARG(src); |
SLJIT_UNUSED_ARG(srcw); |
SLJIT_UNUSED_ARG(srcw); |
|
|
|
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) || (defined SLJIT_DEBUG && SLJIT_DEBUG) |
|
if (SLJIT_UNLIKELY(compiler->skip_checks)) { |
|
compiler->skip_checks = 0; |
|
return; |
|
} |
|
#endif |
|
|
SLJIT_ASSERT(type >= SLJIT_JUMP && type <= SLJIT_CALL3); |
SLJIT_ASSERT(type >= SLJIT_JUMP && type <= SLJIT_CALL3); |
#if (defined SLJIT_DEBUG && SLJIT_DEBUG) |
#if (defined SLJIT_DEBUG && SLJIT_DEBUG) |
FUNCTION_CHECK_SRC(src, srcw); |
FUNCTION_CHECK_SRC(src, srcw); |
#endif |
#endif |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
fprintf(compiler->verbose, " ijump <%s> ", jump_names[type]); | fprintf(compiler->verbose, " ijump.%s ", jump_names[type]); |
sljit_verbose_param(src, srcw); |
sljit_verbose_param(src, srcw); |
fprintf(compiler->verbose, "\n"); |
fprintf(compiler->verbose, "\n"); |
} |
} |
#endif |
#endif |
} |
} |
|
|
static SLJIT_INLINE void check_sljit_emit_cond_value(struct sljit_compiler *compiler, int op, int dst, sljit_w dstw, int type) | static SLJIT_INLINE void check_sljit_emit_op_flags(struct sljit_compiler *compiler, sljit_si op, |
| sljit_si dst, sljit_sw dstw, |
| sljit_si src, sljit_sw srcw, |
| sljit_si type) |
{ |
{ |
/* If debug and verbose are disabled, all arguments are unused. */ |
/* If debug and verbose are disabled, all arguments are unused. */ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(op); |
SLJIT_UNUSED_ARG(op); |
SLJIT_UNUSED_ARG(dst); |
SLJIT_UNUSED_ARG(dst); |
SLJIT_UNUSED_ARG(dstw); |
SLJIT_UNUSED_ARG(dstw); |
|
SLJIT_UNUSED_ARG(src); |
|
SLJIT_UNUSED_ARG(srcw); |
SLJIT_UNUSED_ARG(type); |
SLJIT_UNUSED_ARG(type); |
|
|
SLJIT_ASSERT(type >= SLJIT_C_EQUAL && type < SLJIT_JUMP); |
SLJIT_ASSERT(type >= SLJIT_C_EQUAL && type < SLJIT_JUMP); |
SLJIT_ASSERT(op == SLJIT_MOV || GET_OPCODE(op) == SLJIT_OR); | SLJIT_ASSERT(op == SLJIT_MOV || GET_OPCODE(op) == SLJIT_MOV_UI || GET_OPCODE(op) == SLJIT_MOV_SI |
SLJIT_ASSERT(GET_ALL_FLAGS(op) == 0 || GET_ALL_FLAGS(op) == SLJIT_SET_E || GET_ALL_FLAGS(op) == SLJIT_KEEP_FLAGS); | || (GET_OPCODE(op) >= SLJIT_AND && GET_OPCODE(op) <= SLJIT_XOR)); |
| SLJIT_ASSERT((op & (SLJIT_SET_S | SLJIT_SET_U | SLJIT_SET_O | SLJIT_SET_C)) == 0); |
| SLJIT_ASSERT((op & (SLJIT_SET_E | SLJIT_KEEP_FLAGS)) != (SLJIT_SET_E | SLJIT_KEEP_FLAGS)); |
#if (defined SLJIT_DEBUG && SLJIT_DEBUG) |
#if (defined SLJIT_DEBUG && SLJIT_DEBUG) |
|
if (GET_OPCODE(op) < SLJIT_ADD) { |
|
SLJIT_ASSERT(src == SLJIT_UNUSED && srcw == 0); |
|
} else { |
|
SLJIT_ASSERT(src == dst && srcw == dstw); |
|
} |
FUNCTION_CHECK_DST(dst, dstw); |
FUNCTION_CHECK_DST(dst, dstw); |
#endif |
#endif |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
fprintf(compiler->verbose, " cond_set%s%s <%s> ", !(op & SLJIT_SET_E) ? "" : "E", | fprintf(compiler->verbose, " %sflags.%s%s%s ", !(op & SLJIT_INT_OP) ? "" : "i", |
!(op & SLJIT_KEEP_FLAGS) ? "" : "K", op_names[GET_OPCODE(op)]); | op_names[GET_OPCODE(op)], !(op & SLJIT_SET_E) ? "" : ".e", !(op & SLJIT_KEEP_FLAGS) ? "" : ".k"); |
sljit_verbose_param(dst, dstw); |
sljit_verbose_param(dst, dstw); |
fprintf(compiler->verbose, ", <%s>\n", jump_names[type]); | if (src != SLJIT_UNUSED) { |
| fprintf(compiler->verbose, ", "); |
| sljit_verbose_param(src, srcw); |
| } |
| fprintf(compiler->verbose, ", %s\n", jump_names[type]); |
} |
} |
#endif |
#endif |
} |
} |
|
|
static SLJIT_INLINE void check_sljit_emit_const(struct sljit_compiler *compiler, int dst, sljit_w dstw, sljit_w init_value) | static SLJIT_INLINE void check_sljit_get_local_base(struct sljit_compiler *compiler, sljit_si dst, sljit_sw dstw, sljit_sw offset) |
{ |
{ |
|
SLJIT_UNUSED_ARG(compiler); |
|
SLJIT_UNUSED_ARG(dst); |
|
SLJIT_UNUSED_ARG(dstw); |
|
SLJIT_UNUSED_ARG(offset); |
|
|
|
#if (defined SLJIT_DEBUG && SLJIT_DEBUG) |
|
FUNCTION_CHECK_DST(dst, dstw); |
|
#endif |
|
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) |
|
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
|
fprintf(compiler->verbose, " local_base "); |
|
sljit_verbose_param(dst, dstw); |
|
fprintf(compiler->verbose, ", #%" SLJIT_PRINT_D "d\n", offset); |
|
} |
|
#endif |
|
} |
|
|
|
static SLJIT_INLINE void check_sljit_emit_const(struct sljit_compiler *compiler, sljit_si dst, sljit_sw dstw, sljit_sw init_value) |
|
{ |
/* If debug and verbose are disabled, all arguments are unused. */ |
/* If debug and verbose are disabled, all arguments are unused. */ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(dst); |
SLJIT_UNUSED_ARG(dst); |
Line 1062 static SLJIT_INLINE void check_sljit_emit_const(struct
|
Line 1283 static SLJIT_INLINE void check_sljit_emit_const(struct
|
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
if (SLJIT_UNLIKELY(!!compiler->verbose)) { |
fprintf(compiler->verbose, " const "); |
fprintf(compiler->verbose, " const "); |
sljit_verbose_param(dst, dstw); |
sljit_verbose_param(dst, dstw); |
fprintf(compiler->verbose, ", #%"SLJIT_PRINT_D"d\n", init_value); | fprintf(compiler->verbose, ", #%" SLJIT_PRINT_D "d\n", init_value); |
} |
} |
#endif |
#endif |
} |
} |
|
|
|
static SLJIT_INLINE sljit_si emit_mov_before_return(struct sljit_compiler *compiler, sljit_si op, sljit_si src, sljit_sw srcw) |
|
{ |
|
/* Return if don't need to do anything. */ |
|
if (op == SLJIT_UNUSED) |
|
return SLJIT_SUCCESS; |
|
|
|
#if (defined SLJIT_64BIT_ARCHITECTURE && SLJIT_64BIT_ARCHITECTURE) |
|
/* At the moment the pointer size is always equal to sljit_sw. May be changed in the future. */ |
|
if (src == SLJIT_RETURN_REG && (op == SLJIT_MOV || op == SLJIT_MOV_P)) |
|
return SLJIT_SUCCESS; |
|
#else |
|
if (src == SLJIT_RETURN_REG && (op == SLJIT_MOV || op == SLJIT_MOV_UI || op == SLJIT_MOV_SI || op == SLJIT_MOV_P)) |
|
return SLJIT_SUCCESS; |
|
#endif |
|
|
|
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) || (defined SLJIT_DEBUG && SLJIT_DEBUG) |
|
compiler->skip_checks = 1; |
|
#endif |
|
return sljit_emit_op1(compiler, op, SLJIT_RETURN_REG, 0, src, srcw); |
|
} |
|
|
|
/* CPU description section */ |
|
|
|
#if (defined SLJIT_32BIT_ARCHITECTURE && SLJIT_32BIT_ARCHITECTURE) |
|
#define SLJIT_CPUINFO_PART1 " 32bit (" |
|
#elif (defined SLJIT_64BIT_ARCHITECTURE && SLJIT_64BIT_ARCHITECTURE) |
|
#define SLJIT_CPUINFO_PART1 " 64bit (" |
|
#else |
|
#error "Internal error: CPU type info missing" |
|
#endif |
|
|
|
#if (defined SLJIT_LITTLE_ENDIAN && SLJIT_LITTLE_ENDIAN) |
|
#define SLJIT_CPUINFO_PART2 "little endian + " |
|
#elif (defined SLJIT_BIG_ENDIAN && SLJIT_BIG_ENDIAN) |
|
#define SLJIT_CPUINFO_PART2 "big endian + " |
|
#else |
|
#error "Internal error: CPU type info missing" |
|
#endif |
|
|
|
#if (defined SLJIT_UNALIGNED && SLJIT_UNALIGNED) |
|
#define SLJIT_CPUINFO_PART3 "unaligned)" |
|
#else |
|
#define SLJIT_CPUINFO_PART3 "aligned)" |
|
#endif |
|
|
|
#define SLJIT_CPUINFO SLJIT_CPUINFO_PART1 SLJIT_CPUINFO_PART2 SLJIT_CPUINFO_PART3 |
|
|
#if (defined SLJIT_CONFIG_X86_32 && SLJIT_CONFIG_X86_32) |
#if (defined SLJIT_CONFIG_X86_32 && SLJIT_CONFIG_X86_32) |
#include "sljitNativeX86_common.c" | # include "sljitNativeX86_common.c" |
#elif (defined SLJIT_CONFIG_X86_64 && SLJIT_CONFIG_X86_64) |
#elif (defined SLJIT_CONFIG_X86_64 && SLJIT_CONFIG_X86_64) |
#include "sljitNativeX86_common.c" | # include "sljitNativeX86_common.c" |
#elif (defined SLJIT_CONFIG_ARM_V5 && SLJIT_CONFIG_ARM_V5) |
#elif (defined SLJIT_CONFIG_ARM_V5 && SLJIT_CONFIG_ARM_V5) |
#include "sljitNativeARM_v5.c" | # include "sljitNativeARM_v5.c" |
#elif (defined SLJIT_CONFIG_ARM_V7 && SLJIT_CONFIG_ARM_V7) |
#elif (defined SLJIT_CONFIG_ARM_V7 && SLJIT_CONFIG_ARM_V7) |
#include "sljitNativeARM_v5.c" | # include "sljitNativeARM_v5.c" |
#elif (defined SLJIT_CONFIG_ARM_THUMB2 && SLJIT_CONFIG_ARM_THUMB2) |
#elif (defined SLJIT_CONFIG_ARM_THUMB2 && SLJIT_CONFIG_ARM_THUMB2) |
#include "sljitNativeARM_Thumb2.c" | # include "sljitNativeARM_Thumb2.c" |
#elif (defined SLJIT_CONFIG_PPC_32 && SLJIT_CONFIG_PPC_32) |
#elif (defined SLJIT_CONFIG_PPC_32 && SLJIT_CONFIG_PPC_32) |
#include "sljitNativePPC_common.c" | # include "sljitNativePPC_common.c" |
#elif (defined SLJIT_CONFIG_PPC_64 && SLJIT_CONFIG_PPC_64) |
#elif (defined SLJIT_CONFIG_PPC_64 && SLJIT_CONFIG_PPC_64) |
#include "sljitNativePPC_common.c" | # include "sljitNativePPC_common.c" |
#elif (defined SLJIT_CONFIG_MIPS_32 && SLJIT_CONFIG_MIPS_32) |
#elif (defined SLJIT_CONFIG_MIPS_32 && SLJIT_CONFIG_MIPS_32) |
#include "sljitNativeMIPS_common.c" | # include "sljitNativeMIPS_common.c" |
| #elif (defined SLJIT_CONFIG_SPARC_32 && SLJIT_CONFIG_SPARC_32) |
| # include "sljitNativeSPARC_common.c" |
| #elif (defined SLJIT_CONFIG_TILEGX && SLJIT_CONFIG_TILEGX) |
| # include "sljitNativeTILEGX.c" |
#endif |
#endif |
|
|
#if !(defined SLJIT_CONFIG_MIPS_32 && SLJIT_CONFIG_MIPS_32) |
#if !(defined SLJIT_CONFIG_MIPS_32 && SLJIT_CONFIG_MIPS_32) |
SLJIT_API_FUNC_ATTRIBUTE struct sljit_jump* sljit_emit_cmp(struct sljit_compiler *compiler, int type, | |
int src1, sljit_w src1w, | SLJIT_API_FUNC_ATTRIBUTE struct sljit_jump* sljit_emit_cmp(struct sljit_compiler *compiler, sljit_si type, |
int src2, sljit_w src2w) | sljit_si src1, sljit_sw src1w, |
| sljit_si src2, sljit_sw src2w) |
{ |
{ |
/* Default compare for most architectures. */ |
/* Default compare for most architectures. */ |
int flags, tmp_src, condition; | sljit_si flags, tmp_src, condition; |
sljit_w tmp_srcw; | sljit_sw tmp_srcw; |
|
|
CHECK_ERROR_PTR(); |
CHECK_ERROR_PTR(); |
check_sljit_emit_cmp(compiler, type, src1, src1w, src2, src2w); |
check_sljit_emit_cmp(compiler, type, src1, src1w, src2, src2w); |
Line 1152 SLJIT_API_FUNC_ATTRIBUTE struct sljit_jump* sljit_emit
|
Line 1425 SLJIT_API_FUNC_ATTRIBUTE struct sljit_jump* sljit_emit
|
#endif |
#endif |
return sljit_emit_jump(compiler, condition | (type & SLJIT_REWRITABLE_JUMP)); |
return sljit_emit_jump(compiler, condition | (type & SLJIT_REWRITABLE_JUMP)); |
} |
} |
|
|
|
SLJIT_API_FUNC_ATTRIBUTE struct sljit_jump* sljit_emit_fcmp(struct sljit_compiler *compiler, sljit_si type, |
|
sljit_si src1, sljit_sw src1w, |
|
sljit_si src2, sljit_sw src2w) |
|
{ |
|
sljit_si flags, condition; |
|
|
|
check_sljit_emit_fcmp(compiler, type, src1, src1w, src2, src2w); |
|
|
|
condition = type & 0xff; |
|
flags = (condition <= SLJIT_C_FLOAT_NOT_EQUAL) ? SLJIT_SET_E : SLJIT_SET_S; |
|
if (type & SLJIT_SINGLE_OP) |
|
flags |= SLJIT_SINGLE_OP; |
|
|
|
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) || (defined SLJIT_DEBUG && SLJIT_DEBUG) |
|
compiler->skip_checks = 1; |
#endif |
#endif |
|
sljit_emit_fop1(compiler, SLJIT_CMPD | flags, src1, src1w, src2, src2w); |
|
|
|
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) || (defined SLJIT_DEBUG && SLJIT_DEBUG) |
|
compiler->skip_checks = 1; |
|
#endif |
|
return sljit_emit_jump(compiler, condition | (type & SLJIT_REWRITABLE_JUMP)); |
|
} |
|
|
|
#endif |
|
|
|
#if !(defined SLJIT_CONFIG_X86_32 && SLJIT_CONFIG_X86_32) && !(defined SLJIT_CONFIG_X86_64 && SLJIT_CONFIG_X86_64) |
|
|
|
SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_get_local_base(struct sljit_compiler *compiler, sljit_si dst, sljit_sw dstw, sljit_sw offset) |
|
{ |
|
CHECK_ERROR(); |
|
check_sljit_get_local_base(compiler, dst, dstw, offset); |
|
|
|
ADJUST_LOCAL_OFFSET(SLJIT_MEM1(SLJIT_LOCALS_REG), offset); |
|
#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) || (defined SLJIT_DEBUG && SLJIT_DEBUG) |
|
compiler->skip_checks = 1; |
|
#endif |
|
if (offset != 0) |
|
return sljit_emit_op2(compiler, SLJIT_ADD | SLJIT_KEEP_FLAGS, dst, dstw, SLJIT_LOCALS_REG, 0, SLJIT_IMM, offset); |
|
return sljit_emit_op1(compiler, SLJIT_MOV, dst, dstw, SLJIT_LOCALS_REG, 0); |
|
} |
|
|
|
#endif |
|
|
#else /* SLJIT_CONFIG_UNSUPPORTED */ |
#else /* SLJIT_CONFIG_UNSUPPORTED */ |
|
|
/* Empty function bodies for those machines, which are not (yet) supported. */ |
/* Empty function bodies for those machines, which are not (yet) supported. */ |
|
|
SLJIT_API_FUNC_ATTRIBUTE SLJIT_CONST char* sljit_get_platform_name() | SLJIT_API_FUNC_ATTRIBUTE SLJIT_CONST char* sljit_get_platform_name(void) |
{ |
{ |
return "unsupported"; |
return "unsupported"; |
} |
} |
Line 1175 SLJIT_API_FUNC_ATTRIBUTE void sljit_free_compiler(stru
|
Line 1491 SLJIT_API_FUNC_ATTRIBUTE void sljit_free_compiler(stru
|
SLJIT_ASSERT_STOP(); |
SLJIT_ASSERT_STOP(); |
} |
} |
|
|
SLJIT_API_FUNC_ATTRIBUTE void* sljit_alloc_memory(struct sljit_compiler *compiler, int size) | SLJIT_API_FUNC_ATTRIBUTE void* sljit_alloc_memory(struct sljit_compiler *compiler, sljit_si size) |
{ |
{ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(size); |
SLJIT_UNUSED_ARG(size); |
Line 1205 SLJIT_API_FUNC_ATTRIBUTE void sljit_free_code(void* co
|
Line 1521 SLJIT_API_FUNC_ATTRIBUTE void sljit_free_code(void* co
|
SLJIT_ASSERT_STOP(); |
SLJIT_ASSERT_STOP(); |
} |
} |
|
|
SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_enter(struct sljit_compiler *compiler, int args, int temporaries, int generals, int local_size) | SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_enter(struct sljit_compiler *compiler, sljit_si args, sljit_si scratches, sljit_si saveds, sljit_si local_size) |
{ |
{ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(args); |
SLJIT_UNUSED_ARG(args); |
SLJIT_UNUSED_ARG(temporaries); | SLJIT_UNUSED_ARG(scratches); |
SLJIT_UNUSED_ARG(generals); | SLJIT_UNUSED_ARG(saveds); |
SLJIT_UNUSED_ARG(local_size); |
SLJIT_UNUSED_ARG(local_size); |
SLJIT_ASSERT_STOP(); |
SLJIT_ASSERT_STOP(); |
return SLJIT_ERR_UNSUPPORTED; |
return SLJIT_ERR_UNSUPPORTED; |
} |
} |
|
|
SLJIT_API_FUNC_ATTRIBUTE void sljit_fake_enter(struct sljit_compiler *compiler, int args, int temporaries, int generals, int local_size) | SLJIT_API_FUNC_ATTRIBUTE void sljit_set_context(struct sljit_compiler *compiler, sljit_si args, sljit_si scratches, sljit_si saveds, sljit_si local_size) |
{ |
{ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(args); |
SLJIT_UNUSED_ARG(args); |
SLJIT_UNUSED_ARG(temporaries); | SLJIT_UNUSED_ARG(scratches); |
SLJIT_UNUSED_ARG(generals); | SLJIT_UNUSED_ARG(saveds); |
SLJIT_UNUSED_ARG(local_size); |
SLJIT_UNUSED_ARG(local_size); |
SLJIT_ASSERT_STOP(); |
SLJIT_ASSERT_STOP(); |
} |
} |
|
|
SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_return(struct sljit_compiler *compiler, int src, sljit_w srcw) | SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_return(struct sljit_compiler *compiler, sljit_si op, sljit_si src, sljit_sw srcw) |
{ |
{ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
|
SLJIT_UNUSED_ARG(op); |
SLJIT_UNUSED_ARG(src); |
SLJIT_UNUSED_ARG(src); |
SLJIT_UNUSED_ARG(srcw); |
SLJIT_UNUSED_ARG(srcw); |
SLJIT_ASSERT_STOP(); |
SLJIT_ASSERT_STOP(); |
return SLJIT_ERR_UNSUPPORTED; |
return SLJIT_ERR_UNSUPPORTED; |
} |
} |
|
|
SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_fast_enter(struct sljit_compiler *compiler, int dst, sljit_w dstw, int args, int temporaries, int generals, int local_size) | SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_fast_enter(struct sljit_compiler *compiler, sljit_si dst, sljit_sw dstw) |
{ |
{ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(dst); |
SLJIT_UNUSED_ARG(dst); |
SLJIT_UNUSED_ARG(dstw); |
SLJIT_UNUSED_ARG(dstw); |
SLJIT_UNUSED_ARG(args); |
|
SLJIT_UNUSED_ARG(temporaries); |
|
SLJIT_UNUSED_ARG(generals); |
|
SLJIT_UNUSED_ARG(local_size); |
|
SLJIT_ASSERT_STOP(); |
SLJIT_ASSERT_STOP(); |
return SLJIT_ERR_UNSUPPORTED; |
return SLJIT_ERR_UNSUPPORTED; |
} |
} |
|
|
SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_fast_return(struct sljit_compiler *compiler, int src, sljit_w srcw) | SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_fast_return(struct sljit_compiler *compiler, sljit_si src, sljit_sw srcw) |
{ |
{ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(src); |
SLJIT_UNUSED_ARG(src); |
Line 1257 SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_fast_return(st
|
Line 1570 SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_fast_return(st
|
return SLJIT_ERR_UNSUPPORTED; |
return SLJIT_ERR_UNSUPPORTED; |
} |
} |
|
|
SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_op0(struct sljit_compiler *compiler, int op) | SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_op0(struct sljit_compiler *compiler, sljit_si op) |
{ |
{ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(op); |
SLJIT_UNUSED_ARG(op); |
Line 1265 SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_op0(struct slj
|
Line 1578 SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_op0(struct slj
|
return SLJIT_ERR_UNSUPPORTED; |
return SLJIT_ERR_UNSUPPORTED; |
} |
} |
|
|
SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_op1(struct sljit_compiler *compiler, int op, | SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_op1(struct sljit_compiler *compiler, sljit_si op, |
int dst, sljit_w dstw, | sljit_si dst, sljit_sw dstw, |
int src, sljit_w srcw) | sljit_si src, sljit_sw srcw) |
{ |
{ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(op); |
SLJIT_UNUSED_ARG(op); |
Line 1279 SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_op1(struct slj
|
Line 1592 SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_op1(struct slj
|
return SLJIT_ERR_UNSUPPORTED; |
return SLJIT_ERR_UNSUPPORTED; |
} |
} |
|
|
SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_op2(struct sljit_compiler *compiler, int op, | SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_op2(struct sljit_compiler *compiler, sljit_si op, |
int dst, sljit_w dstw, | sljit_si dst, sljit_sw dstw, |
int src1, sljit_w src1w, | sljit_si src1, sljit_sw src1w, |
int src2, sljit_w src2w) | sljit_si src2, sljit_sw src2w) |
{ |
{ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(op); |
SLJIT_UNUSED_ARG(op); |
Line 1296 SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_op2(struct slj
|
Line 1609 SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_op2(struct slj
|
return SLJIT_ERR_UNSUPPORTED; |
return SLJIT_ERR_UNSUPPORTED; |
} |
} |
|
|
SLJIT_API_FUNC_ATTRIBUTE int sljit_is_fpu_available(void) | SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_get_register_index(sljit_si reg) |
{ |
{ |
SLJIT_ASSERT_STOP(); |
SLJIT_ASSERT_STOP(); |
|
return reg; |
|
} |
|
|
|
SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_op_custom(struct sljit_compiler *compiler, |
|
void *instruction, sljit_si size) |
|
{ |
|
SLJIT_UNUSED_ARG(compiler); |
|
SLJIT_UNUSED_ARG(instruction); |
|
SLJIT_UNUSED_ARG(size); |
|
SLJIT_ASSERT_STOP(); |
|
return SLJIT_ERR_UNSUPPORTED; |
|
} |
|
|
|
SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_is_fpu_available(void) |
|
{ |
|
SLJIT_ASSERT_STOP(); |
return 0; |
return 0; |
} |
} |
|
|
SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_fop1(struct sljit_compiler *compiler, int op, | SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_fop1(struct sljit_compiler *compiler, sljit_si op, |
int dst, sljit_w dstw, | sljit_si dst, sljit_sw dstw, |
int src, sljit_w srcw) | sljit_si src, sljit_sw srcw) |
{ |
{ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(op); |
SLJIT_UNUSED_ARG(op); |
Line 1316 SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_fop1(struct sl
|
Line 1645 SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_fop1(struct sl
|
return SLJIT_ERR_UNSUPPORTED; |
return SLJIT_ERR_UNSUPPORTED; |
} |
} |
|
|
SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_fop2(struct sljit_compiler *compiler, int op, | SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_fop2(struct sljit_compiler *compiler, sljit_si op, |
int dst, sljit_w dstw, | sljit_si dst, sljit_sw dstw, |
int src1, sljit_w src1w, | sljit_si src1, sljit_sw src1w, |
int src2, sljit_w src2w) | sljit_si src2, sljit_sw src2w) |
{ |
{ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(op); |
SLJIT_UNUSED_ARG(op); |
Line 1340 SLJIT_API_FUNC_ATTRIBUTE struct sljit_label* sljit_emi
|
Line 1669 SLJIT_API_FUNC_ATTRIBUTE struct sljit_label* sljit_emi
|
return NULL; |
return NULL; |
} |
} |
|
|
SLJIT_API_FUNC_ATTRIBUTE struct sljit_jump* sljit_emit_jump(struct sljit_compiler *compiler, int type) | SLJIT_API_FUNC_ATTRIBUTE struct sljit_jump* sljit_emit_jump(struct sljit_compiler *compiler, sljit_si type) |
{ |
{ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(type); |
SLJIT_UNUSED_ARG(type); |
Line 1348 SLJIT_API_FUNC_ATTRIBUTE struct sljit_jump* sljit_emit
|
Line 1677 SLJIT_API_FUNC_ATTRIBUTE struct sljit_jump* sljit_emit
|
return NULL; |
return NULL; |
} |
} |
|
|
SLJIT_API_FUNC_ATTRIBUTE struct sljit_jump* sljit_emit_cmp(struct sljit_compiler *compiler, int type, | SLJIT_API_FUNC_ATTRIBUTE struct sljit_jump* sljit_emit_cmp(struct sljit_compiler *compiler, sljit_si type, |
int src1, sljit_w src1w, | sljit_si src1, sljit_sw src1w, |
int src2, sljit_w src2w) | sljit_si src2, sljit_sw src2w) |
{ |
{ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(type); |
SLJIT_UNUSED_ARG(type); |
Line 1362 SLJIT_API_FUNC_ATTRIBUTE struct sljit_jump* sljit_emit
|
Line 1691 SLJIT_API_FUNC_ATTRIBUTE struct sljit_jump* sljit_emit
|
return NULL; |
return NULL; |
} |
} |
|
|
|
SLJIT_API_FUNC_ATTRIBUTE struct sljit_jump* sljit_emit_fcmp(struct sljit_compiler *compiler, sljit_si type, |
|
sljit_si src1, sljit_sw src1w, |
|
sljit_si src2, sljit_sw src2w) |
|
{ |
|
SLJIT_UNUSED_ARG(compiler); |
|
SLJIT_UNUSED_ARG(type); |
|
SLJIT_UNUSED_ARG(src1); |
|
SLJIT_UNUSED_ARG(src1w); |
|
SLJIT_UNUSED_ARG(src2); |
|
SLJIT_UNUSED_ARG(src2w); |
|
SLJIT_ASSERT_STOP(); |
|
return NULL; |
|
} |
|
|
SLJIT_API_FUNC_ATTRIBUTE void sljit_set_label(struct sljit_jump *jump, struct sljit_label* label) |
SLJIT_API_FUNC_ATTRIBUTE void sljit_set_label(struct sljit_jump *jump, struct sljit_label* label) |
{ |
{ |
SLJIT_UNUSED_ARG(jump); |
SLJIT_UNUSED_ARG(jump); |
Line 1376 SLJIT_API_FUNC_ATTRIBUTE void sljit_set_target(struct
|
Line 1719 SLJIT_API_FUNC_ATTRIBUTE void sljit_set_target(struct
|
SLJIT_ASSERT_STOP(); |
SLJIT_ASSERT_STOP(); |
} |
} |
|
|
SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_ijump(struct sljit_compiler *compiler, int type, int src, sljit_w srcw) | SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_ijump(struct sljit_compiler *compiler, sljit_si type, sljit_si src, sljit_sw srcw) |
{ |
{ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(type); |
SLJIT_UNUSED_ARG(type); |
Line 1386 SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_ijump(struct s
|
Line 1729 SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_ijump(struct s
|
return SLJIT_ERR_UNSUPPORTED; |
return SLJIT_ERR_UNSUPPORTED; |
} |
} |
|
|
SLJIT_API_FUNC_ATTRIBUTE int sljit_emit_cond_value(struct sljit_compiler *compiler, int op, int dst, sljit_w dstw, int type) | SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_op_flags(struct sljit_compiler *compiler, sljit_si op, |
| sljit_si dst, sljit_sw dstw, |
| sljit_si src, sljit_sw srcw, |
| sljit_si type) |
{ |
{ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(op); |
SLJIT_UNUSED_ARG(op); |
SLJIT_UNUSED_ARG(dst); |
SLJIT_UNUSED_ARG(dst); |
SLJIT_UNUSED_ARG(dstw); |
SLJIT_UNUSED_ARG(dstw); |
|
SLJIT_UNUSED_ARG(src); |
|
SLJIT_UNUSED_ARG(srcw); |
SLJIT_UNUSED_ARG(type); |
SLJIT_UNUSED_ARG(type); |
SLJIT_ASSERT_STOP(); |
SLJIT_ASSERT_STOP(); |
return SLJIT_ERR_UNSUPPORTED; |
return SLJIT_ERR_UNSUPPORTED; |
} |
} |
|
|
SLJIT_API_FUNC_ATTRIBUTE struct sljit_const* sljit_emit_const(struct sljit_compiler *compiler, int dst, sljit_w dstw, sljit_w initval) | SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_get_local_base(struct sljit_compiler *compiler, sljit_si dst, sljit_sw dstw, sljit_sw offset) |
{ |
{ |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(compiler); |
SLJIT_UNUSED_ARG(dst); |
SLJIT_UNUSED_ARG(dst); |
SLJIT_UNUSED_ARG(dstw); |
SLJIT_UNUSED_ARG(dstw); |
|
SLJIT_UNUSED_ARG(offset); |
|
SLJIT_ASSERT_STOP(); |
|
return SLJIT_ERR_UNSUPPORTED; |
|
} |
|
|
|
SLJIT_API_FUNC_ATTRIBUTE struct sljit_const* sljit_emit_const(struct sljit_compiler *compiler, sljit_si dst, sljit_sw dstw, sljit_sw initval) |
|
{ |
|
SLJIT_UNUSED_ARG(compiler); |
|
SLJIT_UNUSED_ARG(dst); |
|
SLJIT_UNUSED_ARG(dstw); |
SLJIT_UNUSED_ARG(initval); |
SLJIT_UNUSED_ARG(initval); |
SLJIT_ASSERT_STOP(); |
SLJIT_ASSERT_STOP(); |
return NULL; |
return NULL; |
Line 1414 SLJIT_API_FUNC_ATTRIBUTE void sljit_set_jump_addr(slji
|
Line 1772 SLJIT_API_FUNC_ATTRIBUTE void sljit_set_jump_addr(slji
|
SLJIT_ASSERT_STOP(); |
SLJIT_ASSERT_STOP(); |
} |
} |
|
|
SLJIT_API_FUNC_ATTRIBUTE void sljit_set_const(sljit_uw addr, sljit_w new_constant) | SLJIT_API_FUNC_ATTRIBUTE void sljit_set_const(sljit_uw addr, sljit_sw new_constant) |
{ |
{ |
SLJIT_UNUSED_ARG(addr); |
SLJIT_UNUSED_ARG(addr); |
SLJIT_UNUSED_ARG(new_constant); |
SLJIT_UNUSED_ARG(new_constant); |