* Split the `iadd_cout` runtests by type * Implement `iadd_cout` for 32- and 64-bit values on x64 * Delete trailing whitespace in `riscv/lower.isle`
29 lines
804 B
Plaintext
29 lines
804 B
Plaintext
test interpret
|
|
test run
|
|
target aarch64
|
|
; target s390x
|
|
target x86_64
|
|
; target riscv64
|
|
|
|
function %iaddcout_i64_v(i64, i64) -> i64 {
|
|
block0(v0: i64, v1: i64):
|
|
v2, v3 = iadd_cout v0, v1
|
|
return v2
|
|
}
|
|
; run: %iaddcout_i64_v(0, 1) == 1
|
|
; run: %iaddcout_i64_v(100, 27) == 127
|
|
; run: %iaddcout_i64_v(100, 28) == 128
|
|
; run: %iaddcout_i64_v(0x7FFFFFFF_FFFF0000, 0xFFFF) == 0x7FFFFFFF_FFFFFFFF
|
|
; run: %iaddcout_i64_v(0x7FFFFFFF_FFFF0000, 0x10000) == 0x80000000_00000000
|
|
|
|
function %iaddcout_i64_c(i64, i64) -> i8 {
|
|
block0(v0: i64, v1: i64):
|
|
v2, v3 = iadd_cout v0, v1
|
|
return v3
|
|
}
|
|
; run: %iaddcout_i64_c(0, 1) == 0
|
|
; run: %iaddcout_i64_c(100, 27) == 0
|
|
; run: %iaddcout_i64_c(100, 28) == 0
|
|
; run: %iaddcout_i64_c(0x7FFFFFFF_FFFF0000, 0xFFFF) == 0
|
|
; run: %iaddcout_i64_c(0x7FFFFFFF_FFFF0000, 0x10000) == 1
|