From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933221AbcCJX4x (ORCPT ); Thu, 10 Mar 2016 18:56:53 -0500 Received: from mail.linuxfoundation.org ([140.211.169.12]:35375 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932882AbcCJX4t (ORCPT ); Thu, 10 Mar 2016 18:56:49 -0500 Date: Thu, 10 Mar 2016 15:56:42 -0800 From: Greg Kroah-Hartman To: Joe Perches Cc: Rasmus Villemoes , Kees Cook , Andrew Morton , Duncan Sands , linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [RFC 7/7] USB: usbatm: avoid fragile and inefficient snprintf use Message-ID: <20160310235642.GA2586@kroah.com> References: <1457469654-17059-1-git-send-email-linux@rasmusvillemoes.dk> <1457469654-17059-8-git-send-email-linux@rasmusvillemoes.dk> <1457470869.10628.3.camel@perches.com> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <1457470869.10628.3.camel@perches.com> User-Agent: Mutt/1.5.24 (2015-08-30) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Mar 08, 2016 at 01:01:09PM -0800, Joe Perches wrote: > 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() Yes, please use that instead.