mirror of
https://github.com/RPCS3/llvm.git
synced 2025-05-14 01:16:26 +00:00

`llc -march` is problematic because it only switches the target architecture, but leaves the operating system unchanged. This occasionally leads to indeterministic tests because the OS from LLVM_DEFAULT_TARGET_TRIPLE is used. However we can simply always use `llc -mtriple` instead. This changes all the tests to do this to avoid people using -march when they copy and paste parts of tests. This patch: - Removes -march if the .ll file already has a matching `target triple` directive or -mtriple argument. - In all other cases changes -march=ppc32/-march=ppc64 to -mtriple=ppc32--/-mtriple=ppc64-- See also the discussion in https://reviews.llvm.org/D35287 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@309754 91177308-0d34-0410-b5e6-96231b3b80d8
11 lines
316 B
LLVM
11 lines
316 B
LLVM
; RUN: llc -verify-machineinstrs < %s -mtriple=ppc32-- -mcpu=g5
|
|
; PR3628
|
|
|
|
define void @update(<4 x i32> %val, <4 x i32>* %dst) nounwind {
|
|
entry:
|
|
%shl = shl <4 x i32> %val, < i32 4, i32 3, i32 2, i32 1 >
|
|
%shr = ashr <4 x i32> %shl, < i32 1, i32 2, i32 3, i32 4 >
|
|
store <4 x i32> %shr, <4 x i32>* %dst
|
|
ret void
|
|
}
|