diff options
Diffstat (limited to 'drivers/i2c')
| -rw-r--r-- | drivers/i2c/Kconfig | 2 | ||||
| -rw-r--r-- | drivers/i2c/busses/Kconfig | 6 | ||||
| -rw-r--r-- | drivers/i2c/busses/i2c-designware-platdrv.c | 1 | ||||
| -rw-r--r-- | drivers/i2c/busses/i2c-ismt.c | 2 | ||||
| -rw-r--r-- | drivers/i2c/busses/i2c-tegra.c | 13 | ||||
| -rw-r--r-- | drivers/i2c/muxes/i2c-mux-pca9541.c | 2 |
6 files changed, 19 insertions, 7 deletions
diff --git a/drivers/i2c/Kconfig b/drivers/i2c/Kconfig index 46cde098c11c..e380c6eef3af 100644 --- a/drivers/i2c/Kconfig +++ b/drivers/i2c/Kconfig | |||
| @@ -4,7 +4,6 @@ | |||
| 4 | 4 | ||
| 5 | menuconfig I2C | 5 | menuconfig I2C |
| 6 | tristate "I2C support" | 6 | tristate "I2C support" |
| 7 | depends on !S390 | ||
| 8 | select RT_MUTEXES | 7 | select RT_MUTEXES |
| 9 | ---help--- | 8 | ---help--- |
| 10 | I2C (pronounce: I-squared-C) is a slow serial bus protocol used in | 9 | I2C (pronounce: I-squared-C) is a slow serial bus protocol used in |
| @@ -76,6 +75,7 @@ config I2C_HELPER_AUTO | |||
| 76 | 75 | ||
| 77 | config I2C_SMBUS | 76 | config I2C_SMBUS |
| 78 | tristate "SMBus-specific protocols" if !I2C_HELPER_AUTO | 77 | tristate "SMBus-specific protocols" if !I2C_HELPER_AUTO |
| 78 | depends on GENERIC_HARDIRQS | ||
| 79 | help | 79 | help |
| 80 | Say Y here if you want support for SMBus extensions to the I2C | 80 | Say Y here if you want support for SMBus extensions to the I2C |
| 81 | specification. At the moment, the only supported extension is | 81 | specification. At the moment, the only supported extension is |
diff --git a/drivers/i2c/busses/Kconfig b/drivers/i2c/busses/Kconfig index a3725de92384..adfee98486b1 100644 --- a/drivers/i2c/busses/Kconfig +++ b/drivers/i2c/busses/Kconfig | |||
| @@ -114,7 +114,7 @@ config I2C_I801 | |||
| 114 | 114 | ||
| 115 | config I2C_ISCH | 115 | config I2C_ISCH |
| 116 | tristate "Intel SCH SMBus 1.0" | 116 | tristate "Intel SCH SMBus 1.0" |
| 117 | depends on PCI | 117 | depends on PCI && GENERIC_HARDIRQS |
| 118 | select LPC_SCH | 118 | select LPC_SCH |
| 119 | help | 119 | help |
| 120 | Say Y here if you want to use SMBus controller on the Intel SCH | 120 | Say Y here if you want to use SMBus controller on the Intel SCH |
| @@ -543,6 +543,7 @@ config I2C_NUC900 | |||
| 543 | 543 | ||
| 544 | config I2C_OCORES | 544 | config I2C_OCORES |
| 545 | tristate "OpenCores I2C Controller" | 545 | tristate "OpenCores I2C Controller" |
| 546 | depends on GENERIC_HARDIRQS | ||
| 546 | help | 547 | help |
| 547 | If you say yes to this option, support will be included for the | 548 | If you say yes to this option, support will be included for the |
| 548 | OpenCores I2C controller. For details see | 549 | OpenCores I2C controller. For details see |
| @@ -777,7 +778,7 @@ config I2C_DIOLAN_U2C | |||
| 777 | 778 | ||
| 778 | config I2C_PARPORT | 779 | config I2C_PARPORT |
| 779 | tristate "Parallel port adapter" | 780 | tristate "Parallel port adapter" |
| 780 | depends on PARPORT | 781 | depends on PARPORT && GENERIC_HARDIRQS |
| 781 | select I2C_ALGOBIT | 782 | select I2C_ALGOBIT |
| 782 | select I2C_SMBUS | 783 | select I2C_SMBUS |
| 783 | help | 784 | help |
| @@ -802,6 +803,7 @@ config I2C_PARPORT | |||
| 802 | 803 | ||
| 803 | config I2C_PARPORT_LIGHT | 804 | config I2C_PARPORT_LIGHT |
| 804 | tristate "Parallel port adapter (light)" | 805 | tristate "Parallel port adapter (light)" |
| 806 | depends on GENERIC_HARDIRQS | ||
| 805 | select I2C_ALGOBIT | 807 | select I2C_ALGOBIT |
| 806 | select I2C_SMBUS | 808 | select I2C_SMBUS |
| 807 | help | 809 | help |
diff --git a/drivers/i2c/busses/i2c-designware-platdrv.c b/drivers/i2c/busses/i2c-designware-platdrv.c index 0ceb6e1b0f65..e3085c487ace 100644 --- a/drivers/i2c/busses/i2c-designware-platdrv.c +++ b/drivers/i2c/busses/i2c-designware-platdrv.c | |||
| @@ -182,7 +182,6 @@ static int dw_i2c_probe(struct platform_device *pdev) | |||
| 182 | adap->algo = &i2c_dw_algo; | 182 | adap->algo = &i2c_dw_algo; |
| 183 | adap->dev.parent = &pdev->dev; | 183 | adap->dev.parent = &pdev->dev; |
| 184 | adap->dev.of_node = pdev->dev.of_node; | 184 | adap->dev.of_node = pdev->dev.of_node; |
| 185 | ACPI_HANDLE_SET(&adap->dev, ACPI_HANDLE(&pdev->dev)); | ||
| 186 | 185 | ||
| 187 | r = i2c_add_numbered_adapter(adap); | 186 | r = i2c_add_numbered_adapter(adap); |
| 188 | if (r) { | 187 | if (r) { |
diff --git a/drivers/i2c/busses/i2c-ismt.c b/drivers/i2c/busses/i2c-ismt.c index e9205ee8cf94..130f02cc9d94 100644 --- a/drivers/i2c/busses/i2c-ismt.c +++ b/drivers/i2c/busses/i2c-ismt.c | |||
| @@ -80,6 +80,7 @@ | |||
| 80 | /* PCI DIDs for the Intel SMBus Message Transport (SMT) Devices */ | 80 | /* PCI DIDs for the Intel SMBus Message Transport (SMT) Devices */ |
| 81 | #define PCI_DEVICE_ID_INTEL_S1200_SMT0 0x0c59 | 81 | #define PCI_DEVICE_ID_INTEL_S1200_SMT0 0x0c59 |
| 82 | #define PCI_DEVICE_ID_INTEL_S1200_SMT1 0x0c5a | 82 | #define PCI_DEVICE_ID_INTEL_S1200_SMT1 0x0c5a |
| 83 | #define PCI_DEVICE_ID_INTEL_AVOTON_SMT 0x1f15 | ||
| 83 | 84 | ||
| 84 | #define ISMT_DESC_ENTRIES 32 /* number of descriptor entries */ | 85 | #define ISMT_DESC_ENTRIES 32 /* number of descriptor entries */ |
| 85 | #define ISMT_MAX_RETRIES 3 /* number of SMBus retries to attempt */ | 86 | #define ISMT_MAX_RETRIES 3 /* number of SMBus retries to attempt */ |
| @@ -185,6 +186,7 @@ struct ismt_priv { | |||
| 185 | static const DEFINE_PCI_DEVICE_TABLE(ismt_ids) = { | 186 | static const DEFINE_PCI_DEVICE_TABLE(ismt_ids) = { |
| 186 | { PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_S1200_SMT0) }, | 187 | { PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_S1200_SMT0) }, |
| 187 | { PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_S1200_SMT1) }, | 188 | { PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_S1200_SMT1) }, |
| 189 | { PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_AVOTON_SMT) }, | ||
| 188 | { 0, } | 190 | { 0, } |
| 189 | }; | 191 | }; |
| 190 | 192 | ||
diff --git a/drivers/i2c/busses/i2c-tegra.c b/drivers/i2c/busses/i2c-tegra.c index 36704e3ab3fa..b714776b6ddd 100644 --- a/drivers/i2c/busses/i2c-tegra.c +++ b/drivers/i2c/busses/i2c-tegra.c | |||
| @@ -411,7 +411,11 @@ static int tegra_i2c_init(struct tegra_i2c_dev *i2c_dev) | |||
| 411 | int clk_multiplier = I2C_CLK_MULTIPLIER_STD_FAST_MODE; | 411 | int clk_multiplier = I2C_CLK_MULTIPLIER_STD_FAST_MODE; |
| 412 | u32 clk_divisor; | 412 | u32 clk_divisor; |
| 413 | 413 | ||
| 414 | tegra_i2c_clock_enable(i2c_dev); | 414 | err = tegra_i2c_clock_enable(i2c_dev); |
| 415 | if (err < 0) { | ||
| 416 | dev_err(i2c_dev->dev, "Clock enable failed %d\n", err); | ||
| 417 | return err; | ||
| 418 | } | ||
| 415 | 419 | ||
| 416 | tegra_periph_reset_assert(i2c_dev->div_clk); | 420 | tegra_periph_reset_assert(i2c_dev->div_clk); |
| 417 | udelay(2); | 421 | udelay(2); |
| @@ -628,7 +632,12 @@ static int tegra_i2c_xfer(struct i2c_adapter *adap, struct i2c_msg msgs[], | |||
| 628 | if (i2c_dev->is_suspended) | 632 | if (i2c_dev->is_suspended) |
| 629 | return -EBUSY; | 633 | return -EBUSY; |
| 630 | 634 | ||
| 631 | tegra_i2c_clock_enable(i2c_dev); | 635 | ret = tegra_i2c_clock_enable(i2c_dev); |
| 636 | if (ret < 0) { | ||
| 637 | dev_err(i2c_dev->dev, "Clock enable failed %d\n", ret); | ||
| 638 | return ret; | ||
| 639 | } | ||
| 640 | |||
| 632 | for (i = 0; i < num; i++) { | 641 | for (i = 0; i < num; i++) { |
| 633 | enum msg_end_type end_type = MSG_END_STOP; | 642 | enum msg_end_type end_type = MSG_END_STOP; |
| 634 | if (i < (num - 1)) { | 643 | if (i < (num - 1)) { |
diff --git a/drivers/i2c/muxes/i2c-mux-pca9541.c b/drivers/i2c/muxes/i2c-mux-pca9541.c index f3b8f9a6a89b..966a18a5d12d 100644 --- a/drivers/i2c/muxes/i2c-mux-pca9541.c +++ b/drivers/i2c/muxes/i2c-mux-pca9541.c | |||
| @@ -3,7 +3,7 @@ | |||
| 3 | * | 3 | * |
| 4 | * Copyright (c) 2010 Ericsson AB. | 4 | * Copyright (c) 2010 Ericsson AB. |
| 5 | * | 5 | * |
| 6 | * Author: Guenter Roeck <guenter.roeck@ericsson.com> | 6 | * Author: Guenter Roeck <linux@roeck-us.net> |
| 7 | * | 7 | * |
| 8 | * Derived from: | 8 | * Derived from: |
| 9 | * pca954x.c | 9 | * pca954x.c |
