* Manually rename BasicBlock to BlockPredecessor BasicBlock is a pair of (Ebb, Inst) that is used to represent the basic block subcomponent of an Ebb that is a predecessor to an Ebb. Eventually we will be able to remove this struct, but for now it makes sense to give it a non-conflicting name so that we can start to transition Ebb to represent a basic block. I have not updated any comments that refer to BasicBlock, as eventually we will remove BlockPredecessor and replace with Block, which is a basic block, so the comments will become correct. * Manually rename SSABuilder block types to avoid conflict SSABuilder has its own Block and BlockData types. These along with associated identifier will cause conflicts in a later commit, so they are renamed to be more verbose here. * Automatically rename 'Ebb' to 'Block' in *.rs * Automatically rename 'EBB' to 'block' in *.rs * Automatically rename 'ebb' to 'block' in *.rs * Automatically rename 'extended basic block' to 'basic block' in *.rs * Automatically rename 'an basic block' to 'a basic block' in *.rs * Manually update comment for `Block` `Block`'s wikipedia article required an update. * Automatically rename 'an `Block`' to 'a `Block`' in *.rs * Automatically rename 'extended_basic_block' to 'basic_block' in *.rs * Automatically rename 'ebb' to 'block' in *.clif * Manually rename clif constant that contains 'ebb' as substring to avoid conflict * Automatically rename filecheck uses of 'EBB' to 'BB' 'regex: EBB' -> 'regex: BB' '$EBB' -> '$BB' * Automatically rename 'EBB' 'Ebb' to 'block' in *.clif * Automatically rename 'an block' to 'a block' in *.clif * Fix broken testcase when function name length increases Test function names are limited to 16 characters. This causes the new longer name to be truncated and fail a filecheck test. An outdated comment was also fixed.
41 lines
1.1 KiB
Plaintext
41 lines
1.1 KiB
Plaintext
test binemit
|
|
set opt_level=speed_and_size
|
|
target x86_64
|
|
|
|
; Test that instruction shrinking eliminates REX prefixes when possible.
|
|
|
|
; The binary encodings can be verified with the command:
|
|
;
|
|
; sed -ne 's/^ *; asm: *//p' filetests/isa/x86/shrink.clif | llvm-mc -show-encoding -triple=x86_64
|
|
;
|
|
|
|
function %test_shrinking(i32) -> i32 {
|
|
block0(v0: i32 [ %rdi ]):
|
|
; asm: movl $0x2,%eax
|
|
[-,%rcx] v1 = iconst.i32 2 ; bin: b9 00000002
|
|
; asm: subl %ecx,%edi
|
|
[-,%rdi] v2 = isub v0, v1 ; bin: 29 cf
|
|
return v2
|
|
}
|
|
|
|
function %test_not_shrinking(i32) -> i32 {
|
|
block0(v0: i32 [ %r8 ]):
|
|
; asm: movl $0x2,%eax
|
|
[-,%rcx] v1 = iconst.i32 2 ; bin: b9 00000002
|
|
; asm: subl %ecx,%edi
|
|
[-,%r8] v2 = isub v0, v1 ; bin: 41 29 c8
|
|
return v2
|
|
}
|
|
|
|
function %test_not_shrinking_i8() {
|
|
block0:
|
|
[-,%rsi] v1 = iconst.i8 1
|
|
; asm: movsbl %sil,%esi
|
|
[-,%rsi] v2 = sextend.i32 v1 ; bin: 40 0f be f6
|
|
; asm: movzbl %sil,%esi
|
|
[-,%rsi] v3 = uextend.i32 v1 ; bin: 40 0f b6 f6
|
|
; asm: movzbl %sil,%esi
|
|
[-,%rsi] v4 = uextend.i64 v1 ; bin: 40 0f b6 f6
|
|
trap user0
|
|
}
|