mirror of
https://github.com/Gericom/teak-llvm.git
synced 2025-06-29 08:19:01 -04:00

So long as the choice between printing msync and sync is not ambiguous, we can print 'sync 0' and just 'sync'. llvm-svn: 235663
29 lines
740 B
LLVM
29 lines
740 B
LLVM
; RUN: llc < %s -mtriple=powerpc-apple-darwin -march=ppc32 -verify-machineinstrs | FileCheck %s --check-prefix=CHECK
|
|
; RUN: llc < %s -mtriple=powerpc-apple-darwin -march=ppc64 -verify-machineinstrs | FileCheck %s --check-prefix=CHECK
|
|
; RUN: llc < %s -mtriple=powerpc-apple-darwin -mcpu=440 | FileCheck %s --check-prefix=PPC440
|
|
|
|
; Fences
|
|
define void @fence_acquire() {
|
|
; CHECK-LABEL: fence_acquire
|
|
; CHECK: lwsync
|
|
; PPC440-NOT: lwsync
|
|
; PPC440: msync
|
|
fence acquire
|
|
ret void
|
|
}
|
|
define void @fence_release() {
|
|
; CHECK-LABEL: fence_release
|
|
; CHECK: lwsync
|
|
; PPC440-NOT: lwsync
|
|
; PPC440: msync
|
|
fence release
|
|
ret void
|
|
}
|
|
define void @fence_seq_cst() {
|
|
; CHECK-LABEL: fence_seq_cst
|
|
; CHECK: sync
|
|
; PPC440: msync
|
|
fence seq_cst
|
|
ret void
|
|
}
|