diff options
author | Jean Delvare <khali@linux-fr.org> | 2012-10-05 16:23:51 -0400 |
---|---|---|
committer | Jean Delvare <khali@endymion.delvare> | 2012-10-05 16:23:51 -0400 |
commit | eee543e8248150e8fb833943c71f40c7b1724600 (patch) | |
tree | 56efec8384b2bca4cf926583b52a7cf6136fa76f /drivers/i2c/muxes | |
parent | 5f3d2f2e1a63679cf1c4a4210f2f1cc2f335bef6 (diff) |
i2c-mux: Add support for device auto-detection
Let I2C bus segments behind multiplexers have a class. This allows for
device auto-detection on these segments. As long as parent segments
don't share the same class, it should be fine.
I implemented support in drivers i2c-mux-gpio and i2c-mux-pca954x. I
left i2c-mux-pca9541 and i2c-mux-pinctrl alone for the moment as I
don't know if this feature makes sense for the use cases of these
drivers.
Signed-off-by: Jean Delvare <khali@linux-fr.org>
Cc: Peter Korsgaard <peter.korsgaard@barco.com>
Cc: David Daney <david.daney@cavium.com>
Cc: Michael Lawnick <ml.lawnick@gmx.de>
Cc: Rodolfo Giometti <giometti@linux.it>
Diffstat (limited to 'drivers/i2c/muxes')
-rw-r--r-- | drivers/i2c/muxes/i2c-mux-gpio.c | 4 | ||||
-rw-r--r-- | drivers/i2c/muxes/i2c-mux-pca9541.c | 2 | ||||
-rw-r--r-- | drivers/i2c/muxes/i2c-mux-pca954x.c | 10 | ||||
-rw-r--r-- | drivers/i2c/muxes/i2c-mux-pinctrl.c | 2 |
4 files changed, 11 insertions, 7 deletions
diff --git a/drivers/i2c/muxes/i2c-mux-gpio.c b/drivers/i2c/muxes/i2c-mux-gpio.c index 68b1f8ec3436..56889e00c76e 100644 --- a/drivers/i2c/muxes/i2c-mux-gpio.c +++ b/drivers/i2c/muxes/i2c-mux-gpio.c | |||
@@ -104,8 +104,10 @@ static int __devinit i2c_mux_gpio_probe(struct platform_device *pdev) | |||
104 | 104 | ||
105 | for (i = 0; i < pdata->n_values; i++) { | 105 | for (i = 0; i < pdata->n_values; i++) { |
106 | u32 nr = pdata->base_nr ? (pdata->base_nr + i) : 0; | 106 | u32 nr = pdata->base_nr ? (pdata->base_nr + i) : 0; |
107 | unsigned int class = pdata->classes ? pdata->classes[i] : 0; | ||
107 | 108 | ||
108 | mux->adap[i] = i2c_add_mux_adapter(parent, &pdev->dev, mux, nr, i, | 109 | mux->adap[i] = i2c_add_mux_adapter(parent, &pdev->dev, mux, nr, |
110 | i, class, | ||
109 | i2c_mux_gpio_select, deselect); | 111 | i2c_mux_gpio_select, deselect); |
110 | if (!mux->adap[i]) { | 112 | if (!mux->adap[i]) { |
111 | ret = -ENODEV; | 113 | ret = -ENODEV; |
diff --git a/drivers/i2c/muxes/i2c-mux-pca9541.c b/drivers/i2c/muxes/i2c-mux-pca9541.c index f8f72f39e0b5..f3b8f9a6a89b 100644 --- a/drivers/i2c/muxes/i2c-mux-pca9541.c +++ b/drivers/i2c/muxes/i2c-mux-pca9541.c | |||
@@ -354,7 +354,7 @@ static int pca9541_probe(struct i2c_client *client, | |||
354 | if (pdata) | 354 | if (pdata) |
355 | force = pdata->modes[0].adap_id; | 355 | force = pdata->modes[0].adap_id; |
356 | data->mux_adap = i2c_add_mux_adapter(adap, &client->dev, client, | 356 | data->mux_adap = i2c_add_mux_adapter(adap, &client->dev, client, |
357 | force, 0, | 357 | force, 0, 0, |
358 | pca9541_select_chan, | 358 | pca9541_select_chan, |
359 | pca9541_release_chan); | 359 | pca9541_release_chan); |
360 | 360 | ||
diff --git a/drivers/i2c/muxes/i2c-mux-pca954x.c b/drivers/i2c/muxes/i2c-mux-pca954x.c index f2dfe0d8fcce..8e4387235b69 100644 --- a/drivers/i2c/muxes/i2c-mux-pca954x.c +++ b/drivers/i2c/muxes/i2c-mux-pca954x.c | |||
@@ -186,7 +186,7 @@ static int pca954x_probe(struct i2c_client *client, | |||
186 | { | 186 | { |
187 | struct i2c_adapter *adap = to_i2c_adapter(client->dev.parent); | 187 | struct i2c_adapter *adap = to_i2c_adapter(client->dev.parent); |
188 | struct pca954x_platform_data *pdata = client->dev.platform_data; | 188 | struct pca954x_platform_data *pdata = client->dev.platform_data; |
189 | int num, force; | 189 | int num, force, class; |
190 | struct pca954x *data; | 190 | struct pca954x *data; |
191 | int ret = -ENODEV; | 191 | int ret = -ENODEV; |
192 | 192 | ||
@@ -216,18 +216,20 @@ static int pca954x_probe(struct i2c_client *client, | |||
216 | /* Now create an adapter for each channel */ | 216 | /* Now create an adapter for each channel */ |
217 | for (num = 0; num < chips[data->type].nchans; num++) { | 217 | for (num = 0; num < chips[data->type].nchans; num++) { |
218 | force = 0; /* dynamic adap number */ | 218 | force = 0; /* dynamic adap number */ |
219 | class = 0; /* no class by default */ | ||
219 | if (pdata) { | 220 | if (pdata) { |
220 | if (num < pdata->num_modes) | 221 | if (num < pdata->num_modes) { |
221 | /* force static number */ | 222 | /* force static number */ |
222 | force = pdata->modes[num].adap_id; | 223 | force = pdata->modes[num].adap_id; |
223 | else | 224 | class = pdata->modes[num].class; |
225 | } else | ||
224 | /* discard unconfigured channels */ | 226 | /* discard unconfigured channels */ |
225 | break; | 227 | break; |
226 | } | 228 | } |
227 | 229 | ||
228 | data->virt_adaps[num] = | 230 | data->virt_adaps[num] = |
229 | i2c_add_mux_adapter(adap, &client->dev, client, | 231 | i2c_add_mux_adapter(adap, &client->dev, client, |
230 | force, num, pca954x_select_chan, | 232 | force, num, class, pca954x_select_chan, |
231 | (pdata && pdata->modes[num].deselect_on_exit) | 233 | (pdata && pdata->modes[num].deselect_on_exit) |
232 | ? pca954x_deselect_mux : NULL); | 234 | ? pca954x_deselect_mux : NULL); |
233 | 235 | ||
diff --git a/drivers/i2c/muxes/i2c-mux-pinctrl.c b/drivers/i2c/muxes/i2c-mux-pinctrl.c index 46a669763476..5f097f309b9f 100644 --- a/drivers/i2c/muxes/i2c-mux-pinctrl.c +++ b/drivers/i2c/muxes/i2c-mux-pinctrl.c | |||
@@ -221,7 +221,7 @@ static int __devinit i2c_mux_pinctrl_probe(struct platform_device *pdev) | |||
221 | (mux->pdata->base_bus_num + i) : 0; | 221 | (mux->pdata->base_bus_num + i) : 0; |
222 | 222 | ||
223 | mux->busses[i] = i2c_add_mux_adapter(mux->parent, &pdev->dev, | 223 | mux->busses[i] = i2c_add_mux_adapter(mux->parent, &pdev->dev, |
224 | mux, bus, i, | 224 | mux, bus, i, 0, |
225 | i2c_mux_pinctrl_select, | 225 | i2c_mux_pinctrl_select, |
226 | deselect); | 226 | deselect); |
227 | if (!mux->busses[i]) { | 227 | if (!mux->busses[i]) { |