From: Bartosz Golaszewski Date: Tue, 27 Oct 2015 16:15:03 +0000 (+0100) Subject: i2cdump: use I2C block mode for the 'i' mode parameter X-Git-Tag: 1_25_0~163 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=1fe75b8ef10933d047f7ab6060d4710a39611e92;p=oweals%2Fbusybox.git i2cdump: use I2C block mode for the 'i' mode parameter Currently we're calling i2c_smbus_read_block_data() for both 'i' and 's' mode parameters. If the bus doesn't support SMBus block mode, then the i2c access ioctl() fails. Make i2cdump behave compatibly with upstream version by calling i2c_smbus_read_i2c_block_data() for I2C block. Signed-off-by: Bartosz Golaszewski Signed-off-by: Denys Vlasenko --- diff --git a/miscutils/i2c_tools.c b/miscutils/i2c_tools.c index 094bf9e38..6d221e9fc 100644 --- a/miscutils/i2c_tools.c +++ b/miscutils/i2c_tools.c @@ -723,7 +723,7 @@ static int read_block_data(int buf_fd, int mode, int *block) uint8_t cblock[I2C_SMBUS_BLOCK_MAX + I2CDUMP_NUM_REGS]; int res, blen = 0, tmp, i; - if (mode == I2C_SMBUS_BLOCK_DATA || mode == I2C_SMBUS_I2C_BLOCK_DATA) { + if (mode == I2C_SMBUS_BLOCK_DATA) { res = i2c_smbus_read_block_data(buf_fd, 0, cblock); blen = res; } else {