mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-02-02 10:21:54 +00:00
e5bab36c75
instructions: dmb, dsb, isb, msr, and mrs. llvm-svn: 110786
25 lines
578 B
LLVM
25 lines
578 B
LLVM
; RUN: llc < %s -march=thumb -mattr=+v6 | FileCheck %s -check-prefix=V6
|
|
; RUN: llc < %s -march=thumb -mcpu=cortex-m0 | FileCheck %s -check-prefix=M0
|
|
|
|
declare void @llvm.memory.barrier( i1 , i1 , i1 , i1 , i1 )
|
|
|
|
define void @t1() {
|
|
; V6: t1:
|
|
; V6: blx {{_*}}sync_synchronize
|
|
|
|
; M0: t1:
|
|
; M0: dsb
|
|
call void @llvm.memory.barrier( i1 false, i1 false, i1 false, i1 true, i1 true )
|
|
ret void
|
|
}
|
|
|
|
define void @t2() {
|
|
; V6: t2:
|
|
; V6: blx {{_*}}sync_synchronize
|
|
|
|
; M0: t2:
|
|
; M0: dmb
|
|
call void @llvm.memory.barrier( i1 false, i1 false, i1 false, i1 true, i1 false )
|
|
ret void
|
|
}
|