Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp1629240imm; Tue, 10 Jul 2018 05:23:54 -0700 (PDT) X-Google-Smtp-Source: AAOMgpdVYWynznovUKWrwzP00z0TBGPNfBq8H5DCuNLMH8HfNF7eX+d7J6C/vWM29UnYK/Ivc+wj X-Received: by 2002:a17:902:8a87:: with SMTP id p7-v6mr24234379plo.281.1531225434918; Tue, 10 Jul 2018 05:23:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531225434; cv=none; d=google.com; s=arc-20160816; b=GXdCSy83I4jQrQdf6wOPRvVZXsC3k1fvBQmJFmsg6jSf9bJhvyGJF0lb3ki2H8OaxR ISqj91AkBaBXIgXh4DyzSV8rNvQiLXXHkQF4I1Wy7YHKL1XK9iXmcDSp3KRKA4EsNRRV diweSXIkLLc9b71flBs6gWbYSHO+AwmPnzAN5HseXdNCtX834mY4AxiK301tWcgwAM+d Ayh8lJiE/lcsQNZYEaMm8/S9BRhck7nB9C2mUIFRY1AN3Ysio2b1j3Mq2wzmixt0c8ii MElR9zIA/mpGXd+/B5NjWTV/g7LNAGVV+0PzWG0Y1/4Pg6/UtLHVDk2eGt1Cc93uKRJM Ywyw== 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:in-reply-to :mime-version:user-agent:date:message-id:from:cc:references:to :subject:dkim-signature:arc-authentication-results; bh=uJ507R84Xt3W5o9Pkyn0fon8FDpGq97Xuu6z1pb6AjY=; b=L+fWo6Vc9jnIVi5f5nB1s0vIeQXdYlREM1RqxxzzM/fy2pdb1zQhD4xURnkYXWYUgT SbWvi3LGR0SkWDKuurdltykH/fftkTB+eQ/1IQe8KCryEIzljv+yFz9nuNczaWzgj4DX h326yNsSOrbymlzc15B1lUPHW4LvAOCyrZZf+GkgZlAH8Tqr4hQnb93H7oidCwx6BbrW MEBSh2DtHAHSnfnyYEF+mWmghfrcBXd1AGZyQK4CMN/K9VpeyaLs82PSFP6v/4FX00NS 8G2TsyBbtseOhgFO4/eRHK6IUPSxinx+S67fLCTmmSeECdXtYPsYnP5XyyGyTwCbpXV2 j3Tg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=RC8F4LKw; 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=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f21-v6si15729447pgl.235.2018.07.10.05.23.39; Tue, 10 Jul 2018 05:23:54 -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=@ti.com header.s=ti-com-17Q1 header.b=RC8F4LKw; 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=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933283AbeGJMW6 (ORCPT + 99 others); Tue, 10 Jul 2018 08:22:58 -0400 Received: from lelv0142.ext.ti.com ([198.47.23.249]:49308 "EHLO lelv0142.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753275AbeGJMW5 (ORCPT ); Tue, 10 Jul 2018 08:22:57 -0400 Received: from dflxv15.itg.ti.com ([128.247.5.124]) by lelv0142.ext.ti.com (8.15.2/8.15.2) with ESMTP id w6ACMWZD122173; Tue, 10 Jul 2018 07:22:32 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1531225353; bh=uJ507R84Xt3W5o9Pkyn0fon8FDpGq97Xuu6z1pb6AjY=; h=Subject:To:References:CC:From:Date:In-Reply-To; b=RC8F4LKwdPWJJsGX/G9gd0lXuCDqf3sQ6BF3QuKiYRWDqXMhJMSEOA00XPh8gnCi7 XOvWvjl33MctvBVcTRcqwj4oBwGpzsVWUWbXPtufRpg9GNW1zVVSYWgk05ZekEkmQP Fa4CFyoUuslgr4TEvQUirmi6LJdyJCk7DHBeVJKw= Received: from DFLE108.ent.ti.com (dfle108.ent.ti.com [10.64.6.29]) by dflxv15.itg.ti.com (8.14.3/8.13.8) with ESMTP id w6ACMWvE015851; Tue, 10 Jul 2018 07:22:32 -0500 Received: from DFLE115.ent.ti.com (10.64.6.36) by DFLE108.ent.ti.com (10.64.6.29) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1466.3; Tue, 10 Jul 2018 07:22:32 -0500 Received: from dlep32.itg.ti.com (157.170.170.100) by DFLE115.ent.ti.com (10.64.6.36) with Microsoft SMTP Server (version=TLS1_0, cipher=TLS_RSA_WITH_AES_256_CBC_SHA) id 15.1.1466.3 via Frontend Transport; Tue, 10 Jul 2018 07:22:32 -0500 Received: from [172.24.190.233] (ileax41-snat.itg.ti.com [10.172.224.153]) by dlep32.itg.ti.com (8.14.3/8.13.8) with ESMTP id w6ACMS2i022797; Tue, 10 Jul 2018 07:22:29 -0500 Subject: Re: [PATCH] driver core: Partially revert "driver core: correct device's shutdown order" To: "Rafael J. Wysocki" , Greg Kroah-Hartman References: <1530600642-25090-1-git-send-email-kernelfans@gmail.com> <8816662.k3KXbdkA2e@aspire.rjw.lan> <2927655.Y1qg3UnIrE@aspire.rjw.lan> CC: Pingfan Liu , , Grygorii Strashko , Christoph Hellwig , Bjorn Helgaas , Dave Young , , Lukas Wunner , Linux PM From: Kishon Vijay Abraham I Message-ID: Date: Tue, 10 Jul 2018 17:52:28 +0530 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:45.0) Gecko/20100101 Thunderbird/45.8.0 MIME-Version: 1.0 In-Reply-To: <2927655.Y1qg3UnIrE@aspire.rjw.lan> Content-Type: text/plain; charset="windows-1252" Content-Transfer-Encoding: 7bit X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, On Tuesday 10 July 2018 05:05 PM, Rafael J. Wysocki wrote: > From: Rafael J. Wysocki > > Commit 52cdbdd49853 (driver core: correct device's shutdown order) > introduced a regression by breaking device shutdown on some systems. > > Namely, the devices_kset_move_last() call in really_probe() added by > that commit is a mistake as it may cause parents to follow children > in the devices_kset list which then causes shutdown to fail. For > example, if a device has children before really_probe() is called > for it (which is not uncommon), that call will cause it to be > reordered after the children in the devices_kset list and the > ordering of that list will not reflect the correct device shutdown > order any more. > > Also it causes the devices_kset list to be constantly reordered > until all drivers have been probed which is totally pointless > overhead in the majority of cases and it only covers an issue > with system shutdown, while system-wide suspend/resume potentially > has the same issue on the affected platforms (which is not covered). > > For that reason, revert the really_probe() modifications made by > commit 52cdbdd49853 which unfortunately will expose the shutdown > issue the problematic commit attempted to fix (and which will have > to be addressed differently and correctly in the future). > > The other code changes made by commit 52cdbdd49853 are useful and > they need not be reverted. > > Fixes: 52cdbdd49853 (driver core: correct device's shutdown order) > Link: https://lore.kernel.org/lkml/CAFgQCTt7VfqM=UyCnvNFxrSw8Z6cUtAi3HUwR4_xPAc03SgHjQ@mail.gmail.com/ > Reported-by: Pingfan Liu > Tested-by: Pingfan Liu > Signed-off-by: Rafael J. Wysocki > --- This issue because of which 52cdbdd49853 (driver core: correct device's shutdown order) was added is not present from 4.18, since dra7 started using sdhci-omap.c driver which doesn't disable regulator during shutdown. (The original issue was present in omap_hsmmc driver). When sdhci-omap driver is modified to disable regulator during shutdown, something like device_link_add() can be added in _regulator_get(). Since this doesn't reintroduce the problem that was solved by 52cdbdd49853, this can be safely merged. Reviewed-by: Kishon Vijay Abraham I Thanks Kishon