27 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
			
		
		
	
	
			27 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
@ RUN: not llvm-mc -triple=thumbv7-apple-darwin -mcpu=cortex-a8 -show-encoding -mattr=-trustzone < %s | FileCheck %s -check-prefix=NOTZ
 | 
						|
@ RUN: llvm-mc -triple=thumbv7-apple-darwin -mcpu=cortex-a8 -show-encoding -mattr=trustzone < %s | FileCheck %s -check-prefix=TZ
 | 
						|
@ RUN: not llvm-mc -triple=thumbv6kz -mcpu=arm1176jzf-s -show-encoding < %s | FileCheck %s -check-prefix=NOTZ
 | 
						|
 | 
						|
  .syntax unified
 | 
						|
  .globl _func
 | 
						|
 | 
						|
@ Check that the assembler processes SMC instructions when TrustZone support is 
 | 
						|
@ active and that it rejects them when this feature is not enabled
 | 
						|
 | 
						|
_func:
 | 
						|
@ CHECK: _func
 | 
						|
 | 
						|
 | 
						|
@------------------------------------------------------------------------------
 | 
						|
@ SMC
 | 
						|
@------------------------------------------------------------------------------
 | 
						|
        smc #0xf
 | 
						|
        ite eq
 | 
						|
        smceq #0
 | 
						|
 | 
						|
@ NOTZ-NOT: smc 	#15
 | 
						|
@ NOTZ-NOT: smceq	#0
 | 
						|
@ TZ: smc	#15                     @ encoding: [0xff,0xf7,0x00,0x80]
 | 
						|
@ TZ: ite	eq                      @ encoding: [0x0c,0xbf]
 | 
						|
@ TZ: smceq	#0                      @ encoding: [0xf0,0xf7,0x00,0x80]
 |