On Sun, Apr 14, 2019 at 07:37:35AM -0700, Guenter Roeck wrote:
>On 4/13/19 9:03 AM, Adamski, Krzysztof (Nokia - PL/Wroclaw) wrote:
>>Manufacturer specific SAMPLES_FOR_AVG register allows setting the number
>>of samples used in computing the average values (PMBUS_VIRT_READ_*_AVG).
>>The number we write is an exponent of base 2 of the number of samples so
>>for example writing 3 will result in 8 samples average.
>>
>>Signed-off-by: Krzysztof Adamski <[email protected]>
>>---
>> drivers/hwmon/pmbus/lm25066.c | 15 ++++++++++++++-
>> 1 file changed, 14 insertions(+), 1 deletion(-)
>>
>>diff --git a/drivers/hwmon/pmbus/lm25066.c b/drivers/hwmon/pmbus/lm25066.c
>>index 53db78753a0d..b560d33db459 100644
>>--- a/drivers/hwmon/pmbus/lm25066.c
>>+++ b/drivers/hwmon/pmbus/lm25066.c
>>@@ -26,6 +26,7 @@
>> #include <linux/err.h>
>> #include <linux/slab.h>
>> #include <linux/i2c.h>
>>+#include <linux/log2.h>
>> #include "pmbus.h"
>> enum chips { lm25056, lm25066, lm5064, lm5066, lm5066i };
>>@@ -39,12 +40,15 @@ enum chips { lm25056, lm25066, lm5064, lm5066, lm5066i };
>> #define LM25066_CLEAR_PIN_PEAK 0xd6
>> #define LM25066_DEVICE_SETUP 0xd9
>> #define LM25066_READ_AVG_VIN 0xdc
>>+#define LM25066_SAMPLES_FOR_AVG 0xdb
>> #define LM25066_READ_AVG_VOUT 0xdd
>> #define LM25066_READ_AVG_IIN 0xde
>> #define LM25066_READ_AVG_PIN 0xdf
>> #define LM25066_DEV_SETUP_CL BIT(4) /* Current limit */
>>+#define LM25066_SAMPLES_FOR_AVG_MAX 4096
>>+
>> /* LM25056 only */
>> #define LM25056_VAUX_OV_WARN_LIMIT 0xe3
>>@@ -284,6 +288,10 @@ static int lm25066_read_word_data(struct i2c_client
>>*client, int page, int reg)
>> case PMBUS_VIRT_RESET_PIN_HISTORY:
>> ret = 0;
>> break;
>>+ case PMBUS_VIRT_SAMPLES:
>>+ ret = pmbus_read_byte_data(client, 0, LM25066_SAMPLES_FOR_AVG);
>
> if (ret < 0)
> return ret;
>
Good point. However the convention for this switch is to break instead
of returning early. I would stick with that if you don't mind.
>>+ ret = 1 << ret;
>>+ break;
>> default:
>> ret = -ENODATA;
>> break;
>>@@ -398,6 +406,11 @@ static int lm25066_write_word_data(struct i2c_client
>>*client, int page, int reg,
>> case PMBUS_VIRT_RESET_PIN_HISTORY:
>> ret = pmbus_write_byte(client, 0, LM25066_CLEAR_PIN_PEAK);
>> break;
>>+ case PMBUS_VIRT_SAMPLES:
>>+ word = clamp_val(word, 0, LM25066_SAMPLES_FOR_AVG_MAX);
>
>0 is not valid, and ilog2(0) returns -1 (or is undefined).
True, I'll clamp with minimum 1 to fix that. I don't think it's worth
returning an error for 0. Do you?
>
>>+ ret = pmbus_write_byte_data(client, 0, LM25066_SAMPLES_FOR_AVG,
>>+ ilog2(word));
>>+ break;
>> default:
>> ret = -ENODATA;
>> break;
>>@@ -438,7 +451,7 @@ static int lm25066_probe(struct i2c_client *client,
>> info->func[0] = PMBUS_HAVE_VIN | PMBUS_HAVE_VMON
>> | PMBUS_HAVE_PIN | PMBUS_HAVE_IIN | PMBUS_HAVE_STATUS_INPUT
>>- | PMBUS_HAVE_TEMP | PMBUS_HAVE_STATUS_TEMP;
>>+ | PMBUS_HAVE_TEMP | PMBUS_HAVE_STATUS_TEMP | PMBUS_HAVE_SAMPLES;
>> if (data->id == lm25056) {
>> info->func[0] |= PMBUS_HAVE_STATUS_VMON;
>>
>
Krzysztof