Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 308465
b: refs/heads/master
c: 5a3ecd5
h: refs/heads/master
i:
  308463: 3d33c91
v: v3
  • Loading branch information
David Daney authored and Wolfram Sang committed May 12, 2012
1 parent 5e0d2cb commit 39a8315
Show file tree
Hide file tree
Showing 6 changed files with 18 additions and 14 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: d9afca37dea077d11ed67fc7f93b95c003e58819
refs/heads/master: 5a3ecd5f9877b963a581ca5d4495a1a24dafc88c
19 changes: 10 additions & 9 deletions trunk/drivers/i2c/i2c-mux.c
Original file line number Diff line number Diff line change
Expand Up @@ -31,11 +31,11 @@ struct i2c_mux_priv {
struct i2c_algorithm algo;

struct i2c_adapter *parent;
void *mux_dev; /* the mux chip/device */
void *mux_priv; /* the mux chip/device */
u32 chan_id; /* the channel id */

int (*select)(struct i2c_adapter *, void *mux_dev, u32 chan_id);
int (*deselect)(struct i2c_adapter *, void *mux_dev, u32 chan_id);
int (*select)(struct i2c_adapter *, void *mux_priv, u32 chan_id);
int (*deselect)(struct i2c_adapter *, void *mux_priv, u32 chan_id);
};

static int i2c_mux_master_xfer(struct i2c_adapter *adap,
Expand All @@ -47,11 +47,11 @@ static int i2c_mux_master_xfer(struct i2c_adapter *adap,

/* Switch to the right mux port and perform the transfer. */

ret = priv->select(parent, priv->mux_dev, priv->chan_id);
ret = priv->select(parent, priv->mux_priv, priv->chan_id);
if (ret >= 0)
ret = parent->algo->master_xfer(parent, msgs, num);
if (priv->deselect)
priv->deselect(parent, priv->mux_dev, priv->chan_id);
priv->deselect(parent, priv->mux_priv, priv->chan_id);

return ret;
}
Expand All @@ -67,12 +67,12 @@ static int i2c_mux_smbus_xfer(struct i2c_adapter *adap,

/* Select the right mux port and perform the transfer. */

ret = priv->select(parent, priv->mux_dev, priv->chan_id);
ret = priv->select(parent, priv->mux_priv, priv->chan_id);
if (ret >= 0)
ret = parent->algo->smbus_xfer(parent, addr, flags,
read_write, command, size, data);
if (priv->deselect)
priv->deselect(parent, priv->mux_dev, priv->chan_id);
priv->deselect(parent, priv->mux_priv, priv->chan_id);

return ret;
}
Expand All @@ -87,7 +87,8 @@ static u32 i2c_mux_functionality(struct i2c_adapter *adap)
}

struct i2c_adapter *i2c_add_mux_adapter(struct i2c_adapter *parent,
void *mux_dev, u32 force_nr, u32 chan_id,
struct device *mux_dev,
void *mux_priv, u32 force_nr, u32 chan_id,
int (*select) (struct i2c_adapter *,
void *, u32),
int (*deselect) (struct i2c_adapter *,
Expand All @@ -102,7 +103,7 @@ struct i2c_adapter *i2c_add_mux_adapter(struct i2c_adapter *parent,

/* Set up private adapter data */
priv->parent = parent;
priv->mux_dev = mux_dev;
priv->mux_priv = mux_priv;
priv->chan_id = chan_id;
priv->select = select;
priv->deselect = deselect;
Expand Down
3 changes: 2 additions & 1 deletion trunk/drivers/i2c/muxes/gpio-i2cmux.c
Original file line number Diff line number Diff line change
Expand Up @@ -105,7 +105,8 @@ static int __devinit gpiomux_probe(struct platform_device *pdev)
for (i = 0; i < pdata->n_values; i++) {
u32 nr = pdata->base_nr ? (pdata->base_nr + i) : 0;

mux->adap[i] = i2c_add_mux_adapter(parent, mux, nr, i,
mux->adap[i] = i2c_add_mux_adapter(parent, &pdev->dev, mux,
nr, i,
gpiomux_select, deselect);
if (!mux->adap[i]) {
ret = -ENODEV;
Expand Down
3 changes: 2 additions & 1 deletion trunk/drivers/i2c/muxes/pca9541.c
Original file line number Diff line number Diff line change
Expand Up @@ -353,7 +353,8 @@ static int pca9541_probe(struct i2c_client *client,
force = 0;
if (pdata)
force = pdata->modes[0].adap_id;
data->mux_adap = i2c_add_mux_adapter(adap, client, force, 0,
data->mux_adap = i2c_add_mux_adapter(adap, &client->dev, client,
force, 0,
pca9541_select_chan,
pca9541_release_chan);

Expand Down
2 changes: 1 addition & 1 deletion trunk/drivers/i2c/muxes/pca954x.c
Original file line number Diff line number Diff line change
Expand Up @@ -226,7 +226,7 @@ static int pca954x_probe(struct i2c_client *client,
}

data->virt_adaps[num] =
i2c_add_mux_adapter(adap, client,
i2c_add_mux_adapter(adap, &client->dev, client,
force, num, pca954x_select_chan,
(pdata && pdata->modes[num].deselect_on_exit)
? pca954x_deselect_mux : NULL);
Expand Down
3 changes: 2 additions & 1 deletion trunk/include/linux/i2c-mux.h
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,8 @@
* mux control.
*/
struct i2c_adapter *i2c_add_mux_adapter(struct i2c_adapter *parent,
void *mux_dev, u32 force_nr, u32 chan_id,
struct device *mux_dev,
void *mux_priv, u32 force_nr, u32 chan_id,
int (*select) (struct i2c_adapter *,
void *mux_dev, u32 chan_id),
int (*deselect) (struct i2c_adapter *,
Expand Down

0 comments on commit 39a8315

Please sign in to comment.