X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=bertos%2Fdrv%2Flm75.c;h=d1d0a257fc2f7e6b0b582ac44da716ffc0e0485e;hb=41718ab2098bd5640da265c34f1ecb79a4123d39;hp=5d24e0ae520224b348727e016982d0d1b7a2e64d;hpb=5c77344df12ac768e7b53e0085ad08de21513d2f;p=bertos.git diff --git a/bertos/drv/lm75.c b/bertos/drv/lm75.c index 5d24e0ae..d1d0a257 100644 --- a/bertos/drv/lm75.c +++ b/bertos/drv/lm75.c @@ -55,27 +55,35 @@ #include // Macro and data type to manage celsius degree #define SELECT_ADDRESS(addr) LM75_ADDRESS_BYTE | (addr << 1) +#define LM75_ADDRESS_BYTE 0x91 +#define LM75_PAD_BYTE 0x0 -deg_t lm75_read(uint8_t sens_addr) + +#if !CONFIG_I2C_DISABLE_OLD_API + +deg_t lm75_read_1(uint8_t sens_addr) +{ + return lm75_read_2(&local_i2c_old_api, sens_addr); +} +#endif /* !CONFIG_I2C_DISABLE_OLD_API */ + + +/* + * New API + */ +deg_t lm75_read_2(I2c *i2c, uint8_t sens_addr) { uint8_t data[2]; int16_t degree; int16_t deci_degree; - if( !(i2c_start_w(SELECT_ADDRESS(sens_addr)) - && i2c_put(LM75_PAD_BYTE) - && i2c_start_r(SELECT_ADDRESS(sens_addr))) ) - { - i2c_stop(); - return EOF; - } + i2c_start_w(i2c, SELECT_ADDRESS(sens_addr), 1, I2C_NOSTOP); + i2c_putc(i2c, LM75_PAD_BYTE); + i2c_start_r(i2c, SELECT_ADDRESS(sens_addr), sizeof(data), I2C_STOP); + i2c_read(i2c, data, sizeof(data)); - if ( !i2c_recv(data, sizeof(data)) ) - { - i2c_stop(); + if (i2c_error(i2c)) return EOF; - } - i2c_stop(); degree = (int16_t)data[0]; deci_degree = (int16_t)(((data[1] >> 7) & 1 ) * 5); @@ -84,12 +92,3 @@ deg_t lm75_read(uint8_t sens_addr) return degree * 10 + deci_degree; } - -void lm75_init(void) -{ - // Check dependence - MOD_CHECK(i2c); - LM75_HW_INIT(); -} - -