From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-6.0 required=3.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,MENTIONS_GIT_HOSTING,SPF_PASS autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id EA401C43219 for ; Tue, 30 Apr 2019 14:13:41 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id C1E8421707 for ; Tue, 30 Apr 2019 14:13:41 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727345AbfD3ONk (ORCPT ); Tue, 30 Apr 2019 10:13:40 -0400 Received: from iolanthe.rowland.org ([192.131.102.54]:35354 "HELO iolanthe.rowland.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with SMTP id S1726294AbfD3ONj (ORCPT ); Tue, 30 Apr 2019 10:13:39 -0400 Received: (qmail 1597 invoked by uid 2102); 30 Apr 2019 10:13:38 -0400 Received: from localhost (sendmail-bs@127.0.0.1) by localhost with SMTP; 30 Apr 2019 10:13:38 -0400 Date: Tue, 30 Apr 2019 10:13:38 -0400 (EDT) From: Alan Stern X-X-Sender: stern@iolanthe.rowland.org To: Eric Biggers cc: syzbot , , , , , , Subject: Re: KASAN: slab-out-of-bounds Read in hex_string In-Reply-To: <20190429210917.GA251866@gmail.com> Message-ID: MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 29 Apr 2019, Eric Biggers wrote: > On Mon, Apr 29, 2019 at 04:07:04PM -0400, Alan Stern wrote: > > Accessing beyond the end of the descriptor. > > > > #syz test: https://github.com/google/kasan.git usb-fuzzer > > > > --- a/drivers/video/fbdev/udlfb.c > > +++ b/drivers/video/fbdev/udlfb.c > > @@ -1511,6 +1511,7 @@ static int dlfb_parse_vendor_descriptor( > > char *buf; > > char *desc_end; > > int total_len; > > + int width; > > > > buf = kzalloc(MAX_VENDOR_DESCRIPTOR_SIZE, GFP_KERNEL); > > if (!buf) > > @@ -1529,9 +1530,10 @@ static int dlfb_parse_vendor_descriptor( > > } > > > > if (total_len > 5) { > > + width = min(total_len, 11); > > dev_info(&intf->dev, > > - "vendor descriptor length: %d data: %11ph\n", > > - total_len, desc); > > + "vendor descriptor length: %d data: %*ph\n", > > + total_len, width, desc); > > > > if ((desc[0] != total_len) || /* descriptor length */ > > (desc[1] != 0x5f) || /* vendor descriptor type */ > > > > > > Why not write just: > > dev_info(&intf->dev, > "vendor descriptor length: %d data: %*ph\n", > total_len, min(total_len, 11), desc); I did consider doing that. In the end I decided adding an extra temporary variable made the code a little more readable. (For some reason, extra recursion -- a function call embedded in a function argument -- seems to demand more mental effort than an extra temporary. Maybe my brain is just getting old...) > Also, aren't there more out-of-bounds reads in the code just after? It only > checks for at least 1 byte available, but then it reads up to 7 bytes: > > while (desc < desc_end) { > u8 length; > u16 key; > > key = *desc++; > key |= (u16)*desc++ << 8; > length = *desc++; > > switch (key) { > case 0x0200: { /* max_area */ > u32 max_area = *desc++; > max_area |= (u32)*desc++ << 8; > max_area |= (u32)*desc++ << 16; > max_area |= (u32)*desc++ << 24; > dev_warn(&intf->dev, > "DL chip limited to %d pixel modes\n", > max_area); > dlfb->sku_pixel_limit = max_area; > break; > } > default: > break; > } > desc += length; > } Quite right. Please feel free to submit a patch fixing all these problems. > Also I couldn't help but notice it's also using 'char' rather than 'u8', > so bytes >= 0x80 are read incorrectly as they're sign extended... As I recall, the C standard doesn't specify whether char is signed or unsigned; it can vary with the implementation. However you are certainly correct that to ensure there is no sign extension, the code should use unsigned char or u8. Alan Stern From mboxrd@z Thu Jan 1 00:00:00 1970 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: base64 Subject: KASAN: slab-out-of-bounds Read in hex_string From: Alan Stern Message-Id: Date: Tue, 30 Apr 2019 10:13:38 -0400 (EDT) To: Eric Biggers Cc: syzbot , andreyknvl@google.com, gregkh@linuxfoundation.org, linux-kernel@vger.kernel.org, linux-usb@vger.kernel.org, rafael@kernel.org, syzkaller-bugs@googlegroups.com List-ID: T24gTW9uLCAyOSBBcHIgMjAxOSwgRXJpYyBCaWdnZXJzIHdyb3RlOgoKPiBPbiBNb24sIEFwciAy OSwgMjAxOSBhdCAwNDowNzowNFBNIC0wNDAwLCBBbGFuIFN0ZXJuIHdyb3RlOgoKPiA+IEFjY2Vz c2luZyBiZXlvbmQgdGhlIGVuZCBvZiB0aGUgZGVzY3JpcHRvci4KPiA+IAo+ID4gI3N5eiB0ZXN0 OiBodHRwczovL2dpdGh1Yi5jb20vZ29vZ2xlL2thc2FuLmdpdCB1c2ItZnV6emVyCj4gPiAKPiA+ IC0tLSBhL2RyaXZlcnMvdmlkZW8vZmJkZXYvdWRsZmIuYwo+ID4gKysrIGIvZHJpdmVycy92aWRl by9mYmRldi91ZGxmYi5jCj4gPiBAQCAtMTUxMSw2ICsxNTExLDcgQEAgc3RhdGljIGludCBkbGZi X3BhcnNlX3ZlbmRvcl9kZXNjcmlwdG9yKAo+ID4gIAljaGFyICpidWY7Cj4gPiAgCWNoYXIgKmRl c2NfZW5kOwo+ID4gIAlpbnQgdG90YWxfbGVuOwo+ID4gKwlpbnQgd2lkdGg7Cj4gPiAgCj4gPiAg CWJ1ZiA9IGt6YWxsb2MoTUFYX1ZFTkRPUl9ERVNDUklQVE9SX1NJWkUsIEdGUF9LRVJORUwpOwo+ ID4gIAlpZiAoIWJ1ZikKPiA+IEBAIC0xNTI5LDkgKzE1MzAsMTAgQEAgc3RhdGljIGludCBkbGZi X3BhcnNlX3ZlbmRvcl9kZXNjcmlwdG9yKAo+ID4gIAl9Cj4gPiAgCj4gPiAgCWlmICh0b3RhbF9s ZW4gPiA1KSB7Cj4gPiArCQl3aWR0aCA9IG1pbih0b3RhbF9sZW4sIDExKTsKPiA+ICAJCWRldl9p bmZvKCZpbnRmLT5kZXYsCj4gPiAtCQkJICJ2ZW5kb3IgZGVzY3JpcHRvciBsZW5ndGg6ICVkIGRh dGE6ICUxMXBoXG4iLAo+ID4gLQkJCSB0b3RhbF9sZW4sIGRlc2MpOwo+ID4gKwkJCSAidmVuZG9y IGRlc2NyaXB0b3IgbGVuZ3RoOiAlZCBkYXRhOiAlKnBoXG4iLAo+ID4gKwkJCSB0b3RhbF9sZW4s IHdpZHRoLCBkZXNjKTsKPiA+ICAKPiA+ICAJCWlmICgoZGVzY1swXSAhPSB0b3RhbF9sZW4pIHx8 IC8qIGRlc2NyaXB0b3IgbGVuZ3RoICovCj4gPiAgCQkgICAgKGRlc2NbMV0gIT0gMHg1ZikgfHwg ICAvKiB2ZW5kb3IgZGVzY3JpcHRvciB0eXBlICovCj4gPiAKPiA+IAo+IAo+IFdoeSBub3Qgd3Jp dGUganVzdDoKPiAKPiAgICAgICAgICAgICAgICAgZGV2X2luZm8oJmludGYtPmRldiwKPiAgICAg ICAgICAgICAgICAgICAgICAgICAgInZlbmRvciBkZXNjcmlwdG9yIGxlbmd0aDogJWQgZGF0YTog JSpwaFxuIiwKPiAgICAgICAgICAgICAgICAgICAgICAgICAgdG90YWxfbGVuLCBtaW4odG90YWxf bGVuLCAxMSksIGRlc2MpOwoKSSBkaWQgY29uc2lkZXIgZG9pbmcgdGhhdC4gIEluIHRoZSBlbmQg SSBkZWNpZGVkIGFkZGluZyBhbiBleHRyYQp0ZW1wb3JhcnkgdmFyaWFibGUgbWFkZSB0aGUgY29k ZSBhIGxpdHRsZSBtb3JlIHJlYWRhYmxlLiAgKEZvciBzb21lIApyZWFzb24sIGV4dHJhIHJlY3Vy c2lvbiAtLSBhIGZ1bmN0aW9uIGNhbGwgZW1iZWRkZWQgaW4gYSBmdW5jdGlvbiAKYXJndW1lbnQg LS0gc2VlbXMgdG8gZGVtYW5kIG1vcmUgbWVudGFsIGVmZm9ydCB0aGFuIGFuIGV4dHJhIAp0ZW1w b3JhcnkuICBNYXliZSBteSBicmFpbiBpcyBqdXN0IGdldHRpbmcgb2xkLi4uKQoKPiBBbHNvLCBh cmVuJ3QgdGhlcmUgbW9yZSBvdXQtb2YtYm91bmRzIHJlYWRzIGluIHRoZSBjb2RlIGp1c3QgYWZ0 ZXI/ICBJdCBvbmx5Cj4gY2hlY2tzIGZvciBhdCBsZWFzdCAxIGJ5dGUgYXZhaWxhYmxlLCBidXQg dGhlbiBpdCByZWFkcyB1cCB0byA3IGJ5dGVzOgo+IAo+IAkJd2hpbGUgKGRlc2MgPCBkZXNjX2Vu ZCkgewo+IAkJCXU4IGxlbmd0aDsKPiAJCQl1MTYga2V5Owo+IAo+IAkJCWtleSA9ICpkZXNjKys7 Cj4gCQkJa2V5IHw9ICh1MTYpKmRlc2MrKyA8PCA4Owo+IAkJCWxlbmd0aCA9ICpkZXNjKys7Cj4g Cj4gCQkJc3dpdGNoIChrZXkpIHsKPiAJCQljYXNlIDB4MDIwMDogeyAvKiBtYXhfYXJlYSAqLwo+ IAkJCQl1MzIgbWF4X2FyZWEgPSAqZGVzYysrOwo+IAkJCQltYXhfYXJlYSB8PSAodTMyKSpkZXNj KysgPDwgODsKPiAJCQkJbWF4X2FyZWEgfD0gKHUzMikqZGVzYysrIDw8IDE2Owo+IAkJCQltYXhf YXJlYSB8PSAodTMyKSpkZXNjKysgPDwgMjQ7Cj4gCQkJCWRldl93YXJuKCZpbnRmLT5kZXYsCj4g CQkJCQkgIkRMIGNoaXAgbGltaXRlZCB0byAlZCBwaXhlbCBtb2Rlc1xuIiwKPiAJCQkJCSBtYXhf YXJlYSk7Cj4gCQkJCWRsZmItPnNrdV9waXhlbF9saW1pdCA9IG1heF9hcmVhOwo+IAkJCQlicmVh azsKPiAJCQl9Cj4gCQkJZGVmYXVsdDoKPiAJCQkJYnJlYWs7Cj4gCQkJfQo+IAkJCWRlc2MgKz0g bGVuZ3RoOwo+IAkJfQoKUXVpdGUgcmlnaHQuICBQbGVhc2UgZmVlbCBmcmVlIHRvIHN1Ym1pdCBh IHBhdGNoIGZpeGluZyBhbGwgdGhlc2UgCnByb2JsZW1zLgoKPiBBbHNvIEkgY291bGRuJ3QgaGVs cCBidXQgbm90aWNlIGl0J3MgYWxzbyB1c2luZyAnY2hhcicgcmF0aGVyIHRoYW4gJ3U4JywKPiBz byBieXRlcyA+PSAweDgwIGFyZSByZWFkIGluY29ycmVjdGx5IGFzIHRoZXkncmUgc2lnbiBleHRl bmRlZC4uLgoKQXMgSSByZWNhbGwsIHRoZSBDIHN0YW5kYXJkIGRvZXNuJ3Qgc3BlY2lmeSB3aGV0 aGVyIGNoYXIgaXMgc2lnbmVkIG9yCnVuc2lnbmVkOyBpdCBjYW4gdmFyeSB3aXRoIHRoZSBpbXBs ZW1lbnRhdGlvbi4gIEhvd2V2ZXIgeW91IGFyZQpjZXJ0YWlubHkgY29ycmVjdCB0aGF0IHRvIGVu c3VyZSB0aGVyZSBpcyBubyBzaWduIGV4dGVuc2lvbiwgdGhlIGNvZGUKc2hvdWxkIHVzZSB1bnNp Z25lZCBjaGFyIG9yIHU4LgoKQWxhbiBTdGVybgo=