[<prev] [next>] [day] [month] [year] [list]
Message-ID: <5670BBA8.5040900@intel.com>
Date: Wed, 16 Dec 2015 02:17:28 +0100
From: "Rafael J. Wysocki" <rafael.j.wysocki@...el.com>
To: Philip Elcan <pelcan@...eaurora.org>,
"Rafael J. Wysocki" <rjw@...ysocki.net>,
Adrian Hunter <adrian.hunter@...el.com>
Cc: Ulf Hansson <ulf.hansson@...aro.org>, linux-mmc@...r.kernel.org,
linux-kernel@...r.kernel.org,
"linux-acpi@...r.kernel.org" <linux-acpi@...r.kernel.org>,
linux-arm-msm@...r.kernel.org, Timur Tabi <timur@...eaurora.org>,
Jon Masters <jcm@...hat.org>,
Mark Langsdorf <mlangsdo@...hat.com>, harba@...eaurora.org
Subject: Re: [PATCH] mmc: sdhci-acpi: set non-removable in ACPI table
On 12/15/2015 10:36 PM, Philip Elcan wrote:
> On 12/11/2015 05:53 PM, Rafael J. Wysocki wrote:
>> On Friday, December 11, 2015 10:17:18 AM Adrian Hunter wrote:
>>> On 10/12/15 22:57, Philip Elcan wrote:
>>>> On 12/07/2015 03:30 AM, Adrian Hunter wrote:
>>>>> On 04/12/15 17:40, Philip Elcan wrote:
>>>>>> On 12/03/2015 09:14 AM, Adrian Hunter wrote:
>>>>>>> On 03/12/15 15:48, Philip Elcan wrote:
>>>>>>>> This allows setting an SDHC controller as non-removable
>>>>>>>> by using the _RMV method in the ACPI table. It doesn't
>>>>>>> Is that _RMV on the host controller? Shouldn't it be on the card i.e. child
>>>>>>> device node?
>>>>>> Yes, this is on the host controller. The ACPI table only describes the
>>>>>> host controller, not the child nodes.
>>>>>>
>>>>> If you look at Intel devices, the _RMV is on the child e.g.
>>>>>
>>>>> Device (SDHA)
>>>>> {
>>>>> Name (_HID, "80860F14") // _HID: Hardware ID
>>>>> Name (_CID, "PNP0D40") // _CID: Compatible ID
>>>>> Name (_DDN, "Intel(R) eMMC Controller - 80860F14") // _DDN: DOS Device Name
>>>>> ...
>>>>> Device (EMMD)
>>>>> {
>>>>> ...
>>>>> Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
>>>>> {
>>>>> Return (Zero)
>>>>> }
>>>>> }
>>>>> }
>>>>>
>>>>> I am not an ACPI expert but that seems like the correct place for it.
>>>> My understanding is that in ACPI you don't generally create child devices on buses that are discoverable.
>>> I've cc'ed Rafael and the linux-acpi mailing list. Maybe someone there can
>>> comment.
>> The context here is a bit unclear to me.
>>
>> Quite frankly, I don't see now _RMV above is useful for anything. As per the
>> spec, _RMV is only necessary for devices that *can* be removed from the system
>> and where there's no eject mechanism controlled by software. For those
>> devices _RMV is intended to indicate that it is safe to remove the device
>> at the time _RMV is evaluated. Devices that can never be removed don't
>> need _RMV at all.
>>
>> Thanks,
>> Rafael
>>
> Maybe I'm misinterpreting something, but the spec says that "_RMV object indicates
> to OSPM whether the device can be removed while the system is in the working state
> and does not require any ACPI system firmware actions to be performed for the device
> to be safely removed from the system." That sounds exactly like what I'm trying to
> do. And from Adrian's example, it sounds like others are using this to indicate if
> a devices is removeable.
It also says "Any such removable device that does not have _LCK or _EJx
control methods must have and _RMV object."
Which clearly implies that _RMV is not required for devices that cannot
be removed at all. Indeed, it is redundant in those cases as stated above.
> However, if I follow your paradigm, I can just test if the _RMV object exists, and if
> it doesn't, I can assume the device is not removable?
That's correct as far as I can say.
> I'm concerned not all firmware will have this object implemented.
That's correct too.
It only is intended for devices that may be removed in a
surprise-removal fashion and it is rarely used in general.
> Is there something else you suggest I use in the ACPI table to designate an SD/MMC
> device is removable?
If you want to say "this device is removable", then there should be
either _LCK/_EJx or _RMV object present for it. The latter indicates
that the device can be removed at any time in principle, but it is only
safe to remove it if/when 1 is returned by _RMV. That is, the OS can't
prevent the user from removing the device, but it can indicate to the
user (this way or another) when it is safe to remove it. The decision
whether or not to do that is still up to the user.
Thanks,
Rafael
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists