diff options
author | Joe Perches <joe@perches.com> | 2010-06-26 21:02:35 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-07-04 13:40:18 -0400 |
commit | 256df2f3879efdb2e9808bdb1b54b16fbb11fa38 (patch) | |
tree | ec7bd8e1e6d7d7066542420641ccd68e98e42bfa /net/core/dev.c | |
parent | 99bcf217183e02ebae46373896fba7f12d588001 (diff) |
netdevice.h net/core/dev.c: Convert netdev_<level> logging macros to functions
Reduces an x86 defconfig text and data ~2k.
text is smaller, data is larger.
$ size vmlinux*
text data bss dec hex filename
7198862 720112 1366288 9285262 8dae8e vmlinux
7205273 716016 1366288 9287577 8db799 vmlinux.device_h
Uses %pV and struct va_format
Format arguments are verified before printk
Signed-off-by: Joe Perches <joe@perches.com>
Acked-by: Greg Kroah-Hartman <gregkh@suse.de>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/core/dev.c')
-rw-r--r-- | net/core/dev.c | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/net/core/dev.c b/net/core/dev.c index e85cc5fa3c4e..93b8929fa21d 100644 --- a/net/core/dev.c +++ b/net/core/dev.c | |||
@@ -5802,6 +5802,68 @@ char *netdev_drivername(const struct net_device *dev, char *buffer, int len) | |||
5802 | return buffer; | 5802 | return buffer; |
5803 | } | 5803 | } |
5804 | 5804 | ||
5805 | static int __netdev_printk(const char *level, const struct net_device *dev, | ||
5806 | struct va_format *vaf) | ||
5807 | { | ||
5808 | int r; | ||
5809 | |||
5810 | if (dev && dev->dev.parent) | ||
5811 | r = dev_printk(level, dev->dev.parent, "%s: %pV", | ||
5812 | netdev_name(dev), vaf); | ||
5813 | else if (dev) | ||
5814 | r = printk("%s%s: %pV", level, netdev_name(dev), vaf); | ||
5815 | else | ||
5816 | r = printk("%s(NULL net_device): %pV", level, vaf); | ||
5817 | |||
5818 | return r; | ||
5819 | } | ||
5820 | |||
5821 | int netdev_printk(const char *level, const struct net_device *dev, | ||
5822 | const char *format, ...) | ||
5823 | { | ||
5824 | struct va_format vaf; | ||
5825 | va_list args; | ||
5826 | int r; | ||
5827 | |||
5828 | va_start(args, format); | ||
5829 | |||
5830 | vaf.fmt = format; | ||
5831 | vaf.va = &args; | ||
5832 | |||
5833 | r = __netdev_printk(level, dev, &vaf); | ||
5834 | va_end(args); | ||
5835 | |||
5836 | return r; | ||
5837 | } | ||
5838 | EXPORT_SYMBOL(netdev_printk); | ||
5839 | |||
5840 | #define define_netdev_printk_level(func, level) \ | ||
5841 | int func(const struct net_device *dev, const char *fmt, ...) \ | ||
5842 | { \ | ||
5843 | int r; \ | ||
5844 | struct va_format vaf; \ | ||
5845 | va_list args; \ | ||
5846 | \ | ||
5847 | va_start(args, fmt); \ | ||
5848 | \ | ||
5849 | vaf.fmt = fmt; \ | ||
5850 | vaf.va = &args; \ | ||
5851 | \ | ||
5852 | r = __netdev_printk(level, dev, &vaf); \ | ||
5853 | va_end(args); \ | ||
5854 | \ | ||
5855 | return r; \ | ||
5856 | } \ | ||
5857 | EXPORT_SYMBOL(func); | ||
5858 | |||
5859 | define_netdev_printk_level(netdev_emerg, KERN_EMERG); | ||
5860 | define_netdev_printk_level(netdev_alert, KERN_ALERT); | ||
5861 | define_netdev_printk_level(netdev_crit, KERN_CRIT); | ||
5862 | define_netdev_printk_level(netdev_err, KERN_ERR); | ||
5863 | define_netdev_printk_level(netdev_warn, KERN_WARNING); | ||
5864 | define_netdev_printk_level(netdev_notice, KERN_NOTICE); | ||
5865 | define_netdev_printk_level(netdev_info, KERN_INFO); | ||
5866 | |||
5805 | static void __net_exit netdev_exit(struct net *net) | 5867 | static void __net_exit netdev_exit(struct net *net) |
5806 | { | 5868 | { |
5807 | kfree(net->dev_name_head); | 5869 | kfree(net->dev_name_head); |