250 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			LLVM
		
	
	
	
			
		
		
	
	
			250 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			LLVM
		
	
	
	
| ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
 | |
| ; RUN: llc -mtriple=powerpc64-unknown-aix-xcoff -verify-machineinstrs \
 | |
| ; RUN:   -ppc-asm-full-reg-names -mcpu=pwr8 < %s | FileCheck \
 | |
| ; RUN:   --check-prefix=AIX64 %s
 | |
| ; RUN: llc -mtriple=powerpc-unknown-aix-xcoff -verify-machineinstrs \
 | |
| ; RUN:   -ppc-asm-full-reg-names -mcpu=pwr8 < %s | FileCheck \
 | |
| ; RUN:   --check-prefix=AIX32 %s
 | |
| ; RUN: llc -mtriple=powerpc64le-- -verify-machineinstrs \
 | |
| ; RUN:   -ppc-asm-full-reg-names -mcpu=pwr8 < %s | FileCheck --check-prefix=LE %s
 | |
| 
 | |
| define dso_local void @test1(<2 x double>* %v, i64 %a) local_unnamed_addr #0 {
 | |
| ; AIX64-LABEL: test1:
 | |
| ; AIX64:       # %bb.0: # %entry
 | |
| ; AIX64-NEXT:    mtvsrd vs34, r4
 | |
| ; AIX64-NEXT:    #APP
 | |
| ; AIX64-NEXT:    stvx v2, 0, r3
 | |
| ; AIX64-NEXT:    #NO_APP
 | |
| ; AIX64-NEXT:    blr
 | |
| ;
 | |
| ; AIX32-LABEL: test1:
 | |
| ; AIX32:       # %bb.0: # %entry
 | |
| ; AIX32-NEXT:    stw r5, -4(r1)
 | |
| ; AIX32-NEXT:    stw r4, -8(r1)
 | |
| ; AIX32-NEXT:    lfd f0, -8(r1)
 | |
| ; AIX32-NEXT:    xxlor vs34, f0, f0
 | |
| ; AIX32-NEXT:    #APP
 | |
| ; AIX32-NEXT:    stvx v2, 0, r3
 | |
| ; AIX32-NEXT:    #NO_APP
 | |
| ; AIX32-NEXT:    blr
 | |
| ;
 | |
| ; LE-LABEL: test1:
 | |
| ; LE:       # %bb.0: # %entry
 | |
| ; LE-NEXT:    mtvsrd vs34, r4
 | |
| ; LE-NEXT:    #APP
 | |
| ; LE-NEXT:    stvx v2, 0, r3
 | |
| ; LE-NEXT:    #NO_APP
 | |
| ; LE-NEXT:    blr
 | |
| entry:
 | |
|   tail call void asm sideeffect "stvx $0,0,$1", "v,r,~{memory}"(i64 %a, <2 x double>* %v)
 | |
|   ret void
 | |
| }
 | |
| 
 | |
| define dso_local void @test2(<2 x double>* %v, i32 signext %a) local_unnamed_addr #0 {
 | |
| ; AIX64-LABEL: test2:
 | |
| ; AIX64:       # %bb.0: # %entry
 | |
| ; AIX64-NEXT:    clrldi r4, r4, 32
 | |
| ; AIX64-NEXT:    mtvsrd vs34, r4
 | |
| ; AIX64-NEXT:    #APP
 | |
| ; AIX64-NEXT:    stvx v2, 0, r3
 | |
| ; AIX64-NEXT:    #NO_APP
 | |
| ; AIX64-NEXT:    blr
 | |
| ;
 | |
| ; AIX32-LABEL: test2:
 | |
| ; AIX32:       # %bb.0: # %entry
 | |
| ; AIX32-NEXT:    li r5, 0
 | |
| ; AIX32-NEXT:    stw r4, -4(r1)
 | |
| ; AIX32-NEXT:    stw r5, -8(r1)
 | |
| ; AIX32-NEXT:    lfd f0, -8(r1)
 | |
| ; AIX32-NEXT:    xxlor vs34, f0, f0
 | |
| ; AIX32-NEXT:    #APP
 | |
| ; AIX32-NEXT:    stvx v2, 0, r3
 | |
| ; AIX32-NEXT:    #NO_APP
 | |
| ; AIX32-NEXT:    blr
 | |
| ;
 | |
| ; LE-LABEL: test2:
 | |
| ; LE:       # %bb.0: # %entry
 | |
| ; LE-NEXT:    clrldi r4, r4, 32
 | |
| ; LE-NEXT:    mtvsrd vs34, r4
 | |
| ; LE-NEXT:    #APP
 | |
| ; LE-NEXT:    stvx v2, 0, r3
 | |
| ; LE-NEXT:    #NO_APP
 | |
| ; LE-NEXT:    blr
 | |
| entry:
 | |
|   tail call void asm sideeffect "stvx $0,0,$1", "v,r,~{memory}"(i32 %a, <2 x double>* %v)
 | |
|   ret void
 | |
| }
 | |
| 
 | |
| define dso_local void @test3(<2 x double>* %v, i16 signext %a) local_unnamed_addr #0 {
 | |
| ; AIX64-LABEL: test3:
 | |
| ; AIX64:       # %bb.0: # %entry
 | |
| ; AIX64-NEXT:    clrldi r4, r4, 48
 | |
| ; AIX64-NEXT:    mtvsrd vs34, r4
 | |
| ; AIX64-NEXT:    #APP
 | |
| ; AIX64-NEXT:    stvx v2, 0, r3
 | |
| ; AIX64-NEXT:    #NO_APP
 | |
| ; AIX64-NEXT:    blr
 | |
| ;
 | |
| ; AIX32-LABEL: test3:
 | |
| ; AIX32:       # %bb.0: # %entry
 | |
| ; AIX32-NEXT:    li r5, 0
 | |
| ; AIX32-NEXT:    clrlwi r4, r4, 16
 | |
| ; AIX32-NEXT:    stw r5, -8(r1)
 | |
| ; AIX32-NEXT:    stw r4, -4(r1)
 | |
| ; AIX32-NEXT:    lfd f0, -8(r1)
 | |
| ; AIX32-NEXT:    xxlor vs34, f0, f0
 | |
| ; AIX32-NEXT:    #APP
 | |
| ; AIX32-NEXT:    stvx v2, 0, r3
 | |
| ; AIX32-NEXT:    #NO_APP
 | |
| ; AIX32-NEXT:    blr
 | |
| ;
 | |
| ; LE-LABEL: test3:
 | |
| ; LE:       # %bb.0: # %entry
 | |
| ; LE-NEXT:    clrldi r4, r4, 48
 | |
| ; LE-NEXT:    mtvsrd vs34, r4
 | |
| ; LE-NEXT:    #APP
 | |
| ; LE-NEXT:    stvx v2, 0, r3
 | |
| ; LE-NEXT:    #NO_APP
 | |
| ; LE-NEXT:    blr
 | |
| entry:
 | |
|   tail call void asm sideeffect "stvx $0,0,$1", "v,r,~{memory}"(i16 %a, <2 x double>* %v)
 | |
|   ret void
 | |
| }
 | |
| 
 | |
| define dso_local void @test4(<2 x double>* %v, i8 signext %a) local_unnamed_addr #0 {
 | |
| ; AIX64-LABEL: test4:
 | |
| ; AIX64:       # %bb.0: # %entry
 | |
| ; AIX64-NEXT:    clrldi r4, r4, 56
 | |
| ; AIX64-NEXT:    mtvsrd vs34, r4
 | |
| ; AIX64-NEXT:    #APP
 | |
| ; AIX64-NEXT:    stvx v2, 0, r3
 | |
| ; AIX64-NEXT:    #NO_APP
 | |
| ; AIX64-NEXT:    blr
 | |
| ;
 | |
| ; AIX32-LABEL: test4:
 | |
| ; AIX32:       # %bb.0: # %entry
 | |
| ; AIX32-NEXT:    li r5, 0
 | |
| ; AIX32-NEXT:    clrlwi r4, r4, 24
 | |
| ; AIX32-NEXT:    stw r5, -8(r1)
 | |
| ; AIX32-NEXT:    stw r4, -4(r1)
 | |
| ; AIX32-NEXT:    lfd f0, -8(r1)
 | |
| ; AIX32-NEXT:    xxlor vs34, f0, f0
 | |
| ; AIX32-NEXT:    #APP
 | |
| ; AIX32-NEXT:    stvx v2, 0, r3
 | |
| ; AIX32-NEXT:    #NO_APP
 | |
| ; AIX32-NEXT:    blr
 | |
| ;
 | |
| ; LE-LABEL: test4:
 | |
| ; LE:       # %bb.0: # %entry
 | |
| ; LE-NEXT:    clrldi r4, r4, 56
 | |
| ; LE-NEXT:    mtvsrd vs34, r4
 | |
| ; LE-NEXT:    #APP
 | |
| ; LE-NEXT:    stvx v2, 0, r3
 | |
| ; LE-NEXT:    #NO_APP
 | |
| ; LE-NEXT:    blr
 | |
| entry:
 | |
|   tail call void asm sideeffect "stvx $0,0,$1", "v,r,~{memory}"(i8 %a, <2 x double>* %v)
 | |
|   ret void
 | |
| }
 | |
| 
 | |
| define dso_local void @test6(<2 x double>* %v, i32 zeroext %a) local_unnamed_addr #0 {
 | |
| ; AIX64-LABEL: test6:
 | |
| ; AIX64:       # %bb.0: # %entry
 | |
| ; AIX64-NEXT:    mtvsrd vs34, r4
 | |
| ; AIX64-NEXT:    #APP
 | |
| ; AIX64-NEXT:    stvx v2, 0, r3
 | |
| ; AIX64-NEXT:    #NO_APP
 | |
| ; AIX64-NEXT:    blr
 | |
| ;
 | |
| ; AIX32-LABEL: test6:
 | |
| ; AIX32:       # %bb.0: # %entry
 | |
| ; AIX32-NEXT:    li r5, 0
 | |
| ; AIX32-NEXT:    stw r4, -4(r1)
 | |
| ; AIX32-NEXT:    stw r5, -8(r1)
 | |
| ; AIX32-NEXT:    lfd f0, -8(r1)
 | |
| ; AIX32-NEXT:    xxlor vs34, f0, f0
 | |
| ; AIX32-NEXT:    #APP
 | |
| ; AIX32-NEXT:    stvx v2, 0, r3
 | |
| ; AIX32-NEXT:    #NO_APP
 | |
| ; AIX32-NEXT:    blr
 | |
| ;
 | |
| ; LE-LABEL: test6:
 | |
| ; LE:       # %bb.0: # %entry
 | |
| ; LE-NEXT:    mtvsrd vs34, r4
 | |
| ; LE-NEXT:    #APP
 | |
| ; LE-NEXT:    stvx v2, 0, r3
 | |
| ; LE-NEXT:    #NO_APP
 | |
| ; LE-NEXT:    blr
 | |
| entry:
 | |
|   tail call void asm sideeffect "stvx $0,0,$1", "v,r,~{memory}"(i32 %a, <2 x double>* %v)
 | |
|   ret void
 | |
| }
 | |
| 
 | |
| define dso_local void @test7(<2 x double>* %v, i16 zeroext %a) local_unnamed_addr #0 {
 | |
| ; AIX64-LABEL: test7:
 | |
| ; AIX64:       # %bb.0: # %entry
 | |
| ; AIX64-NEXT:    mtvsrd vs34, r4
 | |
| ; AIX64-NEXT:    #APP
 | |
| ; AIX64-NEXT:    stvx v2, 0, r3
 | |
| ; AIX64-NEXT:    #NO_APP
 | |
| ; AIX64-NEXT:    blr
 | |
| ;
 | |
| ; AIX32-LABEL: test7:
 | |
| ; AIX32:       # %bb.0: # %entry
 | |
| ; AIX32-NEXT:    li r5, 0
 | |
| ; AIX32-NEXT:    stw r4, -4(r1)
 | |
| ; AIX32-NEXT:    stw r5, -8(r1)
 | |
| ; AIX32-NEXT:    lfd f0, -8(r1)
 | |
| ; AIX32-NEXT:    xxlor vs34, f0, f0
 | |
| ; AIX32-NEXT:    #APP
 | |
| ; AIX32-NEXT:    stvx v2, 0, r3
 | |
| ; AIX32-NEXT:    #NO_APP
 | |
| ; AIX32-NEXT:    blr
 | |
| ;
 | |
| ; LE-LABEL: test7:
 | |
| ; LE:       # %bb.0: # %entry
 | |
| ; LE-NEXT:    mtvsrd vs34, r4
 | |
| ; LE-NEXT:    #APP
 | |
| ; LE-NEXT:    stvx v2, 0, r3
 | |
| ; LE-NEXT:    #NO_APP
 | |
| ; LE-NEXT:    blr
 | |
| entry:
 | |
|   tail call void asm sideeffect "stvx $0,0,$1", "v,r,~{memory}"(i16 %a, <2 x double>* %v)
 | |
|   ret void
 | |
| }
 | |
| 
 | |
| define dso_local void @test8(<2 x double>* %v, i8 zeroext %a) local_unnamed_addr #0 {
 | |
| ; AIX64-LABEL: test8:
 | |
| ; AIX64:       # %bb.0: # %entry
 | |
| ; AIX64-NEXT:    mtvsrd vs34, r4
 | |
| ; AIX64-NEXT:    #APP
 | |
| ; AIX64-NEXT:    stvx v2, 0, r3
 | |
| ; AIX64-NEXT:    #NO_APP
 | |
| ; AIX64-NEXT:    blr
 | |
| ;
 | |
| ; AIX32-LABEL: test8:
 | |
| ; AIX32:       # %bb.0: # %entry
 | |
| ; AIX32-NEXT:    li r5, 0
 | |
| ; AIX32-NEXT:    stw r4, -4(r1)
 | |
| ; AIX32-NEXT:    stw r5, -8(r1)
 | |
| ; AIX32-NEXT:    lfd f0, -8(r1)
 | |
| ; AIX32-NEXT:    xxlor vs34, f0, f0
 | |
| ; AIX32-NEXT:    #APP
 | |
| ; AIX32-NEXT:    stvx v2, 0, r3
 | |
| ; AIX32-NEXT:    #NO_APP
 | |
| ; AIX32-NEXT:    blr
 | |
| ;
 | |
| ; LE-LABEL: test8:
 | |
| ; LE:       # %bb.0: # %entry
 | |
| ; LE-NEXT:    mtvsrd vs34, r4
 | |
| ; LE-NEXT:    #APP
 | |
| ; LE-NEXT:    stvx v2, 0, r3
 | |
| ; LE-NEXT:    #NO_APP
 | |
| ; LE-NEXT:    blr
 | |
| entry:
 | |
|   tail call void asm sideeffect "stvx $0,0,$1", "v,r,~{memory}"(i8 %a, <2 x double>* %v)
 | |
|   ret void
 | |
| }
 | |
| 
 | |
| attributes #0 = { nounwind }
 |