|
|
@@ -348,14 +348,37 @@ aot_compile_op_i32_trunc_f32(AOTCompContext *comp_ctx, AOTFuncContext *func_ctx,
|
|
|
|
|
|
POP_F32(value);
|
|
|
|
|
|
- if (sign) {
|
|
|
- min_value = F32_CONST(-2147483904.0f);
|
|
|
- max_value = F32_CONST(2147483648.0f);
|
|
|
+ if (!comp_ctx->is_indirect_mode) {
|
|
|
+ if (sign) {
|
|
|
+ min_value = F32_CONST(-2147483904.0f);
|
|
|
+ max_value = F32_CONST(2147483648.0f);
|
|
|
+ }
|
|
|
+ else {
|
|
|
+ min_value = F32_CONST(-1.0f);
|
|
|
+ max_value = F32_CONST(4294967296.0f);
|
|
|
+ }
|
|
|
}
|
|
|
else {
|
|
|
- min_value = F32_CONST(-1.0f);
|
|
|
- max_value = F32_CONST(4294967296.0f);
|
|
|
+ WASMValue wasm_value;
|
|
|
+ if (sign) {
|
|
|
+ wasm_value.f32 = -2147483904.0f;
|
|
|
+ min_value = aot_load_const_from_table(
|
|
|
+ comp_ctx, func_ctx->native_symbol, &wasm_value, VALUE_TYPE_F32);
|
|
|
+ wasm_value.f32 = 2147483648.0f;
|
|
|
+ max_value = aot_load_const_from_table(
|
|
|
+ comp_ctx, func_ctx->native_symbol, &wasm_value, VALUE_TYPE_F32);
|
|
|
+ }
|
|
|
+ else {
|
|
|
+ wasm_value.f32 = -1.0f;
|
|
|
+ min_value = aot_load_const_from_table(
|
|
|
+ comp_ctx, func_ctx->native_symbol, &wasm_value, VALUE_TYPE_F32);
|
|
|
+ wasm_value.f32 = 4294967296.0f;
|
|
|
+ max_value = aot_load_const_from_table(
|
|
|
+ comp_ctx, func_ctx->native_symbol, &wasm_value, VALUE_TYPE_F32);
|
|
|
+ }
|
|
|
}
|
|
|
+ CHECK_LLVM_CONST(min_value);
|
|
|
+ CHECK_LLVM_CONST(max_value);
|
|
|
|
|
|
if (!saturating)
|
|
|
return trunc_float_to_int(
|
|
|
@@ -378,14 +401,37 @@ aot_compile_op_i32_trunc_f64(AOTCompContext *comp_ctx, AOTFuncContext *func_ctx,
|
|
|
|
|
|
POP_F64(value);
|
|
|
|
|
|
- if (sign) {
|
|
|
- min_value = F64_CONST(-2147483649.0);
|
|
|
- max_value = F64_CONST(2147483648.0);
|
|
|
+ if (!comp_ctx->is_indirect_mode) {
|
|
|
+ if (sign) {
|
|
|
+ min_value = F64_CONST(-2147483649.0);
|
|
|
+ max_value = F64_CONST(2147483648.0);
|
|
|
+ }
|
|
|
+ else {
|
|
|
+ min_value = F64_CONST(-1.0);
|
|
|
+ max_value = F64_CONST(4294967296.0);
|
|
|
+ }
|
|
|
}
|
|
|
else {
|
|
|
- min_value = F64_CONST(-1.0);
|
|
|
- max_value = F64_CONST(4294967296.0);
|
|
|
+ WASMValue wasm_value;
|
|
|
+ if (sign) {
|
|
|
+ wasm_value.f64 = -2147483649.0;
|
|
|
+ min_value = aot_load_const_from_table(
|
|
|
+ comp_ctx, func_ctx->native_symbol, &wasm_value, VALUE_TYPE_F64);
|
|
|
+ wasm_value.f64 = 2147483648.0;
|
|
|
+ max_value = aot_load_const_from_table(
|
|
|
+ comp_ctx, func_ctx->native_symbol, &wasm_value, VALUE_TYPE_F64);
|
|
|
+ }
|
|
|
+ else {
|
|
|
+ wasm_value.f64 = -1.0;
|
|
|
+ min_value = aot_load_const_from_table(
|
|
|
+ comp_ctx, func_ctx->native_symbol, &wasm_value, VALUE_TYPE_F64);
|
|
|
+ wasm_value.f64 = 4294967296.0;
|
|
|
+ max_value = aot_load_const_from_table(
|
|
|
+ comp_ctx, func_ctx->native_symbol, &wasm_value, VALUE_TYPE_F64);
|
|
|
+ }
|
|
|
}
|
|
|
+ CHECK_LLVM_CONST(min_value);
|
|
|
+ CHECK_LLVM_CONST(max_value);
|
|
|
|
|
|
if (!saturating)
|
|
|
return trunc_float_to_int(
|
|
|
@@ -509,14 +555,37 @@ aot_compile_op_i64_trunc_f32(AOTCompContext *comp_ctx, AOTFuncContext *func_ctx,
|
|
|
|
|
|
POP_F32(value);
|
|
|
|
|
|
- if (sign) {
|
|
|
- min_value = F32_CONST(-9223373136366403584.0f);
|
|
|
- max_value = F32_CONST(9223372036854775808.0f);
|
|
|
+ if (!comp_ctx->is_indirect_mode) {
|
|
|
+ if (sign) {
|
|
|
+ min_value = F32_CONST(-9223373136366403584.0f);
|
|
|
+ max_value = F32_CONST(9223372036854775808.0f);
|
|
|
+ }
|
|
|
+ else {
|
|
|
+ min_value = F32_CONST(-1.0f);
|
|
|
+ max_value = F32_CONST(18446744073709551616.0f);
|
|
|
+ }
|
|
|
}
|
|
|
else {
|
|
|
- min_value = F32_CONST(-1.0f);
|
|
|
- max_value = F32_CONST(18446744073709551616.0f);
|
|
|
+ WASMValue wasm_value;
|
|
|
+ if (sign) {
|
|
|
+ wasm_value.f32 = -9223373136366403584.0f;
|
|
|
+ min_value = aot_load_const_from_table(
|
|
|
+ comp_ctx, func_ctx->native_symbol, &wasm_value, VALUE_TYPE_F32);
|
|
|
+ wasm_value.f32 = 9223372036854775808.0f;
|
|
|
+ max_value = aot_load_const_from_table(
|
|
|
+ comp_ctx, func_ctx->native_symbol, &wasm_value, VALUE_TYPE_F32);
|
|
|
+ }
|
|
|
+ else {
|
|
|
+ wasm_value.f32 = -1.0f;
|
|
|
+ min_value = aot_load_const_from_table(
|
|
|
+ comp_ctx, func_ctx->native_symbol, &wasm_value, VALUE_TYPE_F32);
|
|
|
+ wasm_value.f32 = 18446744073709551616.0f;
|
|
|
+ max_value = aot_load_const_from_table(
|
|
|
+ comp_ctx, func_ctx->native_symbol, &wasm_value, VALUE_TYPE_F32);
|
|
|
+ }
|
|
|
}
|
|
|
+ CHECK_LLVM_CONST(min_value);
|
|
|
+ CHECK_LLVM_CONST(max_value);
|
|
|
|
|
|
if (!saturating)
|
|
|
return trunc_float_to_int(
|
|
|
@@ -539,14 +608,37 @@ aot_compile_op_i64_trunc_f64(AOTCompContext *comp_ctx, AOTFuncContext *func_ctx,
|
|
|
|
|
|
POP_F64(value);
|
|
|
|
|
|
- if (sign) {
|
|
|
- min_value = F64_CONST(-9223372036854777856.0);
|
|
|
- max_value = F64_CONST(9223372036854775808.0);
|
|
|
+ if (!comp_ctx->is_indirect_mode) {
|
|
|
+ if (sign) {
|
|
|
+ min_value = F64_CONST(-9223372036854777856.0);
|
|
|
+ max_value = F64_CONST(9223372036854775808.0);
|
|
|
+ }
|
|
|
+ else {
|
|
|
+ min_value = F64_CONST(-1.0);
|
|
|
+ max_value = F64_CONST(18446744073709551616.0);
|
|
|
+ }
|
|
|
}
|
|
|
else {
|
|
|
- min_value = F64_CONST(-1.0);
|
|
|
- max_value = F64_CONST(18446744073709551616.0);
|
|
|
+ WASMValue wasm_value;
|
|
|
+ if (sign) {
|
|
|
+ wasm_value.f64 = -9223372036854777856.0;
|
|
|
+ min_value = aot_load_const_from_table(
|
|
|
+ comp_ctx, func_ctx->native_symbol, &wasm_value, VALUE_TYPE_F64);
|
|
|
+ wasm_value.f64 = 9223372036854775808.0;
|
|
|
+ max_value = aot_load_const_from_table(
|
|
|
+ comp_ctx, func_ctx->native_symbol, &wasm_value, VALUE_TYPE_F64);
|
|
|
+ }
|
|
|
+ else {
|
|
|
+ wasm_value.f64 = -1.0;
|
|
|
+ min_value = aot_load_const_from_table(
|
|
|
+ comp_ctx, func_ctx->native_symbol, &wasm_value, VALUE_TYPE_F64);
|
|
|
+ wasm_value.f64 = 18446744073709551616.0;
|
|
|
+ max_value = aot_load_const_from_table(
|
|
|
+ comp_ctx, func_ctx->native_symbol, &wasm_value, VALUE_TYPE_F64);
|
|
|
+ }
|
|
|
}
|
|
|
+ CHECK_LLVM_CONST(min_value);
|
|
|
+ CHECK_LLVM_CONST(max_value);
|
|
|
|
|
|
if (!saturating)
|
|
|
return trunc_float_to_int(
|