mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 47ad7b9bbe
			
		
	
	
		47ad7b9bbe
		
	
	
	
	
		
			
			This commit fixes a number of issues with the tile backtrace code. - Don't try to identify userspace shared object or executable paths if we are doing a backtrace from an interrupt; it's not legal, and also unlikely to be interesting. Likewise, don't try to do it for other address spaces, since d_path() assumes it is being called in "current" context. - Move "in_backtrace" from thread_struct to thread_info. This way we can access it even if our stack thread_info has been clobbered, which makes backtracing more robust. - Avoid using "current" directly when testing for is_sigreturn(). Since "current" may be corrupt, we're better off using kbt->task explicitly to look up the vdso_base for the current task. Conveniently, this simplifies the internal APIs (we only need one is_sigreturn() function now). - Avoid bogus "Odd fault" warning when pc/sp/ex1 are all zero, as is true for kernel threads above the last frame. - Hook into Tejun Heo's dump_stack() framework in lib/dump_stack.c. - Write last entry in save_stack_trace() as ULONG_MAX, not zero, since ftrace (at least) relies on finding that marker. - Implement save_stack_trace_regs() and save_strack_trace_user(), and set CONFIG_USER_STACKTRACE_SUPPORT. Signed-off-by: Chris Metcalf <cmetcalf@ezchip.com>
		
			
				
	
	
		
			92 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Copyright 2010 Tilera Corporation. All Rights Reserved.
 | |
|  *
 | |
|  *   This program is free software; you can redistribute it and/or
 | |
|  *   modify it under the terms of the GNU General Public License
 | |
|  *   as published by the Free Software Foundation, version 2.
 | |
|  *
 | |
|  *   This program is distributed in the hope that it will be useful, but
 | |
|  *   WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  *   MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE, GOOD TITLE or
 | |
|  *   NON INFRINGEMENT.  See the GNU General Public License for
 | |
|  *   more details.
 | |
|  *
 | |
|  * Exports from assembler code and from libtile-cc.
 | |
|  */
 | |
| 
 | |
| #include <linux/module.h>
 | |
| 
 | |
| /* arch/tile/lib/usercopy.S */
 | |
| #include <linux/uaccess.h>
 | |
| EXPORT_SYMBOL(clear_user_asm);
 | |
| EXPORT_SYMBOL(flush_user_asm);
 | |
| EXPORT_SYMBOL(finv_user_asm);
 | |
| 
 | |
| /* arch/tile/kernel/entry.S */
 | |
| #include <linux/kernel.h>
 | |
| #include <asm/processor.h>
 | |
| EXPORT_SYMBOL(current_text_addr);
 | |
| 
 | |
| /* arch/tile/kernel/head.S */
 | |
| EXPORT_SYMBOL(empty_zero_page);
 | |
| 
 | |
| #ifdef CONFIG_FUNCTION_TRACER
 | |
| /* arch/tile/kernel/mcount_64.S */
 | |
| #include <asm/ftrace.h>
 | |
| EXPORT_SYMBOL(__mcount);
 | |
| #endif /* CONFIG_FUNCTION_TRACER */
 | |
| 
 | |
| /* arch/tile/lib/, various memcpy files */
 | |
| EXPORT_SYMBOL(memcpy);
 | |
| EXPORT_SYMBOL(__copy_to_user_inatomic);
 | |
| EXPORT_SYMBOL(__copy_from_user_inatomic);
 | |
| EXPORT_SYMBOL(__copy_from_user_zeroing);
 | |
| #ifdef __tilegx__
 | |
| EXPORT_SYMBOL(__copy_in_user_inatomic);
 | |
| #endif
 | |
| 
 | |
| /* hypervisor glue */
 | |
| #include <hv/hypervisor.h>
 | |
| EXPORT_SYMBOL(hv_dev_open);
 | |
| EXPORT_SYMBOL(hv_dev_pread);
 | |
| EXPORT_SYMBOL(hv_dev_pwrite);
 | |
| EXPORT_SYMBOL(hv_dev_preada);
 | |
| EXPORT_SYMBOL(hv_dev_pwritea);
 | |
| EXPORT_SYMBOL(hv_dev_poll);
 | |
| EXPORT_SYMBOL(hv_dev_poll_cancel);
 | |
| EXPORT_SYMBOL(hv_dev_close);
 | |
| EXPORT_SYMBOL(hv_sysconf);
 | |
| EXPORT_SYMBOL(hv_confstr);
 | |
| EXPORT_SYMBOL(hv_get_rtc);
 | |
| EXPORT_SYMBOL(hv_set_rtc);
 | |
| 
 | |
| /* libgcc.a */
 | |
| uint32_t __udivsi3(uint32_t dividend, uint32_t divisor);
 | |
| EXPORT_SYMBOL(__udivsi3);
 | |
| int32_t __divsi3(int32_t dividend, int32_t divisor);
 | |
| EXPORT_SYMBOL(__divsi3);
 | |
| uint64_t __udivdi3(uint64_t dividend, uint64_t divisor);
 | |
| EXPORT_SYMBOL(__udivdi3);
 | |
| int64_t __divdi3(int64_t dividend, int64_t divisor);
 | |
| EXPORT_SYMBOL(__divdi3);
 | |
| uint32_t __umodsi3(uint32_t dividend, uint32_t divisor);
 | |
| EXPORT_SYMBOL(__umodsi3);
 | |
| int32_t __modsi3(int32_t dividend, int32_t divisor);
 | |
| EXPORT_SYMBOL(__modsi3);
 | |
| uint64_t __umoddi3(uint64_t dividend, uint64_t divisor);
 | |
| EXPORT_SYMBOL(__umoddi3);
 | |
| int64_t __moddi3(int64_t dividend, int64_t divisor);
 | |
| EXPORT_SYMBOL(__moddi3);
 | |
| #ifndef __tilegx__
 | |
| int64_t __muldi3(int64_t, int64_t);
 | |
| EXPORT_SYMBOL(__muldi3);
 | |
| uint64_t __lshrdi3(uint64_t, unsigned int);
 | |
| EXPORT_SYMBOL(__lshrdi3);
 | |
| uint64_t __ashrdi3(uint64_t, unsigned int);
 | |
| EXPORT_SYMBOL(__ashrdi3);
 | |
| uint64_t __ashldi3(uint64_t, unsigned int);
 | |
| EXPORT_SYMBOL(__ashldi3);
 | |
| int __ffsdi2(uint64_t);
 | |
| EXPORT_SYMBOL(__ffsdi2);
 | |
| #endif
 |