Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp568742pxk; Sun, 30 Aug 2020 14:37:40 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzdnjD3XB6qECVEcOgIEitjWtP1+AmmolsI77+gDT1h2ytsNZNtPZParPGtUPtlWqUphNxC X-Received: by 2002:a17:906:c1c3:: with SMTP id bw3mr9575406ejb.8.1598823459846; Sun, 30 Aug 2020 14:37:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1598823459; cv=none; d=google.com; s=arc-20160816; b=HBJZbZJnnYo9GtT76Rx/RUbzTyrDis3Rqt5CFpJMI1ScUQaBkPQyhs/vpUbTWg7Ron U0SQVFdlOz1t5JAX3yVBFkjgGhQWPhzAIJOs0rsxs1YAkfhRkBdtYJtU2JaV33vyn8pC 3wD+K3a00Knb56r0QmyM/NhhvVqtCK9OlUrJRmZbXs51NCwiK8fXc3YVZdj8NKLyphdc hI8Nrk+c6FOMqiGuaIIU53nFN9wM+kX0RZNEZ5YNgyQa8rgqi6e736LMIDJT7hEaOpjT d3tcDt0LJ9CIirNB0EOZo/H7seKeQSiz9GM2oYs+VgWU8Hn5G5gUSMbRuwJSNoBv1eMS 4h6g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=nPhC1+5bbsbtEa8ZJuKpaDEIo2tOFrzHggB+hQ04mew=; b=sx9/wy4zJ30C4z6wMOpPM79p6PmwERL7K/xv+eGJxP9jliPxJlRAwr0lXA9k7fTtYj P57Wk8ePkeaT5ojpnG9KczATnO9+f1I8hYuKpRqez4vyQDQEOiChxGYx6mgvm48wdC99 +tv836CxgZMQYSznhnXBw67kmN/4DnBUrjDfb9+uMayR3wOOF6GW4N2bW13H88rlFxpo tXSfYkj5ST68qu1xpUciyrCKKdknKuAA3SI9WAcBLhu3t9HeqmbRQbWKW26zpF3kHrMo ZfZoHxORZKA2g8SWhasMMms9pdFi1fqVAOvW913akVY/nX5hhWAfHHbuNQSv6S2dhn+U vMXw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=TzglhZqU; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id w16si3902234eds.210.2020.08.30.14.37.16; Sun, 30 Aug 2020 14:37:39 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=TzglhZqU; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726282AbgH3Vfx (ORCPT + 99 others); Sun, 30 Aug 2020 17:35:53 -0400 Received: from us-smtp-1.mimecast.com ([207.211.31.81]:57064 "EHLO us-smtp-delivery-1.mimecast.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726178AbgH3Vfu (ORCPT ); Sun, 30 Aug 2020 17:35:50 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1598823349; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=nPhC1+5bbsbtEa8ZJuKpaDEIo2tOFrzHggB+hQ04mew=; b=TzglhZqU7hAZNTMsykqs4Qt1wekzvIrt2ZyMvGihQGgkiOXD64eZ4HQuLBWJ7WdTrvPDRX LkB0/iLTl/uC8CTGHyUnR+fqlLlSFeJwzL2AqaoX6Nt6eIhq2hH/BB9SmvcBVQB+o2UL2k 0MJhYcK5ACrjUdJAqqvgbh5ceBvxvBo= Received: from mail-ot1-f69.google.com (mail-ot1-f69.google.com [209.85.210.69]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-225-flJEbupoNWCs8c5zaM8wxw-1; Sun, 30 Aug 2020 17:35:46 -0400 X-MC-Unique: flJEbupoNWCs8c5zaM8wxw-1 Received: by mail-ot1-f69.google.com with SMTP id a3so327133oti.2 for ; Sun, 30 Aug 2020 14:35:46 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-transfer-encoding :content-language; bh=nPhC1+5bbsbtEa8ZJuKpaDEIo2tOFrzHggB+hQ04mew=; b=k+1Sq2dogubVTvC3pWjn1AbVmE6Ny0ltU4mGhocZqSSuLBVm18pdVwJcPPSQuTRDbQ ZoUzhQUNfZPCupDeF3hg0BhiEQNbW/TaziCOw1BQm4YX8Gg/07EMKSgizzWu+TWbdnRA SkiW3ijKGV1AtOzBdXQLit+njYHPxcKtu00fUOveQH7jo/r1KIMTBT7IYiHWojpY9bBr icRsq8fpOgMRLVzRLrB80sTWEdkqI06AsGhhduB3i5dJ20Z21EnZdYMk2FeEtTQ9Gj0r sUwxsTN7jUrYXcM+CJYUOp0XRVLO0LKnx8zkIwNc/1IJhjyMfRLK+jl/mo4sQxR5X+rt dWrA== X-Gm-Message-State: AOAM5328/+B/UE+sSAr7O+1wo0csXx7BMerWxye78yQ4jn7sz6kml3Bc vxub6jIb+l2FgD2KL1MjZGqtnGi9d+JbRBoIPLvqmObvDMAATL+jPN7PWYF7XY0gRq+V5ExX40Y Ep9yTjmaNkBm4bnmq4UdkzRw2 X-Received: by 2002:aca:eb51:: with SMTP id j78mr1837286oih.169.1598823344353; Sun, 30 Aug 2020 14:35:44 -0700 (PDT) X-Received: by 2002:aca:6c5:: with SMTP id 188mr1845062oig.84.1598823343518; Sun, 30 Aug 2020 14:35:43 -0700 (PDT) Received: from trix.remote.csb (075-142-250-213.res.spectrum.com. [75.142.250.213]) by smtp.gmail.com with ESMTPSA id m11sm296973ooe.43.2020.08.30.14.35.41 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Sun, 30 Aug 2020 14:35:43 -0700 (PDT) Subject: Re: [PATCH] usb: gadget: net2272: assert for a valid dma request To: Alan Stern Cc: balbi@kernel.org, gregkh@linuxfoundation.org, natechancellor@gmail.com, ndesaulniers@google.com, christophe.jaillet@wanadoo.fr, peter.chen@nxp.com, b-liu@ti.com, chunfeng.yun@mediatek.com, novikov@ispras.ru, yanaijie@huawei.com, linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org References: <20200830183646.24930-1-trix@redhat.com> <20200830212249.GA528080@rowland.harvard.edu> From: Tom Rix Message-ID: <40bac66a-2c05-6f1b-0e46-e577a54aab6e@redhat.com> Date: Sun, 30 Aug 2020 14:35:41 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.6.0 MIME-Version: 1.0 In-Reply-To: <20200830212249.GA528080@rowland.harvard.edu> Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 8/30/20 2:22 PM, Alan Stern wrote: > On Sun, Aug 30, 2020 at 11:36:46AM -0700, trix@redhat.com wrote: >> From: Tom Rix >> >> clang static analysis flags this representive problem >> >> net2272.c:1541:8: warning: Dereference of null pointer >> if ((req->req.length % ep->ep.maxpacket != 0) || >> ^~~~~~~~~~~~~~~ >> This is mostly not a problem. >> >> In net2272_handle_dma(), even though every path through >> the routine dereferences req, it is set to NULL when the >> ep->queue is empty. If the eq->queue was ever empty this >> would have oops. >> >> So the else statement should not be needed. If it is, >> flag it as a BUG. >> >> Signed-off-by: Tom Rix > This patch really seems to be overkill. In particular, Linus Torvalds > feels very strongly that people should not add BUG or BUG_ON calls > except in extreme situations -- which this isn't. > >> --- >> drivers/usb/gadget/udc/net2272.c | 5 ++--- >> 1 file changed, 2 insertions(+), 3 deletions(-) >> >> diff --git a/drivers/usb/gadget/udc/net2272.c b/drivers/usb/gadget/udc/net2272.c >> index 44d1ea2307bb..8301723a8b1a 100644 >> --- a/drivers/usb/gadget/udc/net2272.c >> +++ b/drivers/usb/gadget/udc/net2272.c >> @@ -1506,17 +1506,16 @@ static int net2272_stop(struct usb_gadget *_gadget) >> static void >> net2272_handle_dma(struct net2272_ep *ep) >> { >> - struct net2272_request *req; >> + struct net2272_request *req = NULL; >> unsigned len; >> int status; >> >> if (!list_empty(&ep->queue)) >> req = list_entry(ep->queue.next, >> struct net2272_request, queue); >> - else >> - req = NULL; >> >> dev_vdbg(ep->dev->dev, "handle_dma %s req %p\n", ep->ep.name, req); >> + BUG_ON(!req); > There's no point in adding this. If the function goes on to dereference > a NULL pointer, you'll get the same effect in any case -- an oops. > > If you want to make the point that req had better not be NULL, just get > rid of the "if" test entirely. You could even change the list_entry to > list_first_entry. Since nothing is really going to change, drop this patch. Tom > Alan Stern >