From: Quentin Schulz <quentin.schulz@cherry.de>
To: Guenter Roeck <linux@roeck-us.net>, linux-hwmon@vger.kernel.org
Cc: linux-kernel@vger.kernel.org, Farouk Bouabid <farouk.bouabid@cherry.de>
Subject: Re: [PATCH 09/10] hwmon: (amc6821) Convert to use regmap
Date: Mon, 1 Jul 2024 18:54:57 +0200 [thread overview]
Message-ID: <7a1f2916-3e2b-45ee-9681-7327d7b1798a@cherry.de> (raw)
In-Reply-To: <13b73e86-fed0-4ef0-9815-eda765f2a70c@roeck-us.net>
Hi Guenter,
On 7/1/24 3:47 PM, Guenter Roeck wrote:
> On 7/1/24 06:01, Quentin Schulz wrote:
>
>>> -#define AMC6821_CONF1_FDRC1 BIT(7)
>>> +#define AMC6821_CONF1_FDRC1 BIT(6)
>>
>> This should have been squashed with a previous commit.
>>
>
> Yes. I had found the bug but then fixed it in the wrong patch of the
> series.
>
> ...
>>> static ssize_t temp_show(struct device *dev, struct
>>> device_attribute *devattr,
>>> char *buf)
>>> {
>>> - struct amc6821_data *data = amc6821_update_device(dev);
>>> + struct amc6821_data *data = dev_get_drvdata(dev);
>>> int ix = to_sensor_dev_attr(devattr)->index;
>>> + u32 regval;
>>
>> Why not a u8 directly here? We know single reads are going to return a
>> u8 so no need to store more?
>>
>
> The parameter of regmap_read is a pointer to unsigned int.
>
Eventually through the many indirections, because our regmap_config sets
the size of values in registers to 8b, it's a u8. But it's not worth our
time to optimize this.
EDIT: coming back to this after reading the rest... Wouldn't we have a
possible endianness issue here? Especially with the int8_t cast or the
sign_extend32 (wouldn't the sign bit be at a different index on LE/BE
?). Sorry for the question, endianness really isn't my cup of tea.
>> I'm not too fluent in type conversion, but maybe even an s8 since this
>> is actually what's stored in the register?
>>
>>> + int err;
>>> - return sprintf(buf, "%d\n", data->temp[ix] * 1000);
>>> + err = regmap_read(data->regmap, temp_reg[ix], ®val);
>>> + if (err)
>>> + return err;
>>> +
>>> + return sysfs_emit(buf, "%d\n", (int8_t)regval * 1000);
>>
>> The type casting choice is odd here. Considering we'll be printing an
>> int and that 1000 cannot be stored in an int8_t, maybe just cast it to
>> an int directly?
>>
>
> This is a trick which actually originates from the original code, only
> there it is hidden in amc6821_update_device(). This is equivalent to
> sign_extend32(regval, 7) which is more expensive, so I decided to stick
> with it. On the other side, you are correct, it makes the code more
> difficult to understand. I'll change it to use sign_extend32().
>
Indeed, I completely missed the implications of having a "real" s8
stored in a u32, thanks for the explanation. It does make more sense to
use sign_extend32() indeed.
[...]
>>> @@ -603,58 +582,72 @@ static ssize_t pwm1_auto_point_pwm_store(struct
>>> device *dev,
>>> static ssize_t fan_show(struct device *dev, struct device_attribute
>>> *devattr,
>>> char *buf)
>>> {
>>> - struct amc6821_data *data = amc6821_update_device(dev);
>>> + struct amc6821_data *data = dev_get_drvdata(dev);
>>> int ix = to_sensor_dev_attr(devattr)->index;
>>> - if (0 == data->fan[ix])
>>> - return sprintf(buf, "6000000");
>>> - return sprintf(buf, "%d\n", (int)(6000000 / data->fan[ix]));
>>> + u32 regval;
>>> + u8 regs[2];
>>
>> Can't this be a u16 directly.......
>>
>>> + int err;
>>> +
>>> + err = regmap_bulk_read(data->regmap, fan_reg_low[ix], regs, 2);
>>> + if (err)
>>> + return err;
>>> + regval = (regs[1] << 8) | regs[0];
>>> +
>>
>>
>> ..... to avoid doing this here?
>>
>
> Then it would need an endianness conversion instead. That might save a
> couple
> of cycles, but I think it would make the code more difficult to read.
>
Ah dang it, I always forget Aarch64 (thus LE) is not the only
architecture that exists in the world :D Endianness conversion being my
nemesis, I wholeheartedly agree with you.
[...]
>>> static int amc6821_probe(struct i2c_client *client)
>>> {
>>> struct device *dev = &client->dev;
>>> struct amc6821_data *data;
>>> struct device *hwmon_dev;
>>> + struct regmap *regmap;
>>
>> Save this variable by using data->client directly?
>>
>
> Then I'd have to dereference it twice to check for error.
> In such situations I prefer to use a separate variable.
>
Fair enough. One's taste after all :)
Cheers,
Quentin
next prev parent reply other threads:[~2024-07-01 16:55 UTC|newest]
Thread overview: 37+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-06-28 15:13 [PATCH 00/10] hwmon: (amc6821) Various improvements Guenter Roeck
2024-06-28 15:13 ` [PATCH 01/10] hwmon: (amc6821) Stop accepting invalid pwm values Guenter Roeck
2024-07-01 10:19 ` Quentin Schulz
2024-07-01 13:50 ` Guenter Roeck
2024-06-28 15:13 ` [PATCH 02/10] hwmon: (amc6821) Make reading and writing fan speed limits consistent Guenter Roeck
2024-07-01 11:05 ` Quentin Schulz
2024-07-01 14:11 ` Guenter Roeck
2024-07-01 14:37 ` Guenter Roeck
2024-07-01 16:13 ` Quentin Schulz
2024-07-01 17:21 ` Guenter Roeck
2024-07-01 18:05 ` Quentin Schulz
2024-07-01 19:11 ` Guenter Roeck
2024-06-28 15:13 ` [PATCH 03/10] hwmon: (amc6821) Rename fan1_div to fan1_pulses Guenter Roeck
2024-07-01 11:08 ` Quentin Schulz
2024-06-28 15:13 ` [PATCH 04/10] hwmon: (amc6821) Add support for fan1_target and pwm1_enable mode 4 Guenter Roeck
2024-07-01 11:23 ` Quentin Schulz
2024-07-01 15:26 ` Guenter Roeck
2024-07-01 16:29 ` Quentin Schulz
2024-07-01 17:31 ` Guenter Roeck
2024-06-28 15:13 ` [PATCH 05/10] hwmon: (amc2821) Reorder include files, drop unnecessary ones Guenter Roeck
2024-07-01 11:24 ` Quentin Schulz
2024-06-28 15:13 ` [PATCH 06/10] hwmon: (amc6821) Use tabs for column alignment in defines Guenter Roeck
2024-07-01 11:26 ` Quentin Schulz
2024-06-28 15:13 ` [PATCH 07/10] hwmon: (amc2821) Use BIT() and GENMASK() Guenter Roeck
2024-07-01 11:31 ` Quentin Schulz
2024-07-01 14:44 ` Guenter Roeck
2024-06-28 15:13 ` [PATCH 08/10] hwmon: (amc6821) Drop unnecessary enum chips Guenter Roeck
2024-07-01 11:36 ` Quentin Schulz
2024-07-01 14:47 ` Guenter Roeck
2024-06-28 15:13 ` [PATCH 09/10] hwmon: (amc6821) Convert to use regmap Guenter Roeck
2024-07-01 13:01 ` Quentin Schulz
2024-07-01 13:47 ` Guenter Roeck
2024-07-01 16:54 ` Quentin Schulz [this message]
2024-07-01 17:30 ` Guenter Roeck
2024-06-28 15:13 ` [PATCH 10/10] hwmon: (amc6821) Convert to with_info API Guenter Roeck
2024-07-01 17:46 ` Quentin Schulz
2024-07-01 18:24 ` Guenter Roeck
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=7a1f2916-3e2b-45ee-9681-7327d7b1798a@cherry.de \
--to=quentin.schulz@cherry.de \
--cc=farouk.bouabid@cherry.de \
--cc=linux-hwmon@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux@roeck-us.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox