Implement intelligent backtracing by searching for stack frame creation, and emitting only return addresses. Use print_hex_dump() to display the entire binary kernel stack. Limitation: MMU kernels are not currently able to trace beyond a system trap (interrupt, syscall, etc.). It is the intent of this patch to provide infrastructure that can be extended to add this capability later. Changes from V1: * Removed checks in find_frame_creation() that prevented location of the frame creation instruction in heavily optimized code * Various formatting/commenting/file location tweaks per review comments * Dropped Kconfig option to enable STACKTRACE as something logically separate Signed-off-by: Steven J. Magnani <steve@digidescorp.com>
		
			
				
	
	
		
			29 lines
		
	
	
	
		
			719 B
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			29 lines
		
	
	
	
		
			719 B
			
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 * Backtrace support for Microblaze
 | 
						|
 *
 | 
						|
 * Copyright (C) 2010  Digital Design Corporation
 | 
						|
 *
 | 
						|
 * This file is subject to the terms and conditions of the GNU General Public
 | 
						|
 * License.  See the file "COPYING" in the main directory of this archive
 | 
						|
 * for more details.
 | 
						|
 */
 | 
						|
 | 
						|
#ifndef __MICROBLAZE_UNWIND_H
 | 
						|
#define __MICROBLAZE_UNWIND_H
 | 
						|
 | 
						|
struct stack_trace;
 | 
						|
 | 
						|
struct trap_handler_info {
 | 
						|
	unsigned long start_addr;
 | 
						|
	unsigned long end_addr;
 | 
						|
	const char    *trap_name;
 | 
						|
};
 | 
						|
extern struct trap_handler_info microblaze_trap_handlers;
 | 
						|
 | 
						|
extern const char _hw_exception_handler;
 | 
						|
extern const char ex_handler_unhandled;
 | 
						|
 | 
						|
void microblaze_unwind(struct task_struct *task, struct stack_trace *trace);
 | 
						|
 | 
						|
#endif	/* __MICROBLAZE_UNWIND_H */
 | 
						|
 |