Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp1373327pxk; Fri, 2 Oct 2020 08:03:57 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzEONuhw6tF37LZEJTDUEEQcwuIqExDsaW+J1tfM7MPfR3acOXBd74M7hyxdIYlejOitDZ+ X-Received: by 2002:aa7:c7d7:: with SMTP id o23mr2727354eds.44.1601651037638; Fri, 02 Oct 2020 08:03:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601651037; cv=none; d=google.com; s=arc-20160816; b=ILUYwRmqeMVofiKU/gs3v3gDn74Gp/z7iu8ngxJxXKTolzn0kyC9zetFcHP9Ct5zND S85NJgKzAmDtuuG5dSb4Yn94fneNuQWAALSkogWa8K4mwiBj6mrbciKvGAItYwqZSGOm EkZsKDpkJWsif2+qrmObyRd4ZHZyk4AbyFdm9jO7UmkDV3GuxV1lt5LTiJXZ0HdPVQOm kF6ILS26QznUSTos9Pd8MHSHQ96TXJcvCRyHvrT+jVBUKX/oQoTpzzTHGCoMTPeo4swZ M88tA+CVbLS1wumsf+5sInRA43Gy5fdT9j4c4dWaXeD1l8t1JZXmUFIjYOu2AItU0BvK eOoQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:date:subject:cc:to:from; bh=5AoZuHU2h1/9VP3BIzk83339kL7kHVuRhvc6KkAP9mY=; b=BoRHbnVap5UuxwdppI85LbFx2IGxSYG0oZr4Xfb7E/UgngcNejSO4BIK5/8wnwiNNu d6UYET9u8Uk1YnAvxIKUdIe2Fjuh37ia0mqLapSZokkW+oHCV7kvyshBApQ8SCs+5v1X jfOPPKi2T9SwP2wDwNRXnEhMNnL465McDXEjNeIcCA0/Chq2QRhZCic2Vo5X+QsczdqO c8QNsZ4dCK786TsWmclgDpaJCfyK8uhOqDxqb7/dyl8XxzvtqHMRF6yOEjG6yVB3iPQK o5uPFt77zOmbTOwDdsNvsxHZSE8YzU/wUMONjPgZoLiW78YMW9extJTqYj0ebxPVswxZ J1og== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=ispras.ru Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id k1si1260310ejh.478.2020.10.02.08.03.31; Fri, 02 Oct 2020 08:03:57 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=ispras.ru Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388176AbgJBPCH (ORCPT + 99 others); Fri, 2 Oct 2020 11:02:07 -0400 Received: from mail.ispras.ru ([83.149.199.84]:48358 "EHLO mail.ispras.ru" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388091AbgJBPCH (ORCPT ); Fri, 2 Oct 2020 11:02:07 -0400 Received: from hellwig.intra.ispras.ru (unknown [10.10.2.182]) by mail.ispras.ru (Postfix) with ESMTPS id 2649D40A1DAC; Fri, 2 Oct 2020 15:02:05 +0000 (UTC) From: Evgeny Novikov To: Felipe Balbi Cc: Evgeny Novikov , Greg Kroah-Hartman , Arnd Bergmann , "Gustavo A. R. Silva" , Corentin Labbe , linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, ldv-project@linuxtesting.org Subject: [PATCH] usb: gadget: goku_udc: fix potential crashes in probe Date: Fri, 2 Oct 2020 18:01:55 +0300 Message-Id: <20201002150155.7560-1-novikov@ispras.ru> X-Mailer: git-send-email 2.16.4 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org goku_probe() goes to error label "err" and invokes goku_remove() in case of failures of pci_enable_device(), pci_resource_start() and ioremap(). goku_remove() gets a device from pci_get_drvdata(pdev) and works with it without any checks, in particular it dereferences a corresponding pointer. But goku_probe() did not set this device yet. So, one can expect various crashes. The patch moves setting the device just after allocation of memory for it. Found by Linux Driver Verification project (linuxtesting.org). Reported-by: Pavel Andrianov Signed-off-by: Evgeny Novikov --- drivers/usb/gadget/udc/goku_udc.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/usb/gadget/udc/goku_udc.c b/drivers/usb/gadget/udc/goku_udc.c index 25c1d6ab5adb..3e1267d38774 100644 --- a/drivers/usb/gadget/udc/goku_udc.c +++ b/drivers/usb/gadget/udc/goku_udc.c @@ -1760,6 +1760,7 @@ static int goku_probe(struct pci_dev *pdev, const struct pci_device_id *id) goto err; } + pci_set_drvdata(pdev, dev); spin_lock_init(&dev->lock); dev->pdev = pdev; dev->gadget.ops = &goku_ops; @@ -1793,7 +1794,6 @@ static int goku_probe(struct pci_dev *pdev, const struct pci_device_id *id) } dev->regs = (struct goku_udc_regs __iomem *) base; - pci_set_drvdata(pdev, dev); INFO(dev, "%s\n", driver_desc); INFO(dev, "version: " DRIVER_VERSION " %s\n", dmastr()); INFO(dev, "irq %d, pci mem %p\n", pdev->irq, base); -- 2.26.2