Joe Perches
2011-Jun-12 16:21 UTC
[PATCH 1/2] xen: Add __attribute__((format(printf... where appropriate
Use the compiler to verify printf formats and arguments. Fix fallout. Signed-off-by: Joe Perches <joe at perches.com> --- drivers/block/xen-blkback/xenbus.c | 2 +- include/xen/hvc-console.h | 4 +++- include/xen/xenbus.h | 2 ++ 3 files changed, 6 insertions(+), 2 deletions(-) diff --git a/drivers/block/xen-blkback/xenbus.c b/drivers/block/xen-blkback/xenbus.c index 6cc0db1..3f129b4 100644 --- a/drivers/block/xen-blkback/xenbus.c +++ b/drivers/block/xen-blkback/xenbus.c @@ -684,7 +684,7 @@ again: err = xenbus_switch_state(dev, XenbusStateConnected); if (err) - xenbus_dev_fatal(dev, err, "switching to Connected state", + xenbus_dev_fatal(dev, err, "%s: switching to Connected state", dev->nodename); return; diff --git a/include/xen/hvc-console.h b/include/xen/hvc-console.h index c3adde3..901724d 100644 --- a/include/xen/hvc-console.h +++ b/include/xen/hvc-console.h @@ -6,11 +6,13 @@ extern struct console xenboot_console; #ifdef CONFIG_HVC_XEN void xen_console_resume(void); void xen_raw_console_write(const char *str); +__attribute__((format(printf, 1, 2))) void xen_raw_printk(const char *fmt, ...); #else static inline void xen_console_resume(void) { } static inline void xen_raw_console_write(const char *str) { } -static inline void xen_raw_printk(const char *fmt, ...) { } +static inline __attribute__((format(printf, 1, 2))) +void xen_raw_printk(const char *fmt, ...) { } #endif #endif /* XEN_HVC_CONSOLE_H */ diff --git a/include/xen/xenbus.h b/include/xen/xenbus.h index 5467369..aceeca7 100644 --- a/include/xen/xenbus.h +++ b/include/xen/xenbus.h @@ -223,7 +223,9 @@ int xenbus_free_evtchn(struct xenbus_device *dev, int port); enum xenbus_state xenbus_read_driver_state(const char *path); +__attribute__((format(printf, 3, 4))) void xenbus_dev_error(struct xenbus_device *dev, int err, const char *fmt, ...); +__attribute__((format(printf, 3, 4))) void xenbus_dev_fatal(struct xenbus_device *dev, int err, const char *fmt, ...); const char *xenbus_strstate(enum xenbus_state state); -- 1.7.6.rc1
Konrad Rzeszutek Wilk
2011-Jun-13 16:31 UTC
[Xen-devel] [PATCH 1/2] xen: Add __attribute__((format(printf... where appropriate
On Sun, Jun 12, 2011 at 09:21:13AM -0700, Joe Perches wrote:> Use the compiler to verify printf formats and arguments. >What compiler? If this is not included in 3.0 what is the fallout?> Fix fallout. > > Signed-off-by: Joe Perches <joe at perches.com> > --- > drivers/block/xen-blkback/xenbus.c | 2 +- > include/xen/hvc-console.h | 4 +++- > include/xen/xenbus.h | 2 ++ > 3 files changed, 6 insertions(+), 2 deletions(-) > > diff --git a/drivers/block/xen-blkback/xenbus.c b/drivers/block/xen-blkback/xenbus.c > index 6cc0db1..3f129b4 100644 > --- a/drivers/block/xen-blkback/xenbus.c > +++ b/drivers/block/xen-blkback/xenbus.c > @@ -684,7 +684,7 @@ again: > > err = xenbus_switch_state(dev, XenbusStateConnected); > if (err) > - xenbus_dev_fatal(dev, err, "switching to Connected state", > + xenbus_dev_fatal(dev, err, "%s: switching to Connected state", > dev->nodename); > > return; > diff --git a/include/xen/hvc-console.h b/include/xen/hvc-console.h > index c3adde3..901724d 100644 > --- a/include/xen/hvc-console.h > +++ b/include/xen/hvc-console.h > @@ -6,11 +6,13 @@ extern struct console xenboot_console; > #ifdef CONFIG_HVC_XEN > void xen_console_resume(void); > void xen_raw_console_write(const char *str); > +__attribute__((format(printf, 1, 2))) > void xen_raw_printk(const char *fmt, ...); > #else > static inline void xen_console_resume(void) { } > static inline void xen_raw_console_write(const char *str) { } > -static inline void xen_raw_printk(const char *fmt, ...) { } > +static inline __attribute__((format(printf, 1, 2))) > +void xen_raw_printk(const char *fmt, ...) { } > #endif > > #endif /* XEN_HVC_CONSOLE_H */ > diff --git a/include/xen/xenbus.h b/include/xen/xenbus.h > index 5467369..aceeca7 100644 > --- a/include/xen/xenbus.h > +++ b/include/xen/xenbus.h > @@ -223,7 +223,9 @@ int xenbus_free_evtchn(struct xenbus_device *dev, int port); > > enum xenbus_state xenbus_read_driver_state(const char *path); > > +__attribute__((format(printf, 3, 4))) > void xenbus_dev_error(struct xenbus_device *dev, int err, const char *fmt, ...); > +__attribute__((format(printf, 3, 4))) > void xenbus_dev_fatal(struct xenbus_device *dev, int err, const char *fmt, ...); > > const char *xenbus_strstate(enum xenbus_state state); > -- > 1.7.6.rc1 > > > _______________________________________________ > Xen-devel mailing list > Xen-devel at lists.xensource.com > http://lists.xensource.com/xen-devel
Apparently Analagous Threads
- [PATCH 1/2] xen: Add __attribute__((format(printf... where appropriate
- [PATCH 1/2] xen: Add __attribute__((format(printf... where appropriate
- [PATCH 0001/001] xen: multi page ring support for block devices
- [PATCH 0001/001] xen: multi page ring support for block devices
- [PATCH 0001/001] xen: multi page ring support for block devices