On Tue, 2016-03-08 at 21:40 +0100, Rasmus Villemoes wrote: > Passing overlapping source and destination is fragile, and in this > case we can even simplify the code and avoid the huge stack buffer by > using the %p extension for printing a small hex dump. [] > diff --git a/drivers/usb/atm/usbatm.c b/drivers/usb/atm/usbatm.c [] > @@ -1331,15 +1331,12 @@ MODULE_VERSION(DRIVER_VERSION); > static int usbatm_print_packet(struct usbatm_data *instance, > const unsigned char *data, int len) > { > - unsigned char buffer[256]; > - int i = 0, j = 0; > + int i, j; > > for (i = 0; i < len;) { > - buffer[0] = '\0'; > - sprintf(buffer, "%.3d :", i); > - for (j = 0; (j < 16) && (i < len); j++, i++) > - sprintf(buffer, "%s %2.2x", buffer, data[i]); > - dev_dbg(&instance->usb_intf->dev, "%s", buffer); > + j = min(16, len-i); > + dev_dbg(&instance->usb_intf->dev, "%.3d : %*ph", i, j, data + i); > + i += j; > } > return i; > } Maybe use print_dump_hex_debug() -- To unsubscribe from this list: send the line "unsubscribe linux-usb" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html