mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 10:40:15 +02:00 
			
		
		
		
	dynamic_debug: add trim_prefix() to provide source-root relative paths
trim_prefix(path) skips past the absolute source path root, and returns the pointer to the relative path from there. It is used to shorten the displayed path in $DBGMT/dynamic_debug/control via ddebug_proc_show(), and in ddebug_change() to allow relative filenames to be used in applied queries. For example: ~# echo file kernel/freezer.c +p > $DBGMT/dynamic_debug/control kernel/freezer.c:128 [freezer]cancel_freezing p " clean up: %s\012" trim_prefix(path) insures common prefix before trimming it, so out-of-tree module paths are shown as full absolute paths. Signed-off-by: Jim Cromie <jim.cromie@gmail.com> Signed-off-by: Jason Baron <jbaron@redhat.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
		
							parent
							
								
									7281491c59
								
							
						
					
					
						commit
						2b6783191d
					
				
					 2 changed files with 19 additions and 6 deletions
				
			
		| 
						 | 
				
			
			@ -144,11 +144,12 @@ func
 | 
			
		|||
    func svc_tcp_accept
 | 
			
		||||
 | 
			
		||||
file
 | 
			
		||||
    The given string is compared against either the full
 | 
			
		||||
    pathname or the basename of the source file of each
 | 
			
		||||
    callsite.  Examples:
 | 
			
		||||
    The given string is compared against either the full pathname, the
 | 
			
		||||
    src-root relative pathname, or the basename of the source file of
 | 
			
		||||
    each callsite.  Examples:
 | 
			
		||||
 | 
			
		||||
    file svcsock.c
 | 
			
		||||
    file kernel/freezer.c
 | 
			
		||||
    file /usr/src/packages/BUILD/sgi-enhancednfs-1.4/default/net/sunrpc/svcsock.c
 | 
			
		||||
 | 
			
		||||
module
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -69,6 +69,17 @@ static inline const char *basename(const char *path)
 | 
			
		|||
	return tail ? tail+1 : path;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* Return the path relative to source root */
 | 
			
		||||
static inline const char *trim_prefix(const char *path)
 | 
			
		||||
{
 | 
			
		||||
	int skip = strlen(__FILE__) - strlen("lib/dynamic_debug.c");
 | 
			
		||||
 | 
			
		||||
	if (strncmp(path, __FILE__, skip))
 | 
			
		||||
		skip = 0; /* prefix mismatch, don't skip */
 | 
			
		||||
 | 
			
		||||
	return path + skip;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static struct { unsigned flag:8; char opt_char; } opt_array[] = {
 | 
			
		||||
	{ _DPRINTK_FLAGS_PRINT, 'p' },
 | 
			
		||||
	{ _DPRINTK_FLAGS_INCL_MODNAME, 'm' },
 | 
			
		||||
| 
						 | 
				
			
			@ -125,7 +136,8 @@ static void ddebug_change(const struct ddebug_query *query,
 | 
			
		|||
			/* match against the source filename */
 | 
			
		||||
			if (query->filename &&
 | 
			
		||||
			    strcmp(query->filename, dp->filename) &&
 | 
			
		||||
			    strcmp(query->filename, basename(dp->filename)))
 | 
			
		||||
			    strcmp(query->filename, basename(dp->filename)) &&
 | 
			
		||||
			    strcmp(query->filename, trim_prefix(dp->filename)))
 | 
			
		||||
				continue;
 | 
			
		||||
 | 
			
		||||
			/* match against the function */
 | 
			
		||||
| 
						 | 
				
			
			@ -154,7 +166,7 @@ static void ddebug_change(const struct ddebug_query *query,
 | 
			
		|||
			dp->flags = newflags;
 | 
			
		||||
			if (verbose)
 | 
			
		||||
				pr_info("changed %s:%d [%s]%s =%s\n",
 | 
			
		||||
					dp->filename, dp->lineno,
 | 
			
		||||
					trim_prefix(dp->filename), dp->lineno,
 | 
			
		||||
					dt->mod_name, dp->function,
 | 
			
		||||
					ddebug_describe_flags(dp, flagbuf,
 | 
			
		||||
							sizeof(flagbuf)));
 | 
			
		||||
| 
						 | 
				
			
			@ -714,7 +726,7 @@ static int ddebug_proc_show(struct seq_file *m, void *p)
 | 
			
		|||
	}
 | 
			
		||||
 | 
			
		||||
	seq_printf(m, "%s:%u [%s]%s =%s \"",
 | 
			
		||||
		dp->filename, dp->lineno,
 | 
			
		||||
		trim_prefix(dp->filename), dp->lineno,
 | 
			
		||||
		iter->table->mod_name, dp->function,
 | 
			
		||||
		ddebug_describe_flags(dp, flagsbuf, sizeof(flagsbuf)));
 | 
			
		||||
	seq_escape(m, dp->format, "\t\r\n\"");
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in a new issue