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

Reply via email to