Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp1414570pxv; Sat, 10 Jul 2021 03:40:39 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx6955LthmhN/2fMjXLQkTJ0uS2xVXe38pYsiXQHMJ0V7mItfOPNHpS/7zDo8iqAiYLMDbC X-Received: by 2002:a17:906:c142:: with SMTP id dp2mr42701155ejc.355.1625913639581; Sat, 10 Jul 2021 03:40:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1625913639; cv=none; d=google.com; s=arc-20160816; b=oBZdrFp2dzWu3wLwMW0kO5jZhKZPxavlyKeQ6qsfTxt8/VU5/7rSOCo7lwfLhh+g6P NW+c9lOEeaQyDrgg/MEtj6l7RMmFOoRD9XqnG/qmCXFA5Ru096Vt97MvLGKVEZUT7vXs 5NMnTs2Wyqn5VC0un1BidJjlDy1gNzFICp3SJJffurRcWIY8q5zr/hz92QnGIzvYNO66 U/bQOE6y86grdGOlCdnuv1e/ZOExgliFO1Ccm1c/Uyr9CNwbKxhaX4gdCcwcfln5bAOm zq6GN/2japs+juuyKWeEDNFf/8G8VuOCwgHacG+4q78x7y8rwKaxXhjb4lnS+cYc6uvT QINg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:organization:references:in-reply-to:message-id :date:subject:cc:to:from; bh=fY+ww6fR2sCFKzm91JIUSmuJGMYX6smwdVTfMealed8=; b=o9Meur9Mrsb7Auvrf9N5ZZv9V3KY6wG14OGSINOQYy0aAA7ijaDwgITofX2KxLaERF YFE+rIuBIjnVQBTWELreQ+NnYKUKckHG3og1bz6W5Lsecp3ndxOEnrjYQcJe5ThBpz/L JZhzOGoDzFIU2Lk/KFPQP2LCssVDtjMoEAAoA/24fmgcGGrrT4gMPB6hmbkT/XdfRS5k SIYmeYNZDNNUzLirVUPva1ri08PAFo/yEiZbAZdDPdtm6KAppRCX04QwwI7NHsV9JM67 35zolmYCA4XgUEx9CpdKY67dZ4Qvs/MNdjWThAe4GURrfpMVw3Vqf44MiLQCLnniWZTJ /uKw== 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=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ds7si13097016ejc.692.2021.07.10.03.40.16; Sat, 10 Jul 2021 03:40: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; 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=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232693AbhGJKlD (ORCPT + 99 others); Sat, 10 Jul 2021 06:41:03 -0400 Received: from mga14.intel.com ([192.55.52.115]:34009 "EHLO mga14.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232387AbhGJKlC (ORCPT ); Sat, 10 Jul 2021 06:41:02 -0400 X-IronPort-AV: E=McAfee;i="6200,9189,10040"; a="209638437" X-IronPort-AV: E=Sophos;i="5.84,229,1620716400"; d="scan'208";a="209638437" Received: from orsmga002.jf.intel.com ([10.7.209.21]) by fmsmga103.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 10 Jul 2021 03:38:18 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.84,229,1620716400"; d="scan'208";a="429090442" Received: from ahunter-desktop.fi.intel.com ([10.237.72.79]) by orsmga002.jf.intel.com with ESMTP; 10 Jul 2021 03:38:14 -0700 From: Adrian Hunter To: "Rafael J . Wysocki" Cc: Greg Kroah-Hartman , Saravana Kannan , "Martin K . Petersen" , "James E . J . Bottomley" , linux-scsi@vger.kernel.org, Avri Altman , Bean Huo , Can Guo , Asutosh Das , Bart Van Assche , linux-pm@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH V3 2/3] driver core: Add ability to delete device links of unregistered devices Date: Sat, 10 Jul 2021 13:38:18 +0300 Message-Id: <20210710103819.12532-3-adrian.hunter@intel.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20210710103819.12532-1-adrian.hunter@intel.com> References: <20210710103819.12532-1-adrian.hunter@intel.com> Organization: Intel Finland Oy, Registered Address: PL 281, 00181 Helsinki, Business Identity Code: 0357606 - 4, Domiciled in Helsinki Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Managed device links are deleted by device_del(). However it is possible to add a device link to a consumer before device_add(), and then discover an error prevents the device from being used. In that case normally references to the device would be dropped and the device would be deleted. However the device link holds a reference to the device, so the device link and device remain indefinitely (unless the supplier is deleted). Amend device link removal to accept removal of a link with an unregistered consumer device. Suggested-by: Rafael J. Wysocki Fixes: b294ff3e34490 ("scsi: ufs: core: Enable power management for wlun") Signed-off-by: Adrian Hunter --- drivers/base/core.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/drivers/base/core.c b/drivers/base/core.c index 2de8f7d8cf54..983e895d4ced 100644 --- a/drivers/base/core.c +++ b/drivers/base/core.c @@ -887,6 +887,8 @@ static void device_link_put_kref(struct device_link *link) { if (link->flags & DL_FLAG_STATELESS) kref_put(&link->kref, __device_link_del); + else if (!device_is_registered(link->consumer)) + __device_link_del(&link->kref); else WARN(1, "Unable to drop a managed device link reference\n"); } -- 2.17.1