37 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
			
		
		
	
	
			37 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
/*
 | 
						|
 * cf-hosted.S -- 
 | 
						|
 *
 | 
						|
 * Copyright (c) 2006 CodeSourcery Inc
 | 
						|
 *
 | 
						|
 * The authors hereby grant permission to use, copy, modify, distribute,
 | 
						|
 * and license this software and its documentation for any purpose, provided
 | 
						|
 * that existing copyright notices are retained in all copies and that this
 | 
						|
 * notice is included verbatim in any distributions. No written agreement,
 | 
						|
 * license, or royalty fee is required for any of the authorized uses.
 | 
						|
 * Modifications to this software may be copyrighted by their authors
 | 
						|
 * and need not follow the licensing terms described here, provided that
 | 
						|
 * the new terms are clearly indicated on the first page of each file where
 | 
						|
 * they apply.
 | 
						|
 */
 | 
						|
 | 
						|
/* Semihosting function.  The debugger intercepts the halt, and
 | 
						|
   determines that it is followed by the sentinel pattern. */
 | 
						|
 | 
						|
	.globl __hosted
 | 
						|
__hosted:
 | 
						|
	linkw %fp,#0
 | 
						|
	movel %fp@(8),%d0
 | 
						|
	movel %fp@(12),%d1
 | 
						|
 | 
						|
	/* The semihosting sequence is 'nop; halt;sentinel' aligned to
 | 
						|
	   a 4 byte boundary.  The sentinel is an ill formed instruction
 | 
						|
	   (movec %sp,0).  The debugger will adjust the pc, so it is never
 | 
						|
	    executed.  */
 | 
						|
	.balignw 4,0x4e71
 | 
						|
	nop
 | 
						|
	halt
 | 
						|
	.long 0x4e7bf000
 | 
						|
 | 
						|
	unlk %fp
 | 
						|
	rts
 |