| 
									
										
										
										
											2008-12-11 18:46:46 +09:00
										 |  |  | #ifndef __ASM_SH_KGDB_H
 | 
					
						
							|  |  |  | #define __ASM_SH_KGDB_H
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-11 18:46:46 +09:00
										 |  |  | #include <asm/cacheflush.h>
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #include <asm/ptrace.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-11 18:46:46 +09:00
										 |  |  | enum regnames { | 
					
						
							|  |  |  | 	GDB_R0, GDB_R1, GDB_R2, GDB_R3, GDB_R4, GDB_R5, GDB_R6, GDB_R7, | 
					
						
							|  |  |  | 	GDB_R8, GDB_R9, GDB_R10, GDB_R11, GDB_R12, GDB_R13, GDB_R14, GDB_R15, | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-11 18:46:46 +09:00
										 |  |  | 	GDB_PC, GDB_PR, GDB_SR, GDB_GBR, GDB_MACH, GDB_MACL, GDB_VBR, | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-10 13:42:56 +09:00
										 |  |  | #define _GP_REGS	16
 | 
					
						
							|  |  |  | #define _EXTRA_REGS	7
 | 
					
						
							|  |  |  | #define GDB_SIZEOF_REG	sizeof(u32)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define DBG_MAX_REG_NUM	(_GP_REGS + _EXTRA_REGS)
 | 
					
						
							|  |  |  | #define NUMREGBYTES	(DBG_MAX_REG_NUM * sizeof(GDB_SIZEOF_REG))
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-11 18:46:46 +09:00
										 |  |  | static inline void arch_kgdb_breakpoint(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	__asm__ __volatile__ ("trapa #0x3c\n"); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-11 18:46:46 +09:00
										 |  |  | #define BREAK_INSTR_SIZE	2
 | 
					
						
							| 
									
										
										
										
											2012-04-11 10:48:24 +09:00
										 |  |  | #define BUFMAX			2048
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef CONFIG_SMP
 | 
					
						
							|  |  |  | # define CACHE_FLUSH_IS_SAFE	0
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | # define CACHE_FLUSH_IS_SAFE	1
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-26 16:25:45 -07:00
										 |  |  | #define GDB_ADJUSTS_BREAK_OFFSET
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-11 18:46:46 +09:00
										 |  |  | #endif /* __ASM_SH_KGDB_H */
 |