new file mode 100644
@@ -0,0 +1,53 @@
+#ifndef HELPER_REGISTER_H
+#define HELPER_REGISTER_H
+
+#include "exec/helper-head.h"
+
+/* Need one more level of indirection before stringification
+ to get all the macros expanded first. */
+#define str(s) #s
+
+#define DEF_HELPER_FLAGS_0(NAME, FLAGS, ret) \
+ tcg_register_helper(HELPER(NAME), str(NAME), FLAGS, dh_sizemask(ret, 0));
+
+#define DEF_HELPER_FLAGS_1(NAME, FLAGS, ret, t1) \
+ tcg_register_helper(HELPER(NAME), str(NAME), FLAGS, \
+ dh_sizemask(ret, 0) | dh_sizemask(t1, 1));
+
+#define DEF_HELPER_FLAGS_2(NAME, FLAGS, ret, t1, t2) \
+ tcg_register_helper(HELPER(NAME), str(NAME), FLAGS, \
+ dh_sizemask(ret, 0) | dh_sizemask(t1, 1) | dh_sizemask(t2, 2));
+
+#define DEF_HELPER_FLAGS_3(NAME, FLAGS, ret, t1, t2, t3) \
+ tcg_register_helper(HELPER(NAME), str(NAME), FLAGS, \
+ dh_sizemask(ret, 0) | dh_sizemask(t1, 1) | dh_sizemask(t2, 2) \
+ | dh_sizemask(t3, 3));
+
+#define DEF_HELPER_FLAGS_4(NAME, FLAGS, ret, t1, t2, t3, t4) \
+ tcg_register_helper(HELPER(NAME), str(NAME), FLAGS, \
+ dh_sizemask(ret, 0) | dh_sizemask(t1, 1) | dh_sizemask(t2, 2) \
+ | dh_sizemask(t3, 3) | dh_sizemask(t4, 4));
+
+#define DEF_HELPER_FLAGS_5(NAME, FLAGS, ret, t1, t2, t3, t4, t5) \
+ tcg_register_helper(HELPER(NAME), str(NAME), FLAGS, \
+ dh_sizemask(ret, 0) | dh_sizemask(t1, 1) | dh_sizemask(t2, 2) \
+ | dh_sizemask(t3, 3) | dh_sizemask(t4, 4) | dh_sizemask(t5, 5));
+
+#define DEF_HELPER_FLAGS_6(NAME, FLAGS, ret, t1, t2, t3, t4, t5, t6) \
+ tcg_register_helper(HELPER(NAME), str(NAME), FLAGS, \
+ dh_sizemask(ret, 0) | dh_sizemask(t1, 1) | dh_sizemask(t2, 2) \
+ | dh_sizemask(t3, 3) | dh_sizemask(t4, 4) | dh_sizemask(t5, 5) \
+ | dh_sizemask(t6, 6));
+
+#include "helper.h"
+
+#undef str
+#undef DEF_HELPER_FLAGS_0
+#undef DEF_HELPER_FLAGS_1
+#undef DEF_HELPER_FLAGS_2
+#undef DEF_HELPER_FLAGS_3
+#undef DEF_HELPER_FLAGS_4
+#undef DEF_HELPER_FLAGS_5
+#undef DEF_HELPER_FLAGS_6
+
+#endif // HELPER_REGISTER_H
@@ -1623,6 +1623,18 @@ static inline const char *tcg_find_helper(TCGContext *s, uintptr_t val)
return ret;
}
+void tcg_register_helper(void *func, const char *name,
+ unsigned flags, unsigned sizemask)
+{
+ TCGHelperInfo *info = g_new0(TCGHelperInfo, 1);
+ info->func = func;
+ info->name = name;
+ info->flags = flags;
+ info->sizemask = sizemask;
+
+ g_hash_table_insert(helper_table, func, info);
+}
+
static const char * const cond_name[] =
{
[TCG_COND_NEVER] = "never",
@@ -890,6 +890,9 @@ void tcg_register_thread(void);
void tcg_prologue_init(TCGContext *s);
void tcg_func_start(TCGContext *s);
+void tcg_register_helper(void *func, const char *name,
+ unsigned flags, unsigned sizemask);
+
int tcg_gen_code(TCGContext *s, TranslationBlock *tb);
void tcg_set_frame(TCGContext *s, TCGReg reg, intptr_t start, intptr_t size);
This patch adds functions and headers for adding the helpers from the modules other than the target translators. Signed-off-by: Pavel Dovgalyuk <Pavel.Dovgaluk@ispras.ru> --- include/exec/helper-register.h | 53 ++++++++++++++++++++++++++++++++++++++++ tcg/tcg.c | 12 +++++++++ tcg/tcg.h | 3 ++ 3 files changed, 68 insertions(+) create mode 100644 include/exec/helper-register.h