Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 8e99ada8 authored by Wolfram Sang's avatar Wolfram Sang Committed by Jean Delvare
Browse files

i2c-algo-pca: Rework waiting for a free bus



Waiting for a free bus now accepts the timeout value in jiffies and does
proper checking using time_before.

Signed-off-by: default avatarWolfram Sang <w.sang@pengutronix.de>
Signed-off-by: default avatarJean Delvare <khali@linux-fr.org>
parent eff9ec95
Loading
Loading
Loading
Loading
+1 −1
Original line number Diff line number Diff line
@@ -229,7 +229,7 @@ static struct resource i2c_resources[] = {
static struct i2c_pca9564_pf_platform_data i2c_platform_data = {
	.gpio			= 0,
	.i2c_clock_speed	= I2C_PCA_CON_330kHz,
	.timeout		= 100,
	.timeout		= HZ,
};

static struct platform_device i2c_device = {
+10 −7
Original line number Diff line number Diff line
@@ -22,6 +22,7 @@
#include <linux/module.h>
#include <linux/moduleparam.h>
#include <linux/delay.h>
#include <linux/jiffies.h>
#include <linux/init.h>
#include <linux/errno.h>
#include <linux/i2c.h>
@@ -186,15 +187,17 @@ static int pca_xfer(struct i2c_adapter *i2c_adap,
	int numbytes = 0;
	int state;
	int ret;
	int timeout = i2c_adap->timeout;
	unsigned long timeout = jiffies + i2c_adap->timeout;

	while ((state = pca_status(adap)) != 0xf8 && timeout--) {
	while (pca_status(adap) != 0xf8) {
		if (time_before(jiffies, timeout)) {
			msleep(10);
	}
	if (state != 0xf8) {
		dev_dbg(&i2c_adap->dev, "bus is not idle. status is %#04x\n", state);
		} else {
			dev_dbg(&i2c_adap->dev, "bus is not idle. status is "
				"%#04x\n", state);
			return -EAGAIN;
		}
	}

	DEB1("{{{ XFER %d messages\n", num);

+1 −1
Original line number Diff line number Diff line
@@ -104,7 +104,7 @@ static struct i2c_adapter pca_isa_ops = {
	.owner          = THIS_MODULE,
	.algo_data	= &pca_isa_data,
	.name		= "PCA9564/PCA9665 ISA Adapter",
	.timeout	= 100,
	.timeout	= HZ,
};

static int __devinit pca_isa_match(struct device *dev, unsigned int id)
+1 −1
Original line number Diff line number Diff line
@@ -6,7 +6,7 @@ struct i2c_pca9564_pf_platform_data {
				 * not supplied (negative value), but it
				 * cannot exit some error conditions then */
	int i2c_clock_speed;	/* values are defined in linux/i2c-algo-pca.h */
	int timeout;		/* timeout = this value * 10us */
	int timeout;		/* timeout in jiffies */
};

#endif /* I2C_PCA9564_PLATFORM_H */