aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/i2c/busses/i2c-designware-platdrv.c
diff options
context:
space:
mode:
authorMika Westerberg <mika.westerberg@linux.intel.com>2013-04-09 20:36:39 -0400
committerWolfram Sang <wsa@the-dreams.de>2013-04-15 12:17:28 -0400
commitefe7d640ef486c4c0c305641dbcacc6918542b76 (patch)
treec478b1c7fd8d866f36bc7a5e6022efe312982293 /drivers/i2c/busses/i2c-designware-platdrv.c
parent76cf3fc844a46b5cdb94da98bffcbd45d4c355b8 (diff)
i2c-designware: use dynamic adapter numbering on Lynxpoint
It is not good idea to mix static and dynamic I2C adapter numbering. In this particular case on Lynxpoint we had graphics I2C adapter which took the first numbers preventing the designware I2C driver from using the adapter numbers it preferred. Since Lynxpoint support was just introduced and there is no hardware available outside Intel we can fix this by switching to use dynamic adapter numbering instead of static. Signed-off-by: Mika Westerberg <mika.westerberg@linux.intel.com> Signed-off-by: Wolfram Sang <wsa@the-dreams.de>
Diffstat (limited to 'drivers/i2c/busses/i2c-designware-platdrv.c')
-rw-r--r--drivers/i2c/busses/i2c-designware-platdrv.c9
1 files changed, 0 insertions, 9 deletions
diff --git a/drivers/i2c/busses/i2c-designware-platdrv.c b/drivers/i2c/busses/i2c-designware-platdrv.c
index c53a3127f694..2a596dd1ec66 100644
--- a/drivers/i2c/busses/i2c-designware-platdrv.c
+++ b/drivers/i2c/busses/i2c-designware-platdrv.c
@@ -56,20 +56,11 @@ static u32 i2c_dw_get_clk_rate_khz(struct dw_i2c_dev *dev)
56static int dw_i2c_acpi_configure(struct platform_device *pdev) 56static int dw_i2c_acpi_configure(struct platform_device *pdev)
57{ 57{
58 struct dw_i2c_dev *dev = platform_get_drvdata(pdev); 58 struct dw_i2c_dev *dev = platform_get_drvdata(pdev);
59 struct acpi_device *adev;
60 int busno, ret;
61 59
62 if (!ACPI_HANDLE(&pdev->dev)) 60 if (!ACPI_HANDLE(&pdev->dev))
63 return -ENODEV; 61 return -ENODEV;
64 62
65 ret = acpi_bus_get_device(ACPI_HANDLE(&pdev->dev), &adev);
66 if (ret)
67 return -ENODEV;
68
69 dev->adapter.nr = -1; 63 dev->adapter.nr = -1;
70 if (adev->pnp.unique_id && !kstrtoint(adev->pnp.unique_id, 0, &busno))
71 dev->adapter.nr = busno;
72
73 dev->tx_fifo_depth = 32; 64 dev->tx_fifo_depth = 32;
74 dev->rx_fifo_depth = 32; 65 dev->rx_fifo_depth = 32;
75 return 0; 66 return 0;