On Thu, 19 Jun 2008 12:46:50 +0200 Jean Delvare <khali at linux-fr.org> wrote: > Hi Sean, > > +static SENSOR_DEVICE_ATTR(temp1_input, S_IRUGO, show_temp_input, > > NULL, 0); > > Note that you don't really need to use SENSOR_DEVICE_ATTR for this > one, as you make no use of the index value. No big deal either though. Agreed, but I thought it *looked* better if they all used SENSOR_DEVICE_ATTR than a mix of SENSOR_DEVICE and DEVICE. > > + /* Put the chip in the default power up state. */ > > + i2c_smbus_write_byte_data(client, AD7414_REG_CONF, 0x40); > > This is overwriting _all_ the bits of the configuration file, > including changes that could have been done by the the BIOS or > firmware or whatever. That's not OK! You must read the configuration > register value, check bit 2, and if it's set, write the value back > with just bit 2 cleared. I work with, what we call, "board drivers" too much. We always reset everything to a know state ;) We don't need to worry about bit 2. The chip always runs in continuous conversion mode unless it is powered down. The one shot just *forces* an immediate conversion rather than waiting 800ms. The one shot is really more useful in the powered down mode. All we have to guarantee is that the chip is powered up. Below is the new code: /* Make sure the chip is powered up. */ conf = i2c_smbus_read_byte_data(client, AD7414_REG_CONF); if (conf < 0) printk(KERN_WARNING "ad7414_probe unable to read config register.\n"); else { conf &= ~(1 << 7); i2c_smbus_write_byte_data(client, AD7414_REG_CONF, conf); } I do not fail the driver if the config read fails. The ad7414 is very important for our board and will always come up with the reset value. So the above code is really a NOP for us. I would hate to fail the driver due to an i2c bus glitch. If we can agree on the above patch, I can submit a patch with the code changes. I also added the AD7414_REG_LIMIT array and the round off change. Cheers, Sean