| 
									
										
										
										
											2006-09-26 23:44:01 +09:00
										 |  |  | #ifndef _ASM_STACKTRACE_H
 | 
					
						
							|  |  |  | #define _ASM_STACKTRACE_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <asm/ptrace.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef CONFIG_KALLSYMS
 | 
					
						
							|  |  |  | extern int raw_show_trace; | 
					
						
							|  |  |  | extern unsigned long unwind_stack(struct task_struct *task, unsigned long *sp, | 
					
						
							| 
									
										
										
										
											2006-09-29 18:02:51 +09:00
										 |  |  | 				  unsigned long pc, unsigned long *ra); | 
					
						
							| 
									
										
										
										
											2006-09-26 23:44:01 +09:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #define raw_show_trace 1
 | 
					
						
							| 
									
										
										
										
											2007-08-07 15:02:55 +01:00
										 |  |  | static inline unsigned long unwind_stack(struct task_struct *task, | 
					
						
							|  |  |  | 	unsigned long *sp, unsigned long pc, unsigned long *ra) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2007-08-07 17:30:58 +01:00
										 |  |  | 	return 0; | 
					
						
							| 
									
										
										
										
											2007-08-07 15:02:55 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2006-09-26 23:44:01 +09:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static __always_inline void prepare_frametrace(struct pt_regs *regs) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #ifndef CONFIG_KALLSYMS
 | 
					
						
							|  |  |  | 	/*
 | 
					
						
							|  |  |  | 	 * Remove any garbage that may be in regs (specially func | 
					
						
							|  |  |  | 	 * addresses) to avoid show_raw_backtrace() to report them | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	memset(regs, 0, sizeof(*regs)); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	__asm__ __volatile__( | 
					
						
							|  |  |  | 		".set push\n\t" | 
					
						
							|  |  |  | 		".set noat\n\t" | 
					
						
							|  |  |  | #ifdef CONFIG_64BIT
 | 
					
						
							|  |  |  | 		"1: dla $1, 1b\n\t" | 
					
						
							|  |  |  | 		"sd $1, %0\n\t" | 
					
						
							|  |  |  | 		"sd $29, %1\n\t" | 
					
						
							|  |  |  | 		"sd $31, %2\n\t" | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 		"1: la $1, 1b\n\t" | 
					
						
							|  |  |  | 		"sw $1, %0\n\t" | 
					
						
							|  |  |  | 		"sw $29, %1\n\t" | 
					
						
							|  |  |  | 		"sw $31, %2\n\t" | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 		".set pop\n\t" | 
					
						
							|  |  |  | 		: "=m" (regs->cp0_epc), | 
					
						
							|  |  |  | 		"=m" (regs->regs[29]), "=m" (regs->regs[31]) | 
					
						
							|  |  |  | 		: : "memory"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* _ASM_STACKTRACE_H */
 |