These map to single Intel instructions. The i64 to float conversions are not tested yet. The encoding tables can't yet differentiate instructions on a secondary type variable alone.
50 lines
869 B
Plaintext
50 lines
869 B
Plaintext
; Test code generation for WebAssembly type conversion operators.
|
|
test compile
|
|
|
|
set is_64bit=1
|
|
isa intel haswell
|
|
|
|
function %i32_wrap_i64(i64) -> i32 {
|
|
ebb0(v0: i64):
|
|
v1 = ireduce.i32 v0
|
|
return v1
|
|
}
|
|
|
|
function %i64_extend_s_i32(i32) -> i64 {
|
|
ebb0(v0: i32):
|
|
v1 = sextend.i64 v0
|
|
return v1
|
|
}
|
|
|
|
function %i64_extend_u_i32(i32) -> i64 {
|
|
ebb0(v0: i32):
|
|
v1 = uextend.i64 v0
|
|
return v1
|
|
}
|
|
|
|
function %f32_convert_s_i32(i32) -> f32 {
|
|
ebb0(v0: i32):
|
|
v1 = fcvt_from_sint.f32 v0
|
|
return v1
|
|
}
|
|
|
|
function %f64_convert_s_i32(i32) -> f64 {
|
|
ebb0(v0: i32):
|
|
v1 = fcvt_from_sint.f64 v0
|
|
return v1
|
|
}
|
|
|
|
function %f32_convert_s_i64(i64) -> f32 {
|
|
ebb0(v0: i64):
|
|
v1 = fcvt_from_sint.f32 v0
|
|
return v1
|
|
}
|
|
|
|
function %f64_convert_s_i64(i64) -> f64 {
|
|
ebb0(v0: i64):
|
|
v1 = fcvt_from_sint.f64 v0
|
|
return v1
|
|
}
|
|
|
|
; TODO: f*_convert_u_i* (Don't exist on Intel).
|