From mboxrd@z Thu Jan 1 00:00:00 1970 From: "Lu, Aaron" Subject: Re: [PATCH v2] ACPI: D3 states cleanup Date: Sat, 21 Apr 2012 01:36:36 +0000 Message-ID: References: <1334884749.4927.6.camel@minggr> <1334900255.4927.36.camel@minggr> <20120420074725.GA30140@localhost.amd.com>,<201204201312.54949.rjw@sisk.pl> Mime-Version: 1.0 Content-Type: text/plain; charset="gb2312" Content-Transfer-Encoding: base64 Return-path: Received: from am1ehsobe001.messaging.microsoft.com ([213.199.154.204]:42810 "EHLO am1outboundpool.messaging.microsoft.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751261Ab2DUBhG (ORCPT ); Fri, 20 Apr 2012 21:37:06 -0400 In-Reply-To: <201204201312.54949.rjw@sisk.pl> Content-Language: zh-CN Sender: linux-acpi-owner@vger.kernel.org List-Id: linux-acpi@vger.kernel.org To: "Rafael J. Wysocki" Cc: Lin Ming , Len Brown , linux-acpi , "linux-kernel@vger.kernel.org" , Zhang Rui , "Huang, Ying" DQrU2iAyMDEyLTQtMjCjrM/Czuc3OjA4o6wiUmFmYWVsIEouIFd5c29ja2kiIDxyandAc2lzay5w bD4g0LS1wKO6DQoNCj4gT24gRnJpZGF5LCBBcHJpbCAyMCwgMjAxMiwgQWFyb24gTHUgd3JvdGU6 DQo+PiBIaSwNCj4+IA0KPj4gT24gRnJpLCBBcHIgMjAsIDIwMTIgYXQgMDE6Mzc6MzVQTSArMDgw MCwgTGluIE1pbmcgd3JvdGU6DQo+Pj4+Pj4+IFRoZXJlIGFyZSB0d28gQUNQSSBEMyBzdGF0ZXMg ZGVmaW5lZCBub3c6DQo+Pj4+Pj4+IEFDUElfU1RBVEVfRDMgYW5kIEFDUElfU1RBVEVfRDNfQ09M RC4NCj4+Pj4+Pj4gDQo+Pj4+Pj4+IEJ1dCB0aGUgdXNlcyBvZiB0aGVzZSBzdGF0ZXMgYXJlIG5v dCBjbGVhci9jb3JyZWN0IGluIHNvbWUgY29kZS4NCj4+Pj4+Pj4gRm9yIGV4YW1wbGUsIHNvbWUg Y29kZSByZWZlciBBQ1BJX1NUQVRFX0QzIGFzIEQzaG90IGFuZCBvdGhlcnMgcmVmZXINCj4+Pj4+ Pj4gaXQgYXMgRDNjb2xkLg0KPj4+Pj4+PiANCj4+Pj4+Pj4gVGhpcyBwYXRjaCBpbnRyb2R1Y2Vz IEFDUElfU1RBVEVfRDNfSE9UIHRvIHJlZmVyIHRvIEFDUEkgRDNob3Qgc3RhdGUuDQo+Pj4+Pj4+ IEFuZCBjaGFuZ2VzIEFDUElfU1RBVEVfRDMgdG8gcmVmZXIgdG8gQUNQSSBEM2NvbGQgc3RhdGUg b25seS4NCj4+Pj4+Pj4gQWxzbyByZWRlZmluZXMgQUNQSV9TVEFURV9EM19DT0xEIHRoZSBzYW1l IGFzIEFDUElfU1RBVEVfRDMuDQo+Pj4+Pj4+IA0KPj4+Pj4+IA0KPj4+Pj4+IFdpdGggdGhpcyBw YXRjaCBub3csIGlmIGEgZGV2aWNlIGhhcyBfUFMzLCB0aGVuIHdlIHdpbGwgc2V0IGl0cyBEM2hv dA0KPj4+Pj4+IGZsYWcgdmFsaWQuIFRoaXMgZG9lc24ndCBmZWVsIHJpZ2h0IHRvIG1lLCBzaW5j ZSBwZXIgb3VyIGRpc2N1c3Npb24gdGhlDQo+Pj4+Pj4gb3RoZXIgZGF5LCB3ZSBzaG91bGQgYXNz dW1lIF9QUzMgd2lsbCBwdXQgdGhlIGRldmljZSBpbnRvIEQzY29sZC4NCj4+Pj4+PiANCj4+Pj4+ PiBPciBkbyB5b3UgbWVhbjogaWYgX1BTMyBpcyBhdmFpbGFibGUsIHRoZW4gYm90aCBEM2hvdCBh bmQgRDNjb2xkIGlzDQo+Pj4+Pj4gdmFsaWQgZnJvbSB0aGUgcGVyc3BlY3RpdmUgb2YgYWNwaSwg aXQgaXMgdGhlIGluZGl2aWR1YWwgZHJpdmVyJ3MNCj4+Pj4+PiByZXNwb25zaWJpbGl0eSB0byBk ZWNpZGUgd2hpY2ggc3RhdGUgaXMgYWN0dWFsbHkgdmFsaWQgYW5kIHdpbGwgYmUgdXNlZC4NCj4+ Pj4+IA0KPj4+Pj4gUmlnaHQuDQo+Pj4+PiANCj4+Pj4+IEFDUElfU1RBVEVfRDMoc2FtZSBhcyBB Q1BJX1NUQVRFX0QzX0NPTEQgbm93KSBpcyBhbHdheXMgdmFsaWQuDQo+Pj4+PiANCj4+Pj4gDQo+ Pj4+IEkgbWVhbiwgaWYgX1BTMyBpcyBhdmFpbGFibGUsIGNhbiB3ZSBzYXkgRDNob3QgaXMgdmFs aWQ/DQo+Pj4gDQo+Pj4gWWVzLg0KPj4+IA0KPj4gDQo+PiBPSywgbm93IEknbSBjb25mdXNlZC4u Lg0KPj4gDQo+PiBGaXJzdCwgbGV0IG1lIHRyeSB0byBjbGFyaWZ5IHRoZSBtZWFuaW5nIG9mIGFj cGkgcG93ZXIgc3RhdGUncyB2YWxpZA0KPj4gZmxhZy4NCj4+IA0KPj4gQnkgdmFsaWQsIEkgc3Vw cG9zZSBpdCBtZWFucyB0aGUgZGV2aWNlIGNhbiBiZSBpbiB0aGF0IHN0YXRlLCBpbnN0ZWFkIG9m DQo+PiB3ZSBoYXZlIGEgd2F5IHRvIHByb2dyYW0gdGhpcyBkZXZpY2UgdG8gZ28gaW50byB0aGF0 IHN0YXRlLg0KPj4gDQo+PiBlLmcuIEQwIGlzIHZhbGlkIG1lYW5zIHRoZSBkZXZpY2UgY2FuIGJl IGluIEQwIHN0YXRlLCBhbmQgRDNfY29sZCBpcw0KPj4gdmFsaWQgbWVhbnMgdGhlIGRldmljZSBj YW4gYmUgaW4gRDNfY29sZCBzdGF0ZS4gV2UgdW5jb25kaXRpb25hbGx5IHNldA0KPj4gdGhlc2Ug dHdvIHN0YXRlcyBhcyB2YWxpZCwgYmVjYXVzZSB3ZSBrbm93IGV2ZXJ5IGRldmljZSBzdXBwb3J0 cyB0aGVzZQ0KPj4gdHdvIHN0YXRlcy4gQnV0IHdlIG1pZ2h0IG5vdCBiZSBhYmxlIHRvIHB1dCB0 aGUgZGV2aWNlIGludG8gdGhhdCBzdGF0ZQ0KPj4gaW4gc29mdHdhcmUsIHNpbmNlIHdlIG1pZ2h0 IG5vdCBoYXZlIF9QUzAgb3IgX1BTMyBjb250cm9sIG1ldGhvZHMgZm9yIGl0Lg0KPj4gDQo+PiBB bmQgaWYgd2UgZG8gaGF2ZSB0aGUgX1BTeCBvciBfUFJ4IGNvbnRyb2wgbWV0aG9kcywgd2Uga25v d3Mgd2UgaGF2ZSBhDQo+PiB3YXkgdG8gcHV0IHRoZSBkZXZpY2UgaW50byB0aGF0IHN0YXRlLCBh bmQgaGVuY2UgdGhlIGRldmljZSBzaG91bGQgYmUNCj4+IGFibGUgdG8gc3VwcG9ydCB0aGF0IHBv d2VyIHN0YXRlLCBzbyB3ZSB3aWxsIHNldCB0aGF0IHN0YXRlIGFzIHZhbGlkIHRvby4NCj4+IA0K Pj4gSXMgdGhpcyBjb3JyZWN0Pw0KPj4gDQo+PiBGb3IgRDNob3QsIG9idmlvdXNseSBub3QgYWxs IGRldmljZSBzdXBwb3J0cyB0aGlzIHN0YXRlLCBzbyB3ZSB3aWxsIG5lZWQNCj4+IHRvIGZpZ3Vy ZSBpdCBvdXQgdGhyb3VnaCB0aGUgYWNwaSB0YWJsZS4NCj4+IEkgcmVtZW1iZXJlZCBSYWZhZWwg c2FpZCB0aGUgZm9sbG93aW5nIHdvcmRzIHRoZSBvdGhlciBkYXkgaW4gYSByZXBseSB0bw0KPj4g bXkgZXZhbHVhdGVfcHMzX3doZW5fZW50ZXJpbmdfZDNfY29sZF9wYXRjaDoNCj4+IA0KPj4gLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0NCj4+IEknZCByYXRoZXIgc2F5IHRoYXQgd2l0aCBfUFIzIHdlIGhhdmUgdGhl IG9wcG9ydHVuaXR5IHRvIGF2b2lkIHJlbW92aW5nDQo+PiBwb3dlciBjb21wbGV0ZWx5IGZyb20g dGhlIGRldmljZS4gIEluIG90aGVyIHdvcmRzLCBEM19ob3QgaXMgc3VwcG9ydGVkIChhbmQNCj4+ IGl0IGlzIHN1cHBvcnRlZCBfb25seV8gaW4gdGhhdCBjYXNlKS4NCj4+IC0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t DQo+PiANCj4+IFNvIEkgdGhpbmsgaGVyZSBpcyBhIHByb2JsZW0sIHRoYXQgaWYgYSBkZXZpY2Ug aGFzIG9ubHkgX1BTMywgd2h5IHNob3VsZA0KPj4gd2Ugc2F5IEQzaG90IGlzIHN1cHBvcnRlZD8g SXMgdGhlcmUgYSByZWFzb24gZm9yIHRoaXMgdGhhdCBJIG1pc3NlZD8NCj4gDQo+IE9LLCBJIGFn cmVlLiAgV2UgbmVlZCB0byBzcGVjaWFsIGNhc2UgdGhlIHNpdHVhdGlvbiBpbiB3aGljaCBfUFIz IGlzIG5vdA0KPiBwcmVzZW50LCBidXQgX1BTMyBpcy4gIElPVywgd2Ugc2hvdWxkIGRvIHNvbWV0 aGluZyBsaWtlIHRoaXMgaW4gdGhlIGxvb3AgaW4NCj4gYWNwaV9idXNfZ2V0X3Bvd2VyX2ZsYWdz KCk6DQo+IA0KPiANCj4gICAgICAgIC8qIFN0YXRlIGlzIHZhbGlkIGlmIHdlIGhhdmUgc29tZSBw b3dlciBjb250cm9sICovDQo+ICAgICAgICBpZiAocHMtPnJlc291cmNlcy5jb3VudA0KPiAgICAg ICAgICAgIHx8IChwcy0+ZmxhZ3MuZXhwbGljaXRfc2V0ICYmIGkgPCBBQ1BJX1NUQVRFX0QzKSkN Cj4gICAgICAgICAgICBwcy0+ZmxhZ3MudmFsaWQgPSAxOw0KPiANCg0KTG9va3MgZ29vZCB0byBt ZSwgdGhhbmtzLg0KDQotQWFyb24NCg0K From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751986Ab2DUBhJ (ORCPT ); Fri, 20 Apr 2012 21:37:09 -0400 Received: from am1ehsobe001.messaging.microsoft.com ([213.199.154.204]:42810 "EHLO am1outboundpool.messaging.microsoft.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751261Ab2DUBhG (ORCPT ); Fri, 20 Apr 2012 21:37:06 -0400 X-SpamScore: -12 X-BigFish: VPS-12(zzc89bh936eK1432N98dKzz1202hzzz2dh668h839h941hd25h) X-Forefront-Antispam-Report: CIP:163.181.249.109;KIP:(null);UIP:(null);IPV:NLI;H:ausb3twp02.amd.com;RD:none;EFVD:NLI X-WSS-ID: 0M2T353-02-12F-02 X-M-MSG: From: "Lu, Aaron" To: "Rafael J. Wysocki" CC: Lin Ming , Len Brown , linux-acpi , "linux-kernel@vger.kernel.org" , Zhang Rui , "Huang, Ying" Subject: Re: [PATCH v2] ACPI: D3 states cleanup Thread-Topic: [PATCH v2] ACPI: D3 states cleanup Thread-Index: AQHNHpOrWF7Jlsxu+k2twS9uk1hIcJai++GA//+Jk4CAAKizgP//ffaAgACqbID//7NDAAAu7bmX Date: Sat, 21 Apr 2012 01:36:36 +0000 Message-ID: References: <1334884749.4927.6.camel@minggr> <1334900255.4927.36.camel@minggr> <20120420074725.GA30140@localhost.amd.com>,<201204201312.54949.rjw@sisk.pl> In-Reply-To: <201204201312.54949.rjw@sisk.pl> Accept-Language: zh-CN, en-US Content-Language: zh-CN X-MS-Has-Attach: X-MS-TNEF-Correlator: Content-Type: text/plain; charset="gb2312" MIME-Version: 1.0 X-OriginatorOrg: amd.com Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Transfer-Encoding: 8bit X-MIME-Autoconverted: from base64 to 8bit by nfs id q3L1cGOi007981 2012-4-207:08"Rafael J. Wysocki" д > On Friday, April 20, 2012, Aaron Lu wrote: >> Hi, >> >> On Fri, Apr 20, 2012 at 01:37:35PM +0800, Lin Ming wrote: >>>>>>> There are two ACPI D3 states defined now: >>>>>>> ACPI_STATE_D3 and ACPI_STATE_D3_COLD. >>>>>>> >>>>>>> But the uses of these states are not clear/correct in some code. >>>>>>> For example, some code refer ACPI_STATE_D3 as D3hot and others refer >>>>>>> it as D3cold. >>>>>>> >>>>>>> This patch introduces ACPI_STATE_D3_HOT to refer to ACPI D3hot state. >>>>>>> And changes ACPI_STATE_D3 to refer to ACPI D3cold state only. >>>>>>> Also redefines ACPI_STATE_D3_COLD the same as ACPI_STATE_D3. >>>>>>> >>>>>> >>>>>> With this patch now, if a device has _PS3, then we will set its D3hot >>>>>> flag valid. This doesn't feel right to me, since per our discussion the >>>>>> other day, we should assume _PS3 will put the device into D3cold. >>>>>> >>>>>> Or do you mean: if _PS3 is available, then both D3hot and D3cold is >>>>>> valid from the perspective of acpi, it is the individual driver's >>>>>> responsibility to decide which state is actually valid and will be used. >>>>> >>>>> Right. >>>>> >>>>> ACPI_STATE_D3(same as ACPI_STATE_D3_COLD now) is always valid. >>>>> >>>> >>>> I mean, if _PS3 is available, can we say D3hot is valid? >>> >>> Yes. >>> >> >> OK, now I'm confused... >> >> First, let me try to clarify the meaning of acpi power state's valid >> flag. >> >> By valid, I suppose it means the device can be in that state, instead of >> we have a way to program this device to go into that state. >> >> e.g. D0 is valid means the device can be in D0 state, and D3_cold is >> valid means the device can be in D3_cold state. We unconditionally set >> these two states as valid, because we know every device supports these >> two states. But we might not be able to put the device into that state >> in software, since we might not have _PS0 or _PS3 control methods for it. >> >> And if we do have the _PSx or _PRx control methods, we knows we have a >> way to put the device into that state, and hence the device should be >> able to support that power state, so we will set that state as valid too. >> >> Is this correct? >> >> For D3hot, obviously not all device supports this state, so we will need >> to figure it out through the acpi table. >> I remembered Rafael said the following words the other day in a reply to >> my evaluate_ps3_when_entering_d3_cold_patch: >> >> ----------------------------------------------------------------------- >> I'd rather say that with _PR3 we have the opportunity to avoid removing >> power completely from the device. In other words, D3_hot is supported (and >> it is supported _only_ in that case). >> ----------------------------------------------------------------------- >> >> So I think here is a problem, that if a device has only _PS3, why should >> we say D3hot is supported? Is there a reason for this that I missed? > > OK, I agree. We need to special case the situation in which _PR3 is not > present, but _PS3 is. IOW, we should do something like this in the loop in > acpi_bus_get_power_flags(): > > > /* State is valid if we have some power control */ > if (ps->resources.count > || (ps->flags.explicit_set && i < ACPI_STATE_D3)) > ps->flags.valid = 1; > Looks good to me, thanks. -Aaron {.n++%ݶw{.n+{G{ayʇڙ,jfhz_(階ݢj"mG?&~iOzv^m ?I