i2c: algo: pca: Fix mode selection for PCA9665
The code currently always selects turbo mode for PCA9665, no matter which clock frequency is configured. This is because it compares the clock frequency against constants reflecting (boundary / 100). Compare against real boundary frequencies to fix the problem. Signed-off-by: Thomas Kavanagh <tkavanagh@juniper.net> Signed-off-by: Guenter Roeck <groeck@juniper.net> Signed-off-by: Wolfram Sang <w.sang@pengutronix.de>
This commit is contained in:
parent
4a5b2b269e
commit
5f71a3ef37
|
@ -476,17 +476,17 @@ static int pca_init(struct i2c_adapter *adap)
|
||||||
/* To avoid integer overflow, use clock/100 for calculations */
|
/* To avoid integer overflow, use clock/100 for calculations */
|
||||||
clock = pca_clock(pca_data) / 100;
|
clock = pca_clock(pca_data) / 100;
|
||||||
|
|
||||||
if (pca_data->i2c_clock > 10000) {
|
if (pca_data->i2c_clock > 1000000) {
|
||||||
mode = I2C_PCA_MODE_TURBO;
|
mode = I2C_PCA_MODE_TURBO;
|
||||||
min_tlow = 14;
|
min_tlow = 14;
|
||||||
min_thi = 5;
|
min_thi = 5;
|
||||||
raise_fall_time = 22; /* Raise 11e-8s, Fall 11e-8s */
|
raise_fall_time = 22; /* Raise 11e-8s, Fall 11e-8s */
|
||||||
} else if (pca_data->i2c_clock > 4000) {
|
} else if (pca_data->i2c_clock > 400000) {
|
||||||
mode = I2C_PCA_MODE_FASTP;
|
mode = I2C_PCA_MODE_FASTP;
|
||||||
min_tlow = 17;
|
min_tlow = 17;
|
||||||
min_thi = 9;
|
min_thi = 9;
|
||||||
raise_fall_time = 22; /* Raise 11e-8s, Fall 11e-8s */
|
raise_fall_time = 22; /* Raise 11e-8s, Fall 11e-8s */
|
||||||
} else if (pca_data->i2c_clock > 1000) {
|
} else if (pca_data->i2c_clock > 100000) {
|
||||||
mode = I2C_PCA_MODE_FAST;
|
mode = I2C_PCA_MODE_FAST;
|
||||||
min_tlow = 44;
|
min_tlow = 44;
|
||||||
min_thi = 20;
|
min_thi = 20;
|
||||||
|
|
Loading…
Reference in New Issue