Hi James, > A revised adt7461 patch addressing all of Jean's comments is > attached. > > This driver will detect the adt7461 chip only if boot firmware > has left the chip in its default lm90-compatible mode. I'm fine with the idea but not quite with your implementation: > @@ -221,6 +229,8 @@ > struct i2c_client *client = to_i2c_client(dev); \ > struct lm90_data *data = i2c_get_clientdata(client); \ > long val = simple_strtol(buf, NULL, 10); \ > + if ((data->kind == adt7461) && ((val < 0) || (val > 127000))) \ > + return -EINVAL; \ > data->value = TEMP1_TO_REG(val); \ > i2c_smbus_write_byte_data(client, reg, data->value); \ > return count; \ > @@ -232,6 +242,8 @@ > struct i2c_client *client = to_i2c_client(dev); \ > struct lm90_data *data = i2c_get_clientdata(client); \ > long val = simple_strtol(buf, NULL, 10); \ > + if ((data->kind == adt7461) && ((val < 0) || (val > 127000))) \ > + return -EINVAL; \ > data->value = TEMP2_TO_REG(val); \ > i2c_smbus_write_byte_data(client, regh, data->value >> 8); \ > i2c_smbus_write_byte_data(client, regl, data->value & 0xff); \ This is inconsistent with the rest of the interface. For continuous values, we do not return errors on out-of-range writes. Instead, we force the value to whatever range boundary makes sense. See TEMP1_TO_REG and TEMP2_TO_REG. So I would suggest that you implement TEMP1_TO_REG_ADT7461 and TEMP2_TO_REG_ADT7461 the same way with different boundaries, and call them. > + if (address == 0x4c > + && chip_id == 0x51 /* ADT7461 */ > + && (reg_config1 & 0x3F) == 0x00 That could be broaden to "& 0x1F" is I am not mistaken. We don't really care about bit 5, do we? And maybe put a comment explaining that we check for compatibility at this point (similar checks for the other chips are only for unused bits, not for specific configuration). Thanks, -- Jean Delvare