Skip to content

Commit ef4e795

Browse files
authored
Implement i32.div_s (#1792)
1 parent 1449275 commit ef4e795

File tree

3 files changed

+15
-0
lines changed

3 files changed

+15
-0
lines changed

core/iwasm/aot/aot_intrinsic.c

Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -68,6 +68,7 @@ static const aot_intrinsic g_intrinsic_mapping[] = {
6868
{ "f32.const", NULL, AOT_INTRINSIC_FLAG_F32_CONST },
6969
{ "f64.const", NULL, AOT_INTRINSIC_FLAG_F64_CONST },
7070
{ "i64.div_s", "aot_intrinsic_i64_div_s", AOT_INTRINSIC_FLAG_I64_DIV_S},
71+
{ "i32.div_s", "aot_intrinsic_i32_div_s", AOT_INTRINSIC_FLAG_I32_DIV_S},
7172
{ "i32.div_u", "aot_intrinsic_i32_div_u", AOT_INTRINSIC_FLAG_I32_DIV_U},
7273
{ "i32.rem_s", "aot_intrinsic_i32_rem_s", AOT_INTRINSIC_FLAG_I32_REM_S},
7374
{ "i32.rem_u", "aot_intrinsic_i32_rem_u", AOT_INTRINSIC_FLAG_I32_REM_U},
@@ -504,6 +505,12 @@ aot_intrinsic_i64_div_s(int64 l, int64 r)
504505
return l / r;
505506
}
506507

508+
int32
509+
aot_intrinsic_i32_div_s(int32 l, int32 r)
510+
{
511+
return l / r;
512+
}
513+
507514
uint32
508515
aot_intrinsic_i32_div_u(uint32 l, uint32 r)
509516
{
@@ -593,6 +600,7 @@ add_i64_common_intrinsics(AOTCompContext *comp_ctx)
593600
static void
594601
add_i32_common_intrinsics(AOTCompContext *comp_ctx)
595602
{
603+
add_intrinsic_capability(comp_ctx, AOT_INTRINSIC_FLAG_I32_DIV_S);
596604
add_intrinsic_capability(comp_ctx, AOT_INTRINSIC_FLAG_I32_DIV_U);
597605
add_intrinsic_capability(comp_ctx, AOT_INTRINSIC_FLAG_I32_REM_S);
598606
add_intrinsic_capability(comp_ctx, AOT_INTRINSIC_FLAG_I32_REM_U);
@@ -691,6 +699,7 @@ aot_intrinsic_fill_capability_flags(AOTCompContext *comp_ctx)
691699
return;
692700

693701
if (!strncmp(comp_ctx->target_arch, "thumb", 5)) {
702+
add_intrinsic_capability(comp_ctx, AOT_INTRINSIC_FLAG_I32_CONST);
694703
add_i32_common_intrinsics(comp_ctx);
695704
if (!strcmp(comp_ctx->target_cpu, "cortex-m7")) {
696705
}
@@ -705,6 +714,7 @@ aot_intrinsic_fill_capability_flags(AOTCompContext *comp_ctx)
705714
}
706715
}
707716
else if (!strncmp(comp_ctx->target_arch, "riscv", 5)) {
717+
add_intrinsic_capability(comp_ctx, AOT_INTRINSIC_FLAG_I32_CONST);
708718
/*
709719
* Note: Use builtin intrinsics since hardware float operation
710720
* will cause rodata relocation

core/iwasm/aot/aot_intrinsic.h

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -62,6 +62,7 @@ extern "C" {
6262
#define AOT_INTRINSIC_FLAG_I32_DIV_U AOT_INTRINSIC_FLAG(0, 28)
6363
#define AOT_INTRINSIC_FLAG_I32_REM_S AOT_INTRINSIC_FLAG(0, 29)
6464
#define AOT_INTRINSIC_FLAG_I32_REM_U AOT_INTRINSIC_FLAG(0, 30)
65+
#define AOT_INTRINSIC_FLAG_I32_DIV_S AOT_INTRINSIC_FLAG(0, 31)
6566

6667
#define AOT_INTRINSIC_FLAG_F64_FADD AOT_INTRINSIC_FLAG(1, 0)
6768
#define AOT_INTRINSIC_FLAG_F64_FSUB AOT_INTRINSIC_FLAG(1, 1)
@@ -259,6 +260,9 @@ aot_intrinsic_f64_cmp(AOTFloatCond cond, float64 lhs, float64 rhs);
259260
int64
260261
aot_intrinsic_i64_div_s(int64 l, int64 r);
261262

263+
int32
264+
aot_intrinsic_i32_div_s(int32 l, int32 r);
265+
262266
uint32
263267
aot_intrinsic_i32_div_u(uint32 l, uint32 r);
264268

core/iwasm/aot/aot_reloc.h

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -114,6 +114,7 @@ typedef struct {
114114
REG_SYM(aot_intrinsic_i64_rem_u), \
115115
REG_SYM(aot_intrinsic_i64_bit_or), \
116116
REG_SYM(aot_intrinsic_i64_bit_and), \
117+
REG_SYM(aot_intrinsic_i32_div_s), \
117118
REG_SYM(aot_intrinsic_i32_div_u), \
118119
REG_SYM(aot_intrinsic_i32_rem_s), \
119120
REG_SYM(aot_intrinsic_i32_rem_u), \

0 commit comments

Comments
 (0)