diff options
author | Thomas Gleixner <tglx@linutronix.de> | 2009-08-26 09:37:54 +0200 |
---|---|---|
committer | Thomas Gleixner <tglx@linutronix.de> | 2009-08-26 09:37:54 +0200 |
commit | 9e6d9c5e5889ce8fde5afc5066c5825a3d52114d (patch) | |
tree | 5f145236afb7d7cb65efd7ed267ef131e7a05bda /lib | |
parent | 89236ce246166dc6fceef1164bd19cfc13b477a0 (diff) | |
parent | 0a47df7bd2e94290b19870cd71909d3f24a9e959 (diff) | |
download | lwn-9e6d9c5e5889ce8fde5afc5066c5825a3d52114d.tar.gz lwn-9e6d9c5e5889ce8fde5afc5066c5825a3d52114d.zip |
Merge branch 'rt/atomic-locks' into rt/base
Diffstat (limited to 'lib')
-rw-r--r-- | lib/dma-debug.c | 28 |
1 files changed, 16 insertions, 12 deletions
diff --git a/lib/dma-debug.c b/lib/dma-debug.c index 65b0d99b6d0a..58a9f9fc609a 100644 --- a/lib/dma-debug.c +++ b/lib/dma-debug.c @@ -156,9 +156,13 @@ static bool driver_filter(struct device *dev) return true; /* driver filter on and initialized */ - if (current_driver && dev->driver == current_driver) + if (current_driver && dev && dev->driver == current_driver) return true; + /* driver filter on, but we can't filter on a NULL device... */ + if (!dev) + return false; + if (current_driver || !current_driver_name[0]) return false; @@ -183,17 +187,17 @@ static bool driver_filter(struct device *dev) return ret; } -#define err_printk(dev, entry, format, arg...) do { \ - error_count += 1; \ - if (driver_filter(dev) && \ - (show_all_errors || show_num_errors > 0)) { \ - WARN(1, "%s %s: " format, \ - dev_driver_string(dev), \ - dev_name(dev) , ## arg); \ - dump_entry_trace(entry); \ - } \ - if (!show_all_errors && show_num_errors > 0) \ - show_num_errors -= 1; \ +#define err_printk(dev, entry, format, arg...) do { \ + error_count += 1; \ + if (driver_filter(dev) && \ + (show_all_errors || show_num_errors > 0)) { \ + WARN(1, "%s %s: " format, \ + dev ? dev_driver_string(dev) : "NULL", \ + dev ? dev_name(dev) : "NULL", ## arg); \ + dump_entry_trace(entry); \ + } \ + if (!show_all_errors && show_num_errors > 0) \ + show_num_errors -= 1; \ } while (0); /* |