blob: ed047c934f7c77f633fde4473ea3e99ad0d08560 [file] [log] [blame]
// Copyright 2011 Google Inc. All Rights Reserved.
#ifndef ART_SRC_RUNTIME_SUPPORT_H_
#define ART_SRC_RUNTIME_SUPPORT_H_
/* Helper for both JNI and regular compiled code */
extern "C" void art_deliver_exception(void*);
#if defined(__arm__)
/* Compiler helpers */
extern "C" uint64_t art_shl_long(uint64_t, uint32_t);
extern "C" uint64_t art_shr_long(uint64_t, uint32_t);
extern "C" uint64_t art_ushr_long(uint64_t, uint32_t);
extern "C" void art_throw_null_pointer_exception_from_code();
extern "C" void art_throw_div_zero_from_code();
extern "C" void art_throw_array_bounds_from_code(int32_t index, int32_t limit);
extern "C" void art_invoke_interface_trampoline(void*, void*, void*, void*);
extern "C" void art_test_suspend();
/* Conversions */
extern "C" float __aeabi_i2f(int op1); // OP_INT_TO_FLOAT
extern "C" int __aeabi_f2iz(float op1); // OP_FLOAT_TO_INT
extern "C" float __aeabi_d2f(double op1); // OP_DOUBLE_TO_FLOAT
extern "C" double __aeabi_f2d(float op1); // OP_FLOAT_TO_DOUBLE
extern "C" double __aeabi_i2d(int op1); // OP_INT_TO_DOUBLE
extern "C" int __aeabi_d2iz(double op1); // OP_DOUBLE_TO_INT
extern "C" float __aeabi_l2f(long op1); // OP_LONG_TO_FLOAT
extern "C" double __aeabi_l2d(long op1); // OP_LONG_TO_DOUBLE
/* Single-precision FP arithmetics */
extern "C" float __aeabi_fadd(float a, float b); // OP_ADD_FLOAT[_2ADDR]
extern "C" float __aeabi_fsub(float a, float b); // OP_SUB_FLOAT[_2ADDR]
extern "C" float __aeabi_fdiv(float a, float b); // OP_DIV_FLOAT[_2ADDR]
extern "C" float __aeabi_fmul(float a, float b); // OP_MUL_FLOAT[_2ADDR]
extern "C" float fmodf(float a, float b); // OP_REM_FLOAT[_2ADDR]
/* Double-precision FP arithmetics */
extern "C" double __aeabi_dadd(double a, double b); // OP_ADD_DOUBLE[_2ADDR]
extern "C" double __aeabi_dsub(double a, double b); // OP_SUB_DOUBLE[_2ADDR]
extern "C" double __aeabi_ddiv(double a, double b); // OP_DIV_DOUBLE[_2ADDR]
extern "C" double __aeabi_dmul(double a, double b); // OP_MUL_DOUBLE[_2ADDR]
extern "C" double fmod(double a, double b); // OP_REM_DOUBLE[_2ADDR]
/* Integer arithmetics */
extern "C" int __aeabi_idivmod(int op1, int op2); // OP_REM_INT[_2ADDR|_LIT8|_LIT16]
extern "C" int __aeabi_idiv(int op1, int op2); // OP_DIV_INT[_2ADDR|_LIT8|_LIT16]
/* Long long arithmetics - OP_REM_LONG[_2ADDR] & OP_DIV_LONG[_2ADDR] */
extern "C" long long __aeabi_ldivmod(long long op1, long long op2);
extern "C" long long __aeabi_lmul(long long op1, long long op2);
#endif
#endif // ART_SRC_RUNTIME_SUPPORT_H_