Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp3199625imm; Sun, 29 Jul 2018 12:40:12 -0700 (PDT) X-Google-Smtp-Source: AAOMgpduI2ecn3U+oEn7OF2ZsFoqTZI6ZzZS5aFC02qZBdg2ovGdrM4x+lnrmVzRvHDZe5+Unx3D X-Received: by 2002:a17:902:1703:: with SMTP id i3-v6mr13555129pli.263.1532893212474; Sun, 29 Jul 2018 12:40:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1532893212; cv=none; d=google.com; s=arc-20160816; b=anP+2DDs0C8/nvLw5G8QnKRIW3bJO/De+pDRno/exabk3VcqYP8IGoYOYMUCdsSCsN mL3pgNdQ8yPjQvZgqdtrNjmcUiVkimmXGQuzAHptXQ6rElePv0JF7Sxcm/prEwVdfDA2 FVnbrAmVsXRTb3FS6LbmV9msFQyn/nHsfubbGzgIzsGbokXV2QH1aih9s2T+I1ethQWH aLbTub1loHIMGvALkgv6gKjN7w7+lYS10t0zUStPwswGJwU/i9kTwJAJD+ZoDeW8BvD0 xTsAY9u9gSMBIlqR1xDY3SezKV8ryWkljfJu2Uk+l10vyHVaEuQYgnWBIncVcF0FCTc0 lAVw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature:arc-authentication-results; bh=vVj1a9aoqq+jMPjxXfqU1FR7aZDkjTxC3929c002Pbk=; b=HBDAAleZJvIjqdQUhB7WfUqu6lu05KxTORi/BPzp9mbt1emnke14Ds641W43zhSxWg JqQcvQe2qe/8aDdP83vW3YA0c26DJbzZKAhfmkizi4Lg2UgFn/eEQIcA2mfwD7vk9FH/ +x9cWm622RFAu/vsAxwSdBXMip+qyj+7fuILXOyhVV0CLHHL5fTrG6ySnTEfRDEFRqlN QV/TZ4HJ52RyES+b3y1bylfI7UnkQ9Ol8y5pGSn9lPdlzzJfIeWWgO92ZCNzj5Dm79TH gvLp8OyctV0T/1fJT4ixskGNJrwywA7Dxo6AGLPKbDjAla0fjsqI+LXxVgBDWULQ7V2B KMtw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=KZrreNgk; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e6-v6si9726864pfe.31.2018.07.29.12.39.58; Sun, 29 Jul 2018 12:40:12 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=KZrreNgk; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728882AbeG2VIc (ORCPT + 99 others); Sun, 29 Jul 2018 17:08:32 -0400 Received: from mail-pg1-f194.google.com ([209.85.215.194]:43810 "EHLO mail-pg1-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726586AbeG2VIa (ORCPT ); Sun, 29 Jul 2018 17:08:30 -0400 Received: by mail-pg1-f194.google.com with SMTP id d17-v6so1592334pgv.10 for ; Sun, 29 Jul 2018 12:36:59 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=vVj1a9aoqq+jMPjxXfqU1FR7aZDkjTxC3929c002Pbk=; b=KZrreNgkXBUaMTxlX21CIqhjNL9lPT4QS+j9M8qLm4MUgjXTwkJZksm+bEZZzDdfYL 03TH+2+Sa101QgfJfVFSkEWIW/FIbm8zUvlnZCB1vctYltWhCy36YD+mfq5o+/kEBtkm fPatbbHSfGuAgNwGVgxCqw6R+5KKouYV62d+sNBMem5T3TbiwkV8r6bv8XemHW2FN906 cQSRu78gSssgzEjR+vPm9TOKnE1PSLBR92a2/xHWdgvLgmCoaLP7d9SI6AHYsvRhScLL gVN6J0r/Ydg+tS1FJhNY4+0DvgfSWqWFkGSFAvBkbotL9nOxkPVVaEMJbprUUaqqlv2G 7lMA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=vVj1a9aoqq+jMPjxXfqU1FR7aZDkjTxC3929c002Pbk=; b=EsuU7hCfKwibJYJRIpWjH49szgC8sKy2BkSPFtLrp2txghwYNAFHMVsUHfDhlAiJnL 0gWQm/zxxkTfGv8RRdDy5h8xo0mro8U9ZPEl7TNyM5Kk1DgSV9+fzAxrHYPlaYIxKXPx hV8OWUX/vtIe3MKE3n4QcNAOEKzPEHK6ik80rAbVX6gxD3qfqiKgrzsscNtjwmvs/hcn Tfolc/OZbF0PkIs5u/TKr241TtEHwU4WfiH2xF/rU1PELS/FZ/U13ixTYRmrI6qYmjOY m5geI3DBFJVCTiB55PATbrR8q98z6EJiC1ccS6uDngRzs22UwrW5EjK+AqgWI91TSF3l gQmQ== X-Gm-Message-State: AOUpUlF3yKZuiWVDoBONTmX63VHkGwobr86L7nt/hf1bvdP7+mRttarC oTVrVLmq3ODi6MhL67cDm0M= X-Received: by 2002:a65:6398:: with SMTP id h24-v6mr13719096pgv.245.1532893019150; Sun, 29 Jul 2018 12:36:59 -0700 (PDT) Received: from toddpoynor2.mtv.corp.google.com ([2620:0:1000:3701:7d29:cd13:d903:7908]) by smtp.gmail.com with ESMTPSA id k26-v6sm27474062pfb.167.2018.07.29.12.36.58 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Sun, 29 Jul 2018 12:36:58 -0700 (PDT) From: Todd Poynor To: Rob Springer , John Joseph , Ben Chan , Greg Kroah-Hartman Cc: devel@driverdev.osuosl.org, linux-kernel@vger.kernel.org, Dmitry Torokhov , Todd Poynor Subject: [PATCH 01/13] staging: gasket: core: hold reference to pci_dev while used Date: Sun, 29 Jul 2018 12:36:34 -0700 Message-Id: <20180729193646.201721-2-toddpoynor@gmail.com> X-Mailer: git-send-email 2.18.0.345.g5c9ce644c3-goog In-Reply-To: <20180729193646.201721-1-toddpoynor@gmail.com> References: <20180729193646.201721-1-toddpoynor@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Todd Poynor Hold a reference on the struct pci_dev while a pointer to it is held in the gasket data structures. Signed-off-by: Todd Poynor --- drivers/staging/gasket/gasket_core.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/drivers/staging/gasket/gasket_core.c b/drivers/staging/gasket/gasket_core.c index 2b484d067c38a..b832a4f529f27 100644 --- a/drivers/staging/gasket/gasket_core.c +++ b/drivers/staging/gasket/gasket_core.c @@ -488,6 +488,7 @@ static void gasket_free_dev(struct gasket_dev *gasket_dev) internal_desc->devs[gasket_dev->dev_idx] = NULL; mutex_unlock(&internal_desc->mutex); put_device(gasket_dev->dev); + pci_dev_put(gasket_dev->pci_dev); kfree(gasket_dev); } @@ -565,6 +566,7 @@ static int gasket_pci_probe( ret = gasket_alloc_dev(internal_desc, parent, &gasket_dev, kobj_name); if (ret) return ret; + gasket_dev->pci_dev = pci_dev_get(pci_dev); if (IS_ERR_OR_NULL(gasket_dev->dev_info.device)) { pr_err("Cannot create %s device %s [ret = %ld]\n", driver_desc->name, gasket_dev->dev_info.name, @@ -572,7 +574,6 @@ static int gasket_pci_probe( ret = -ENODEV; goto fail1; } - gasket_dev->pci_dev = pci_dev; ret = gasket_setup_pci(pci_dev, gasket_dev); if (ret) @@ -703,7 +704,6 @@ static int gasket_setup_pci( { int i, mapped_bars, ret; - gasket_dev->pci_dev = pci_dev; ret = pci_enable_device(pci_dev); if (ret) { dev_err(gasket_dev->dev, "cannot enable PCI device\n"); -- 2.18.0.345.g5c9ce644c3-goog