82 lines
		
	
	
	
		
			1.7 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			82 lines
		
	
	
	
		
			1.7 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
| 
								 | 
							
								/* Kernel debugger for MN10300
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * Copyright (C) 2010 Red Hat, Inc. All Rights Reserved.
							 | 
						||
| 
								 | 
							
								 * Written by David Howells (dhowells@redhat.com)
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * This program is free software; you can redistribute it and/or
							 | 
						||
| 
								 | 
							
								 * modify it under the terms of the GNU General Public Licence
							 | 
						||
| 
								 | 
							
								 * as published by the Free Software Foundation; either version
							 | 
						||
| 
								 | 
							
								 * 2 of the Licence, or (at your option) any later version.
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#ifndef _ASM_KGDB_H
							 | 
						||
| 
								 | 
							
								#define _ASM_KGDB_H
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*
							 | 
						||
| 
								 | 
							
								 * BUFMAX defines the maximum number of characters in inbound/outbound
							 | 
						||
| 
								 | 
							
								 * buffers at least NUMREGBYTES*2 are needed for register packets
							 | 
						||
| 
								 | 
							
								 * Longer buffer is needed to list all threads
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								#define BUFMAX			1024
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*
							 | 
						||
| 
								 | 
							
								 * Note that this register image is in a different order than the register
							 | 
						||
| 
								 | 
							
								 * image that Linux produces at interrupt time.
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								enum regnames {
							 | 
						||
| 
								 | 
							
									GDB_FR_D0		= 0,
							 | 
						||
| 
								 | 
							
									GDB_FR_D1		= 1,
							 | 
						||
| 
								 | 
							
									GDB_FR_D2		= 2,
							 | 
						||
| 
								 | 
							
									GDB_FR_D3		= 3,
							 | 
						||
| 
								 | 
							
									GDB_FR_A0		= 4,
							 | 
						||
| 
								 | 
							
									GDB_FR_A1		= 5,
							 | 
						||
| 
								 | 
							
									GDB_FR_A2		= 6,
							 | 
						||
| 
								 | 
							
									GDB_FR_A3		= 7,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									GDB_FR_SP		= 8,
							 | 
						||
| 
								 | 
							
									GDB_FR_PC		= 9,
							 | 
						||
| 
								 | 
							
									GDB_FR_MDR		= 10,
							 | 
						||
| 
								 | 
							
									GDB_FR_EPSW		= 11,
							 | 
						||
| 
								 | 
							
									GDB_FR_LIR		= 12,
							 | 
						||
| 
								 | 
							
									GDB_FR_LAR		= 13,
							 | 
						||
| 
								 | 
							
									GDB_FR_MDRQ		= 14,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									GDB_FR_E0		= 15,
							 | 
						||
| 
								 | 
							
									GDB_FR_E1		= 16,
							 | 
						||
| 
								 | 
							
									GDB_FR_E2		= 17,
							 | 
						||
| 
								 | 
							
									GDB_FR_E3		= 18,
							 | 
						||
| 
								 | 
							
									GDB_FR_E4		= 19,
							 | 
						||
| 
								 | 
							
									GDB_FR_E5		= 20,
							 | 
						||
| 
								 | 
							
									GDB_FR_E6		= 21,
							 | 
						||
| 
								 | 
							
									GDB_FR_E7		= 22,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									GDB_FR_SSP		= 23,
							 | 
						||
| 
								 | 
							
									GDB_FR_MSP		= 24,
							 | 
						||
| 
								 | 
							
									GDB_FR_USP		= 25,
							 | 
						||
| 
								 | 
							
									GDB_FR_MCRH		= 26,
							 | 
						||
| 
								 | 
							
									GDB_FR_MCRL		= 27,
							 | 
						||
| 
								 | 
							
									GDB_FR_MCVF		= 28,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									GDB_FR_FPCR		= 29,
							 | 
						||
| 
								 | 
							
									GDB_FR_DUMMY0		= 30,
							 | 
						||
| 
								 | 
							
									GDB_FR_DUMMY1		= 31,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									GDB_FR_FS0		= 32,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									GDB_FR_SIZE		= 64,
							 | 
						||
| 
								 | 
							
								};
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#define GDB_ORIG_D0		41
							 | 
						||
| 
								 | 
							
								#define NUMREGBYTES		(GDB_FR_SIZE*4)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								static inline void arch_kgdb_breakpoint(void)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
									asm(".globl __arch_kgdb_breakpoint; __arch_kgdb_breakpoint: break");
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								extern u8 __arch_kgdb_breakpoint;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#define BREAK_INSTR_SIZE	1
							 | 
						||
| 
								 | 
							
								#define CACHE_FLUSH_IS_SAFE	1
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#endif /* _ASM_KGDB_H */
							 |