aboutsummaryrefslogtreecommitdiffstats
path: root/sound/i2c/i2c.c
diff options
context:
space:
mode:
Diffstat (limited to 'sound/i2c/i2c.c')
-rw-r--r--sound/i2c/i2c.c18
1 files changed, 12 insertions, 6 deletions
diff --git a/sound/i2c/i2c.c b/sound/i2c/i2c.c
index 5c0c77dd01c3..eb7c7d05a7c1 100644
--- a/sound/i2c/i2c.c
+++ b/sound/i2c/i2c.c
@@ -98,7 +98,8 @@ int snd_i2c_bus_create(struct snd_card *card, const char *name,
98 bus->master = master; 98 bus->master = master;
99 } 99 }
100 strlcpy(bus->name, name, sizeof(bus->name)); 100 strlcpy(bus->name, name, sizeof(bus->name));
101 if ((err = snd_device_new(card, SNDRV_DEV_BUS, bus, &ops)) < 0) { 101 err = snd_device_new(card, SNDRV_DEV_BUS, bus, &ops);
102 if (err < 0) {
102 snd_i2c_bus_free(bus); 103 snd_i2c_bus_free(bus);
103 return err; 104 return err;
104 } 105 }
@@ -246,7 +247,8 @@ static int snd_i2c_bit_sendbyte(struct snd_i2c_bus *bus, unsigned char data)
246 247
247 for (i = 7; i >= 0; i--) 248 for (i = 7; i >= 0; i--)
248 snd_i2c_bit_send(bus, !!(data & (1 << i))); 249 snd_i2c_bit_send(bus, !!(data & (1 << i)));
249 if ((err = snd_i2c_bit_ack(bus)) < 0) 250 err = snd_i2c_bit_ack(bus);
251 if (err < 0)
250 return err; 252 return err;
251 return 0; 253 return 0;
252} 254}
@@ -278,12 +280,14 @@ static int snd_i2c_bit_sendbytes(struct snd_i2c_device *device,
278 if (device->flags & SND_I2C_DEVICE_ADDRTEN) 280 if (device->flags & SND_I2C_DEVICE_ADDRTEN)
279 return -EIO; /* not yet implemented */ 281 return -EIO; /* not yet implemented */
280 snd_i2c_bit_start(bus); 282 snd_i2c_bit_start(bus);
281 if ((err = snd_i2c_bit_sendbyte(bus, device->addr << 1)) < 0) { 283 err = snd_i2c_bit_sendbyte(bus, device->addr << 1);
284 if (err < 0) {
282 snd_i2c_bit_hw_stop(bus); 285 snd_i2c_bit_hw_stop(bus);
283 return err; 286 return err;
284 } 287 }
285 while (count-- > 0) { 288 while (count-- > 0) {
286 if ((err = snd_i2c_bit_sendbyte(bus, *bytes++)) < 0) { 289 err = snd_i2c_bit_sendbyte(bus, *bytes++);
290 if (err < 0) {
287 snd_i2c_bit_hw_stop(bus); 291 snd_i2c_bit_hw_stop(bus);
288 return err; 292 return err;
289 } 293 }
@@ -302,12 +306,14 @@ static int snd_i2c_bit_readbytes(struct snd_i2c_device *device,
302 if (device->flags & SND_I2C_DEVICE_ADDRTEN) 306 if (device->flags & SND_I2C_DEVICE_ADDRTEN)
303 return -EIO; /* not yet implemented */ 307 return -EIO; /* not yet implemented */
304 snd_i2c_bit_start(bus); 308 snd_i2c_bit_start(bus);
305 if ((err = snd_i2c_bit_sendbyte(bus, (device->addr << 1) | 1)) < 0) { 309 err = snd_i2c_bit_sendbyte(bus, (device->addr << 1) | 1);
310 if (err < 0) {
306 snd_i2c_bit_hw_stop(bus); 311 snd_i2c_bit_hw_stop(bus);
307 return err; 312 return err;
308 } 313 }
309 while (count-- > 0) { 314 while (count-- > 0) {
310 if ((err = snd_i2c_bit_readbyte(bus, count == 0)) < 0) { 315 err = snd_i2c_bit_readbyte(bus, count == 0);
316 if (err < 0) {
311 snd_i2c_bit_hw_stop(bus); 317 snd_i2c_bit_hw_stop(bus);
312 return err; 318 return err;
313 } 319 }