mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-15 20:29:48 +00:00
22266c1d48
The usual default of "dmb ish" (inner-shareable) isn't even a valid instruction on v6M or v7M (well, it does the same thing but software is strongly discouraged from using it) so we should emit a full-system barrier there. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@189483 91177308-0d34-0410-b5e6-96231b3b80d8
14 lines
379 B
LLVM
14 lines
379 B
LLVM
; RUN: llc < %s -mtriple=thumbv6-apple-darwin | FileCheck %s -check-prefix=V6
|
|
; RUN: llc < %s -mtriple=thumbv7-apple-darwin -mattr=-db | FileCheck %s -check-prefix=V6
|
|
; RUN: llc < %s -march=thumb -mcpu=cortex-m0 | FileCheck %s -check-prefix=V6M
|
|
|
|
define void @t1() {
|
|
; V6-LABEL: t1:
|
|
; V6: blx {{_*}}sync_synchronize
|
|
|
|
; V6M-LABEL: t1:
|
|
; V6M: dmb sy
|
|
fence seq_cst
|
|
ret void
|
|
}
|