Initial commit
	
		
			
	
		
	
	
		
	
		
			Some checks failed
		
		
	
	
		
			
				
	
				Build Kernel / Build all affected Kernels (push) Has been cancelled
				
			
		
			
				
	
				Build all core packages / Build all core packages for selected target (push) Has been cancelled
				
			
		
			
				
	
				Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
				
			
		
			
				
	
				Build Toolchains / Build Toolchains for each target (push) Has been cancelled
				
			
		
			
				
	
				Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
				
			
		
			
				
	
				Coverity scan build / Coverity x86/64 build (push) Has been cancelled
				
			
		
		
	
	
				
					
				
			
		
			Some checks failed
		
		
	
	Build Kernel / Build all affected Kernels (push) Has been cancelled
				
			Build all core packages / Build all core packages for selected target (push) Has been cancelled
				
			Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
				
			Build Toolchains / Build Toolchains for each target (push) Has been cancelled
				
			Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
				
			Coverity scan build / Coverity x86/64 build (push) Has been cancelled
				
			This commit is contained in:
		| @@ -0,0 +1,41 @@ | ||||
| From: Felix Fietkau <nbd@nbd.name> | ||||
| Subject: kernel: when KALLSYMS is disabled, print module address + size for matching backtrace entries | ||||
|  | ||||
| [john@phrozen.org: felix will add this to his upstream queue] | ||||
|  | ||||
| lede-commit 53827cdc824556cda910b23ce5030c363b8f1461 | ||||
| Signed-off-by: Felix Fietkau <nbd@nbd.name> | ||||
| --- | ||||
|  lib/vsprintf.c | 15 +++++++++++---- | ||||
|  1 file changed, 11 insertions(+), 4 deletions(-) | ||||
|  | ||||
| --- a/lib/vsprintf.c | ||||
| +++ b/lib/vsprintf.c | ||||
| @@ -982,8 +982,10 @@ char *symbol_string(char *buf, char *end | ||||
|  		    struct printf_spec spec, const char *fmt) | ||||
|  { | ||||
|  	unsigned long value; | ||||
| -#ifdef CONFIG_KALLSYMS | ||||
|  	char sym[KSYM_SYMBOL_LEN]; | ||||
| +#ifndef CONFIG_KALLSYMS | ||||
| +	struct module *mod; | ||||
| +	int len; | ||||
|  #endif | ||||
|   | ||||
|  	if (fmt[1] == 'R') | ||||
| @@ -1004,8 +1006,14 @@ char *symbol_string(char *buf, char *end | ||||
|   | ||||
|  	return string_nocheck(buf, end, sym, spec); | ||||
|  #else | ||||
| -	return special_hex_number(buf, end, value, sizeof(void *)); | ||||
| +	len = snprintf(sym, sizeof(sym), "0x%lx", value); | ||||
| +	mod = __module_address(value); | ||||
| +	if (mod) | ||||
| +		snprintf(sym + len, sizeof(sym) - len, " [%s@%p+0x%x]", | ||||
| +			 mod->name, mod->mem[MOD_TEXT].base, | ||||
| +			 mod->mem[MOD_TEXT].size); | ||||
|  #endif | ||||
| +	return string(buf, end, sym, spec); | ||||
|  } | ||||
|   | ||||
|  static const struct printf_spec default_str_spec = { | ||||
		Reference in New Issue
	
	Block a user
	 domenico
					domenico