mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 03:02:36 +01:00
6457993f9d
The e500 core has a silicon bug that triggers an illegal instruction program trap on any sync other than msync. Other cores will typically ignore illegal sync types, and the documentation even implies that the 'illegal' bits are ignored. Address this hardware deficiency by only using msync, like the PPC440. Differential Revision: https://reviews.llvm.org/D76614
30 lines
788 B
LLVM
30 lines
788 B
LLVM
; RUN: llc < %s -mtriple=powerpc-unknown-linux-gnu -verify-machineinstrs | FileCheck %s
|
|
; RUN: llc < %s -mtriple=powerpc64-unknown-linux-gnu -verify-machineinstrs | FileCheck %s
|
|
; RUN: llc < %s -mtriple=powerpc-unknown-linux-gnu -mcpu=440 | FileCheck %s --check-prefix=PPC440
|
|
; RUN: llc < %s -mtriple=powerpc-unknown-linux-gnu -mcpu=e500 | 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
|
|
}
|