Choosing smaller instruction encodings on eg. x86 is an optimization, rather than a useful discrete setting. Use "is_compressed" only for ISAs that have an explicit compression feature that users of the output may to be aware of, such as RISC-V's RVC or ARM's Thumb-2.
29 lines
856 B
Plaintext
29 lines
856 B
Plaintext
; binary emission of 64-bit code.
|
|
test binemit
|
|
set is_64bit
|
|
set opt_level=best
|
|
set allones_funcaddrs
|
|
isa x86 haswell
|
|
|
|
; The binary encodings can be verified with the command:
|
|
;
|
|
; sed -ne 's/^ *; asm: *//p' filetests/isa/x86/allones_funcaddrs64.cton | llvm-mc -show-encoding -triple=x86_64
|
|
;
|
|
|
|
; Tests from binary64.cton affected by allones_funcaddrs.
|
|
function %I64() {
|
|
sig0 = ()
|
|
fn0 = %foo()
|
|
|
|
ebb0:
|
|
|
|
; asm: movabsq $-1, %rcx
|
|
[-,%rcx] v400 = func_addr.i64 fn0 ; bin: 48 b9 Abs8(%foo) ffffffffffffffff
|
|
; asm: movabsq $-1, %rsi
|
|
[-,%rsi] v401 = func_addr.i64 fn0 ; bin: 48 be Abs8(%foo) ffffffffffffffff
|
|
; asm: movabsq $-1, %r10
|
|
[-,%r10] v402 = func_addr.i64 fn0 ; bin: 49 ba Abs8(%foo) ffffffffffffffff
|
|
|
|
return ; bin: c3
|
|
}
|