
Utilize common API in PPCTargetParser (https://github.com/llvm/llvm-project/pull/97541) to set default CPU with same interfaces for LLC. This will update AIX default CPU to pwr7 and LoP powerppc64 default CPU to ppc64.
42 lines
1.3 KiB
LLVM
42 lines
1.3 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
|
|
;RUN: llc < %s --mcpu=ppc -mtriple=powerpc64-unknown-linux-gnu -mattr=+altivec | FileCheck %s -check-prefix=BE
|
|
;RUN: llc < %s --mtriple=powerpc64le-unknown-linux-gnu -mattr=+altivec | FileCheck %s -check-prefix=LE
|
|
|
|
define <8 x i32> @test_large_vec_vaarg(i32 %n, ...) {
|
|
; BE-LABEL: test_large_vec_vaarg:
|
|
; BE: # %bb.0:
|
|
; BE-NEXT: ld 3, -8(1)
|
|
; BE-NEXT: addi 3, 3, 15
|
|
; BE-NEXT: rldicr 3, 3, 0, 59
|
|
; BE-NEXT: addi 4, 3, 16
|
|
; BE-NEXT: addi 5, 3, 31
|
|
; BE-NEXT: std 4, -8(1)
|
|
; BE-NEXT: rldicr 4, 5, 0, 59
|
|
; BE-NEXT: lvx 2, 0, 3
|
|
; BE-NEXT: addi 3, 4, 16
|
|
; BE-NEXT: std 3, -8(1)
|
|
; BE-NEXT: lvx 3, 0, 4
|
|
; BE-NEXT: blr
|
|
;
|
|
; LE-LABEL: test_large_vec_vaarg:
|
|
; LE: # %bb.0:
|
|
; LE-NEXT: ld 3, -8(1)
|
|
; LE-NEXT: addi 3, 3, 15
|
|
; LE-NEXT: rldicr 3, 3, 0, 59
|
|
; LE-NEXT: addi 4, 3, 16
|
|
; LE-NEXT: std 4, -8(1)
|
|
; LE-NEXT: lxvd2x 0, 0, 3
|
|
; LE-NEXT: ld 3, -8(1)
|
|
; LE-NEXT: addi 3, 3, 15
|
|
; LE-NEXT: rldicr 3, 3, 0, 59
|
|
; LE-NEXT: addi 4, 3, 16
|
|
; LE-NEXT: std 4, -8(1)
|
|
; LE-NEXT: xxswapd 34, 0
|
|
; LE-NEXT: lxvd2x 0, 0, 3
|
|
; LE-NEXT: xxswapd 35, 0
|
|
; LE-NEXT: blr
|
|
%args = alloca ptr, align 4
|
|
%x = va_arg ptr %args, <8 x i32>
|
|
ret <8 x i32> %x
|
|
}
|