From mboxrd@z Thu Jan 1 00:00:00 1970 From: Lukas Wunner Subject: Re: [PATCH v2 00/13] Runtime PM for Thunderbolt on Macs Date: Wed, 20 Jul 2016 09:23:59 +0200 Message-ID: <20160720072359.GC8066@wunner.de> References: <20160707150243.GA3633@wunner.de> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Return-path: Content-Disposition: inline In-Reply-To: Sender: linux-pci-owner@vger.kernel.org To: "Rafael J. Wysocki" Cc: Linux PCI , Linux PM , Andreas Noever , Alan Stern , Huang Ying List-Id: linux-pm@vger.kernel.org On Fri, Jul 08, 2016 at 03:28:12AM +0200, Rafael J. Wysocki wrote: > On Thu, Jul 7, 2016 at 5:02 PM, Lukas Wunner wrote: > > (1) Would it be possible to allow dev_pm_domain_set() for already > > bound devices? (It would allow me to simplify this series > > considerably.) > > I don't think so, because setting a PM domain generally changes the > set of PM callbacks for the device and it may not be safe to call it > after the driver has been bound. That sounds more like a locking problem than anything else. If the system is awake and the device is active, it would seem safe to change its set of PM callbacks. Am I missing something? How about checking in dev_pm_domain_set() if pm_runtime_active(dev) and calling lock_system_sleep() / unlock_system_sleep() to ensure that? Thanks, Lukas