[Skiboot] [PATCH 4/4] hwmon: (ibmpowernv) pretty print labels
Cedric Le Goater
clg at fr.ibm.com
Wed Apr 8 00:42:12 AEST 2015
On 04/03/2015 05:49 PM, Guenter Roeck wrote:
> On 04/01/2015 03:15 AM, Cédric Le Goater wrote:
>> The new OPAL device tree adds a few properties which can be used to add
>> extra information on the sensor label.
>>
>> Signed-off-by: Cédric Le Goater <clg at fr.ibm.com>
>> ---
>> drivers/hwmon/ibmpowernv.c | 22 ++++++++++++++++++++++
>> 1 file changed, 22 insertions(+)
>>
>> diff --git a/drivers/hwmon/ibmpowernv.c b/drivers/hwmon/ibmpowernv.c
>> index be6fe559b52a..3e753c215b40 100644
>> --- a/drivers/hwmon/ibmpowernv.c
>> +++ b/drivers/hwmon/ibmpowernv.c
>> @@ -113,9 +113,31 @@ static ssize_t show_label(struct device *dev, struct device_attribute *devattr,
>> static void __init make_sensor_label(struct device_node *np,
>> struct sensor_data *sdata, const char *label)
>> {
>> + u32 id;
>> size_t n;
>>
>> n = snprintf(sdata->label, sizeof(sdata->label), "%s", label);
>> +
>> + /*
>> + * Core temp pretty print
>> + */
>> + if (!of_property_read_u32(np, "ibm,pir", &id)) {
>> + int i;
>> +
>> + for_each_possible_cpu(i)
>> + if (paca[i].hw_cpu_id == id)
>> + break;
>> +
>> + n += snprintf(sdata->label + n, sizeof(sdata->label) - n,
>> + " %d-%d", i, i+7);
>
> If ibm,pir points to a bad/invalid CPU id you just print an invalid value.
> Is that what you want ?
Certainly not :) I am being over optimistic on the underlying layer.
> Also, what relevance does 'i' have for the user ?
> It is the index into the paca array, sure, but what is its relevance
> outside this code, especially in the context of you printing both i and i+7 ?
It gives a hint on the localization of the core in the system, which
can be useful when developing custom heat sinks. The translation
from physical to linux cpu id is here to be consistent with the user
layer. The physical id is rarely used at that level.
I will send a v2 for this patch.
Thanks,
C.
>
> Guenter
>
>> + }
>> +
>> + /*
>> + * Membuffer pretty print
>> + */
>> + if (!of_property_read_u32(np, "ibm,chip-id", &id))
>> + n += snprintf(sdata->label + n, sizeof(sdata->label) - n,
>> + " %d", id & 0xffff);
>> }
>>
>> static int get_sensor_index_attr(const char *name, u32 *index,
>>
>
More information about the Skiboot
mailing list