blob: 23126d79ae1983ad9e1a242775d29d199c4df422 [file] [log] [blame]
buzbee54330722011-08-23 16:46:55 -07001// Copyright 2011 Google Inc. All Rights Reserved.
2
3#ifndef ART_SRC_RUNTIME_SUPPORT_H_
4#define ART_SRC_RUNTIME_SUPPORT_H_
5
6#if defined(__arm__)
buzbee7b1b86d2011-08-26 18:59:10 -07007 /* Compiler helpers */
buzbee54330722011-08-23 16:46:55 -07008 extern "C" uint64_t art_shl_long(uint64_t, uint32_t);
9 extern "C" uint64_t art_shr_long(uint64_t, uint32_t);
10 extern "C" uint64_t art_ushr_long(uint64_t, uint32_t);
buzbee4a3164f2011-09-03 11:25:10 -070011 extern "C" void art_invoke_interface_trampoline(void*, void*, void*, void*);
buzbee7b1b86d2011-08-26 18:59:10 -070012
13 /* Conversions */
14 extern "C" float __aeabi_i2f(int op1); // OP_INT_TO_FLOAT
15 extern "C" int __aeabi_f2iz(float op1); // OP_FLOAT_TO_INT
16 extern "C" float __aeabi_d2f(double op1); // OP_DOUBLE_TO_FLOAT
17 extern "C" double __aeabi_f2d(float op1); // OP_FLOAT_TO_DOUBLE
18 extern "C" double __aeabi_i2d(int op1); // OP_INT_TO_DOUBLE
19 extern "C" int __aeabi_d2iz(double op1); // OP_DOUBLE_TO_INT
20 extern "C" float __aeabi_l2f(long op1); // OP_LONG_TO_FLOAT
21 extern "C" double __aeabi_l2d(long op1); // OP_LONG_TO_DOUBLE
22
23 /* Single-precision FP arithmetics */
24 extern "C" float __aeabi_fadd(float a, float b); // OP_ADD_FLOAT[_2ADDR]
25 extern "C" float __aeabi_fsub(float a, float b); // OP_SUB_FLOAT[_2ADDR]
26 extern "C" float __aeabi_fdiv(float a, float b); // OP_DIV_FLOAT[_2ADDR]
27 extern "C" float __aeabi_fmul(float a, float b); // OP_MUL_FLOAT[_2ADDR]
28 extern "C" float fmodf(float a, float b); // OP_REM_FLOAT[_2ADDR]
29
30 /* Double-precision FP arithmetics */
31 extern "C" double __aeabi_dadd(double a, double b); // OP_ADD_DOUBLE[_2ADDR]
32 extern "C" double __aeabi_dsub(double a, double b); // OP_SUB_DOUBLE[_2ADDR]
33 extern "C" double __aeabi_ddiv(double a, double b); // OP_DIV_DOUBLE[_2ADDR]
34 extern "C" double __aeabi_dmul(double a, double b); // OP_MUL_DOUBLE[_2ADDR]
35 extern "C" double fmod(double a, double b); // OP_REM_DOUBLE[_2ADDR]
36
37 /* Integer arithmetics */
38 extern "C" int __aeabi_idivmod(int op1, int op2); // OP_REM_INT[_2ADDR|_LIT8|_LIT16]
39 extern "C" int __aeabi_idiv(int op1, int op2); // OP_DIV_INT[_2ADDR|_LIT8|_LIT16]
40
41/* Long long arithmetics - OP_REM_LONG[_2ADDR] & OP_DIV_LONG[_2ADDR] */
42extern "C" long long __aeabi_ldivmod(long long op1, long long op2);
buzbee439c4fa2011-08-27 15:59:07 -070043extern "C" long long __aeabi_lmul(long long op1, long long op2);
buzbee7b1b86d2011-08-26 18:59:10 -070044
buzbee54330722011-08-23 16:46:55 -070045#endif
46
buzbee1b4c8592011-08-31 10:43:51 -070047namespace art {
48 int64_t D2L(double);
49 int64_t F2L(float);
50 void HandleFillArrayDataFromCode(art::Array*, const uint16_t*);
51}
buzbeee6d61962011-08-27 11:58:19 -070052
buzbee54330722011-08-23 16:46:55 -070053#endif // ART_SRC_RUNTIME_SUPPORT_H_