Received: by 2002:ac0:a581:0:0:0:0:0 with SMTP id m1-v6csp635757imm; Wed, 4 Jul 2018 03:24:27 -0700 (PDT) X-Google-Smtp-Source: AAOMgpfRHz85pdkpkW6Ren1+T4VSBj8ekODwONVRkT59lLL3go7HZ4MW92LXSxqu/4wxdlNT1ZLm X-Received: by 2002:a65:4b87:: with SMTP id t7-v6mr1343858pgq.391.1530699867087; Wed, 04 Jul 2018 03:24:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1530699867; cv=none; d=google.com; s=arc-20160816; b=OrmDZaY7wDWwTtXzrHoTWl+xG+qTTboumVYs0GFZssL4kEnqUKUfVYbyxeNaEKW1ar e/BdgcPZq31f7FcufmSharK/vGMPoOGrYrVpvCY483BUdhuL4St+nT2F3RUETS6sZoza rubTaTm5pu3kQUGtPGYMrXl/I4qNdC043ZbxxiKcaMu3rpOchJU/ciccWMju6bjoC+aL +abZBBQrC3zCT5gS9wLK4P3oTEUoMObUjUP5MAu4MXUrk3inxGeZ/eJnSEgtcXtTn1g/ vFcg8D17qXIqNvKdqlWgxoOCVFPSSz1w/FwzP5Ekpju+DXS7OX6VnWs1svrbWjCUJ3G4 q8WQ== 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 :arc-authentication-results; bh=UDU69Ryw3M9z6qV6W5/QLTPRTyjDhLoNeiBo3twv4Do=; b=z8KtAH46HvfpR4azSmgB1deOhtiXJO2cSHrcdUCk7Ww65tJ1RL6ZiS+zxiJxG5KCsw 14M58/iLWkiD3VNJULzMQnGP4neNvxUxak991ALNqilOj75iYo9KC/7TA0GNzZcVJcgQ ITz0tPzHyEa+3em1sMsdSyTagU4oj8jwm/qZgMuekGSbMUbW5iJQmBgKExf8NNAaf0O4 7wijfSrHGFmgaK7BAQM7XEU8dEgIPtkCN73KkNXJewc31RksB7DG56EjF2F+36lAe3Km fOqbJih5DVtKnnvOhFu7Z7f+XzSVsBtRePkTihpbAid6MHSUa3VLbqUT0islx60bs4y7 voZA== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id n11-v6si2342941plk.225.2018.07.04.03.24.12; Wed, 04 Jul 2018 03:24:27 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S934117AbeGDKXU (ORCPT + 99 others); Wed, 4 Jul 2018 06:23:20 -0400 Received: from cloudserver094114.home.pl ([79.96.170.134]:63120 "EHLO cloudserver094114.home.pl" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932538AbeGDKXS (ORCPT ); Wed, 4 Jul 2018 06:23:18 -0400 Received: from 79.184.254.38.ipv4.supernova.orange.pl (79.184.254.38) (HELO aspire.rjw.lan) by serwer1319399.home.pl (79.96.170.134) with SMTP (IdeaSmtpServer 0.83) id 44b6ab2906fb0cc6; Wed, 4 Jul 2018 12:23:16 +0200 From: "Rafael J. Wysocki" To: Pingfan Liu Cc: linux-kernel@vger.kernel.org, Greg Kroah-Hartman , Grygorii Strashko , Christoph Hellwig , Bjorn Helgaas , Dave Young , linux-pci@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, Linux PM Subject: Re: [PATCHv3 0/4] drivers/base: bugfix for supplier<-consumer ordering in device_kset Date: Wed, 04 Jul 2018 12:21:52 +0200 Message-ID: <6281446.GoJLz6Hq6C@aspire.rjw.lan> In-Reply-To: References: <1530600642-25090-1-git-send-email-kernelfans@gmail.com> <4685360.VNmeYLh0dQ@aspire.rjw.lan> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="us-ascii" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wednesday, July 4, 2018 4:47:07 AM CEST Pingfan Liu wrote: > On Tue, Jul 3, 2018 at 10:36 PM Rafael J. Wysocki wrote: > > > > On Tuesday, July 3, 2018 8:50:38 AM CEST Pingfan Liu wrote: > > > commit 52cdbdd49853 ("driver core: correct device's shutdown order") > > > places an assumption of supplier<-consumer order on the process of probe. > > > But it turns out to break down the parent <- child order in some scene. > > > E.g in pci, a bridge is enabled by pci core, and behind it, the devices > > > have been probed. Then comes the bridge's module, which enables extra > > > feature(such as hotplug) on this bridge. > > > > So what *exactly* does happen in that case? > > > I saw the shpc_probe() is called on the bridge, although the probing > failed on that bare-metal. But if it success, then it will enable the > hotplug feature on the bridge. I don't understand what you are saying here, sorry. device_reorder_to_tail() walks the entire device hierarchy below the target and moves all of the children in there *after* their parents. How can it break "the parent <- child order" then? Thanks, Rafael