mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-14 11:32:34 +00:00
Add Cortex-M0 support. It's a ARMv6m device (no ARM mode) with some 32-bit
instructions: dmb, dsb, isb, msr, and mrs. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@110786 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
11db068721
commit
c7569ed4e4
@ -127,6 +127,9 @@ def : Processor<"arm1176jzf-s", ARMV6Itineraries, [ArchV6, FeatureVFP2]>;
|
|||||||
def : Processor<"mpcorenovfp", ARMV6Itineraries, [ArchV6]>;
|
def : Processor<"mpcorenovfp", ARMV6Itineraries, [ArchV6]>;
|
||||||
def : Processor<"mpcore", ARMV6Itineraries, [ArchV6, FeatureVFP2]>;
|
def : Processor<"mpcore", ARMV6Itineraries, [ArchV6, FeatureVFP2]>;
|
||||||
|
|
||||||
|
// V6M Processors.
|
||||||
|
def : Processor<"cortex-m0", ARMV6Itineraries, [ArchV6, FeatureDB]>;
|
||||||
|
|
||||||
// V6T2 Processors.
|
// V6T2 Processors.
|
||||||
def : Processor<"arm1156t2-s", ARMV6Itineraries,
|
def : Processor<"arm1156t2-s", ARMV6Itineraries,
|
||||||
[ArchV6T2, FeatureThumb2]>;
|
[ArchV6T2, FeatureThumb2]>;
|
||||||
@ -141,6 +144,8 @@ def : Processor<"cortex-a8", CortexA8Itineraries,
|
|||||||
def : Processor<"cortex-a9", CortexA9Itineraries,
|
def : Processor<"cortex-a9", CortexA9Itineraries,
|
||||||
[ArchV7A, FeatureThumb2, FeatureNEON, FeatureT2ExtractPack,
|
[ArchV7A, FeatureThumb2, FeatureNEON, FeatureT2ExtractPack,
|
||||||
FeatureDB]>;
|
FeatureDB]>;
|
||||||
|
|
||||||
|
// V7M Processors.
|
||||||
def : ProcNoItin<"cortex-m3", [ArchV7M, FeatureThumb2, FeatureHWDiv,
|
def : ProcNoItin<"cortex-m3", [ArchV7M, FeatureThumb2, FeatureHWDiv,
|
||||||
FeatureDB]>;
|
FeatureDB]>;
|
||||||
def : ProcNoItin<"cortex-m4", [ArchV7M, FeatureThumb2, FeatureHWDiv,
|
def : ProcNoItin<"cortex-m4", [ArchV7M, FeatureThumb2, FeatureHWDiv,
|
||||||
|
@ -1,17 +1,24 @@
|
|||||||
; RUN: llc < %s -march=thumb -mattr=+v6 | FileCheck %s
|
; 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 )
|
declare void @llvm.memory.barrier( i1 , i1 , i1 , i1 , i1 )
|
||||||
|
|
||||||
define void @t1() {
|
define void @t1() {
|
||||||
; CHECK: t1:
|
; V6: t1:
|
||||||
; CHECK: blx {{_*}}sync_synchronize
|
; V6: blx {{_*}}sync_synchronize
|
||||||
|
|
||||||
|
; M0: t1:
|
||||||
|
; M0: dsb
|
||||||
call void @llvm.memory.barrier( i1 false, i1 false, i1 false, i1 true, i1 true )
|
call void @llvm.memory.barrier( i1 false, i1 false, i1 false, i1 true, i1 true )
|
||||||
ret void
|
ret void
|
||||||
}
|
}
|
||||||
|
|
||||||
define void @t2() {
|
define void @t2() {
|
||||||
; CHECK: t2:
|
; V6: t2:
|
||||||
; CHECK: blx {{_*}}sync_synchronize
|
; V6: blx {{_*}}sync_synchronize
|
||||||
|
|
||||||
|
; M0: t2:
|
||||||
|
; M0: dmb
|
||||||
call void @llvm.memory.barrier( i1 false, i1 false, i1 false, i1 true, i1 false )
|
call void @llvm.memory.barrier( i1 false, i1 false, i1 false, i1 true, i1 false )
|
||||||
ret void
|
ret void
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user