diff options
Diffstat (limited to 'drivers/i2c/algos/i2c-algo-bit.c')
-rw-r--r-- | drivers/i2c/algos/i2c-algo-bit.c | 31 |
1 files changed, 15 insertions, 16 deletions
diff --git a/drivers/i2c/algos/i2c-algo-bit.c b/drivers/i2c/algos/i2c-algo-bit.c index a39e6cff86e7..38319a69bd0a 100644 --- a/drivers/i2c/algos/i2c-algo-bit.c +++ b/drivers/i2c/algos/i2c-algo-bit.c | |||
@@ -600,12 +600,14 @@ static const struct i2c_algorithm i2c_bit_algo = { | |||
600 | /* | 600 | /* |
601 | * registering functions to load algorithms at runtime | 601 | * registering functions to load algorithms at runtime |
602 | */ | 602 | */ |
603 | static int i2c_bit_prepare_bus(struct i2c_adapter *adap) | 603 | static int __i2c_bit_add_bus(struct i2c_adapter *adap, |
604 | int (*add_adapter)(struct i2c_adapter *)) | ||
604 | { | 605 | { |
605 | struct i2c_algo_bit_data *bit_adap = adap->algo_data; | 606 | struct i2c_algo_bit_data *bit_adap = adap->algo_data; |
607 | int ret; | ||
606 | 608 | ||
607 | if (bit_test) { | 609 | if (bit_test) { |
608 | int ret = test_bus(bit_adap, adap->name); | 610 | ret = test_bus(bit_adap, adap->name); |
609 | if (ret < 0) | 611 | if (ret < 0) |
610 | return -ENODEV; | 612 | return -ENODEV; |
611 | } | 613 | } |
@@ -614,30 +616,27 @@ static int i2c_bit_prepare_bus(struct i2c_adapter *adap) | |||
614 | adap->algo = &i2c_bit_algo; | 616 | adap->algo = &i2c_bit_algo; |
615 | adap->retries = 3; | 617 | adap->retries = 3; |
616 | 618 | ||
619 | ret = add_adapter(adap); | ||
620 | if (ret < 0) | ||
621 | return ret; | ||
622 | |||
623 | /* Complain if SCL can't be read */ | ||
624 | if (bit_adap->getscl == NULL) { | ||
625 | dev_warn(&adap->dev, "Not I2C compliant: can't read SCL\n"); | ||
626 | dev_warn(&adap->dev, "Bus may be unreliable\n"); | ||
627 | } | ||
617 | return 0; | 628 | return 0; |
618 | } | 629 | } |
619 | 630 | ||
620 | int i2c_bit_add_bus(struct i2c_adapter *adap) | 631 | int i2c_bit_add_bus(struct i2c_adapter *adap) |
621 | { | 632 | { |
622 | int err; | 633 | return __i2c_bit_add_bus(adap, i2c_add_adapter); |
623 | |||
624 | err = i2c_bit_prepare_bus(adap); | ||
625 | if (err) | ||
626 | return err; | ||
627 | |||
628 | return i2c_add_adapter(adap); | ||
629 | } | 634 | } |
630 | EXPORT_SYMBOL(i2c_bit_add_bus); | 635 | EXPORT_SYMBOL(i2c_bit_add_bus); |
631 | 636 | ||
632 | int i2c_bit_add_numbered_bus(struct i2c_adapter *adap) | 637 | int i2c_bit_add_numbered_bus(struct i2c_adapter *adap) |
633 | { | 638 | { |
634 | int err; | 639 | return __i2c_bit_add_bus(adap, i2c_add_numbered_adapter); |
635 | |||
636 | err = i2c_bit_prepare_bus(adap); | ||
637 | if (err) | ||
638 | return err; | ||
639 | |||
640 | return i2c_add_numbered_adapter(adap); | ||
641 | } | 640 | } |
642 | EXPORT_SYMBOL(i2c_bit_add_numbered_bus); | 641 | EXPORT_SYMBOL(i2c_bit_add_numbered_bus); |
643 | 642 | ||