ALSA: core - strip too long file names in snd_print*()
authorTakashi Iwai <tiwai@suse.de>
Thu, 27 Aug 2009 10:34:54 +0000 (12:34 +0200)
committerTakashi Iwai <tiwai@suse.de>
Thu, 27 Aug 2009 10:39:35 +0000 (12:39 +0200)
When modules are built with M= option, they pass long file paths to
__FILE__.  This results in ugly outputs of snd_print*() when
CONFIG_SND_VERBOSE_PRINTK is set.

This patch adds a check of the path and strips the leading path dirs
if the file name is an absolute path to improve the readability of logs.

Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/core/misc.c

index a9710e0c97afe74e800660fe1697c9d100c18539..1d29e678369e5e7b915aaf1c017684baad5beb05 100644 (file)
@@ -35,8 +35,17 @@ void release_and_free_resource(struct resource *res)
 EXPORT_SYMBOL(release_and_free_resource);
 
 #ifdef CONFIG_SND_VERBOSE_PRINTK
-void snd_verbose_printk(const char *file, int line, const char *format, ...)
+static const char *sanity_file_name(const char *path)
 {
+       if (*path == '/')
+               return strrchr(path, '/') + 1;
+       else
+               return path;
+}
+
+void snd_verbose_printk(const char *path, int line, const char *format, ...)
+{
+       const char *file = sanity_file_name(path);
        va_list args;
        
        if (format[0] == '<' && format[1] >= '0' && format[1] <= '7' && format[2] == '>') {
@@ -56,8 +65,9 @@ EXPORT_SYMBOL(snd_verbose_printk);
 #endif
 
 #if defined(CONFIG_SND_DEBUG) && defined(CONFIG_SND_VERBOSE_PRINTK)
-void snd_verbose_printd(const char *file, int line, const char *format, ...)
+void snd_verbose_printd(const char *path, int line, const char *format, ...)
 {
+       const char *file = sanity_file_name(path);
        va_list args;
        
        if (format[0] == '<' && format[1] >= '0' && format[1] <= '7' && format[2] == '>') {