2014-10-04 02:04:36 +08:00
|
|
|
; 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
|
2015-04-24 02:30:38 +08:00
|
|
|
; CHECK: lwsync
|
|
|
|
; PPC440-NOT: lwsync
|
2014-10-04 02:04:36 +08:00
|
|
|
; PPC440: msync
|
|
|
|
fence acquire
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
define void @fence_release() {
|
|
|
|
; CHECK-LABEL: fence_release
|
2015-04-24 02:30:38 +08:00
|
|
|
; CHECK: lwsync
|
|
|
|
; PPC440-NOT: lwsync
|
2014-10-04 02:04:36 +08:00
|
|
|
; PPC440: msync
|
|
|
|
fence release
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
define void @fence_seq_cst() {
|
|
|
|
; CHECK-LABEL: fence_seq_cst
|
|
|
|
; CHECK: sync 0
|
|
|
|
; PPC440-NOT: sync 0
|
|
|
|
; PPC440: msync
|
|
|
|
fence seq_cst
|
|
|
|
ret void
|
|
|
|
}
|