re: max17042: Add POR init procedure from Maxim appnote

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




Hello Ramakrishna Pallala,

The patch f3a71a6eb13b: "max17042: Add POR init procedure from Maxim 
appnote" from Mar 13, 2012, leads to the following
static checker warning: "drivers/power/max17042_battery.c:339 
max17042_init_model()
	 warn: passing casted pointer 'temp_data' to 'max17042_model_data_compare()' 32 vs 16."

drivers/power/max17042_battery.c
   307  static inline int max17042_model_data_compare(struct max17042_chip *chip,
   308                                          u16 *data1, u16 *data2, int size)
   309  {
   310          int i;
   311  
   312          if (memcmp(data1, data2, size)) {
   313                  dev_err(&chip->client->dev, "%s compare failed\n", __func__);
   314                  for (i = 0; i < size; i++)
   315                          dev_info(&chip->client->dev, "0x%x, 0x%x",
   316                                  data1[i], data2[i]);
   317                  dev_info(&chip->client->dev, "\n");
   318                  return -EINVAL;
   319          }
   320          return 0;
   321  }
   322  
   323  static int max17042_init_model(struct max17042_chip *chip)
   324  {
   325          int ret;
   326          int table_size = ARRAY_SIZE(chip->pdata->config_data->cell_char_tbl);
   327          u32 *temp_data;
   328  
   329          temp_data = kcalloc(table_size, sizeof(*temp_data), GFP_KERNEL);
   330          if (!temp_data)
   331                  return -ENOMEM;
   332  
   333          max10742_unlock_model(chip);
   334          max17042_write_model_data(chip, MAX17042_MODELChrTbl,
   335                                  table_size);
   336          max17042_read_model_data(chip, MAX17042_MODELChrTbl, temp_data,
   337                                  table_size);
   338  
   339          ret = max17042_model_data_compare(
   340                  chip,
   341                  chip->pdata->config_data->cell_char_tbl,
   342                  (u16 *)temp_data,
   343                  table_size);

temp_data is a buffer of 32 bit numbers.

table_size is the number of 32 bit numbers in temp_data.

The max17042_model_data_compare() function is quite buggy because the
memcmp() assumes u8 and the for loop assumes u16.  Both can't be correct
and in fact both are wrong since we are passing the size in terms of
u32.

   344  
   345          max10742_lock_model(chip);
   346          kfree(temp_data);
   347  
   348          return ret;
   349  }

regards,
dan carpenter

--
To unsubscribe from this list: send the line "unsubscribe devicetree" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Device Tree Compilter]     [Device Tree Spec]     [Linux Driver Backports]     [Video for Linux]     [Linux USB Devel]     [Linux PCI Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [XFree86]     [Yosemite Backpacking]
  Powered by Linux