USB: serial: add macro for console error reporting
authorJohan Hovold <jhovold@gmail.com>
Mon, 6 Feb 2012 18:22:19 +0000 (19:22 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 9 Feb 2012 16:43:02 +0000 (08:43 -0800)
Add macro which prints an error message only once if port is used a
console.

Reporting errors in a write path when port is used as a console could
otherwise result in an infinite loop.

Signed-off-by: Johan Hovold <jhovold@gmail.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
include/linux/usb/serial.h

index 4267a9c717baac379045ad953746e2b0569b9b95..10cb74d2ad1d75ba983f46e843eecb286cbc1a4c 100644 (file)
@@ -389,5 +389,20 @@ do {                                                                       \
                printk(KERN_DEBUG "%s: " format "\n", __FILE__, ##arg); \
 } while (0)
 
+/*
+ * Macro for reporting errors in write path to avoid inifinite loop
+ * when port is used as a console.
+ */
+#define dev_err_console(usport, fmt, ...)                              \
+do {                                                                   \
+       static bool __print_once;                                       \
+       struct usb_serial_port *__port = (usport);                      \
+                                                                       \
+       if (!__port->port.console || !__print_once) {                   \
+               __print_once = true;                                    \
+               dev_err(&__port->dev, fmt, ##__VA_ARGS__);              \
+       }                                                               \
+} while (0)
+
 #endif /* __LINUX_USB_SERIAL_H */