diff options
| author | Michal Marek <mmarek@suse.cz> | 2011-06-08 16:01:34 +0200 | 
|---|---|---|
| committer | Michal Marek <mmarek@suse.cz> | 2011-06-08 16:01:34 +0200 | 
| commit | a61944c251c3e68c4bbf6eb96ff61c7b286351c5 (patch) | |
| tree | fd9f82297805d043a45a828626dfd29bddc48b00 /drivers/i2c/algos/i2c-algo-bit.c | |
| parent | ac9a126571e76abec76e1c1f46672e82501eab1e (diff) | |
| parent | 55922c9d1b84b89cb946c777fddccb3247e7df2c (diff) | |
Merge commit 'v3.0-rc1' into kbuild/kconfig
Diffstat (limited to 'drivers/i2c/algos/i2c-algo-bit.c')
| -rw-r--r-- | drivers/i2c/algos/i2c-algo-bit.c | 22 | 
1 files changed, 19 insertions, 3 deletions
| diff --git a/drivers/i2c/algos/i2c-algo-bit.c b/drivers/i2c/algos/i2c-algo-bit.c index 38319a69bd0..d6d58684712 100644 --- a/drivers/i2c/algos/i2c-algo-bit.c +++ b/drivers/i2c/algos/i2c-algo-bit.c @@ -232,9 +232,17 @@ static int i2c_inb(struct i2c_adapter *i2c_adap)   * Sanity check for the adapter hardware - check the reaction of   * the bus lines only if it seems to be idle.   */ -static int test_bus(struct i2c_algo_bit_data *adap, char *name) +static int test_bus(struct i2c_adapter *i2c_adap)  { -	int scl, sda; +	struct i2c_algo_bit_data *adap = i2c_adap->algo_data; +	const char *name = i2c_adap->name; +	int scl, sda, ret; + +	if (adap->pre_xfer) { +		ret = adap->pre_xfer(i2c_adap); +		if (ret < 0) +			return -ENODEV; +	}  	if (adap->getscl == NULL)  		pr_info("%s: Testing SDA only, SCL is not readable\n", name); @@ -297,11 +305,19 @@ static int test_bus(struct i2c_algo_bit_data *adap, char *name)  		       "while pulling SCL high!\n", name);  		goto bailout;  	} + +	if (adap->post_xfer) +		adap->post_xfer(i2c_adap); +  	pr_info("%s: Test OK\n", name);  	return 0;  bailout:  	sdahi(adap);  	sclhi(adap); + +	if (adap->post_xfer) +		adap->post_xfer(i2c_adap); +  	return -ENODEV;  } @@ -607,7 +623,7 @@ static int __i2c_bit_add_bus(struct i2c_adapter *adap,  	int ret;  	if (bit_test) { -		ret = test_bus(bit_adap, adap->name); +		ret = test_bus(adap);  		if (ret < 0)  			return -ENODEV;  	} | 
