Re: [PATCH v6 14/24] of/unittest: convert to use an explicit i2c mux core

2016-04-05 Thread Peter Rosin
On 2016-04-04 07:16, Rob Herring wrote:
> On Sun, Apr 03, 2016 at 10:52:44AM +0200, Peter Rosin wrote:
>> From: Peter Rosin 
>>
>> Allocate an explicit i2c mux core to handle parent and child adapters
>> etc. Update the select op to be in terms of the i2c mux core instead
>> of the child adapter.
>>
>> Signed-off-by: Peter Rosin 
>> ---
>>  drivers/of/unittest.c | 40 +++-
>>  1 file changed, 15 insertions(+), 25 deletions(-)
> 
> I assume you ran the unittest...

It's one of the few drivers I do have hardware for, so yes, I did
indeed test it!

> Acked-by: Rob Herring 

Thanks!

Cheers,
Peter
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH v6 14/24] of/unittest: convert to use an explicit i2c mux core

2016-04-03 Thread Rob Herring
On Sun, Apr 03, 2016 at 10:52:44AM +0200, Peter Rosin wrote:
> From: Peter Rosin 
> 
> Allocate an explicit i2c mux core to handle parent and child adapters
> etc. Update the select op to be in terms of the i2c mux core instead
> of the child adapter.
> 
> Signed-off-by: Peter Rosin 
> ---
>  drivers/of/unittest.c | 40 +++-
>  1 file changed, 15 insertions(+), 25 deletions(-)

I assume you ran the unittest...

Acked-by: Rob Herring 
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[PATCH v6 14/24] of/unittest: convert to use an explicit i2c mux core

2016-04-03 Thread Peter Rosin
From: Peter Rosin 

Allocate an explicit i2c mux core to handle parent and child adapters
etc. Update the select op to be in terms of the i2c mux core instead
of the child adapter.

Signed-off-by: Peter Rosin 
---
 drivers/of/unittest.c | 40 +++-
 1 file changed, 15 insertions(+), 25 deletions(-)

diff --git a/drivers/of/unittest.c b/drivers/of/unittest.c
index e986e6ee52e0..84a65b711e8c 100644
--- a/drivers/of/unittest.c
+++ b/drivers/of/unittest.c
@@ -1692,13 +1692,7 @@ static struct i2c_driver unittest_i2c_dev_driver = {
 
 #if IS_BUILTIN(CONFIG_I2C_MUX)
 
-struct unittest_i2c_mux_data {
-   int nchans;
-   struct i2c_adapter *adap[];
-};
-
-static int unittest_i2c_mux_select_chan(struct i2c_adapter *adap,
-  void *client, u32 chan)
+static int unittest_i2c_mux_select_chan(struct i2c_mux_core *muxc, u32 chan)
 {
return 0;
 }
@@ -1706,11 +1700,11 @@ static int unittest_i2c_mux_select_chan(struct 
i2c_adapter *adap,
 static int unittest_i2c_mux_probe(struct i2c_client *client,
const struct i2c_device_id *id)
 {
-   int ret, i, nchans, size;
+   int ret, i, nchans;
struct device *dev = >dev;
struct i2c_adapter *adap = to_i2c_adapter(dev->parent);
struct device_node *np = client->dev.of_node, *child;
-   struct unittest_i2c_mux_data *stm;
+   struct i2c_mux_core *muxc;
u32 reg, max_reg;
 
dev_dbg(dev, "%s for node @%s\n", __func__, np->full_name);
@@ -1734,25 +1728,23 @@ static int unittest_i2c_mux_probe(struct i2c_client 
*client,
return -EINVAL;
}
 
-   size = offsetof(struct unittest_i2c_mux_data, adap[nchans]);
-   stm = devm_kzalloc(dev, size, GFP_KERNEL);
-   if (!stm) {
-   dev_err(dev, "Out of memory\n");
+   muxc = i2c_mux_alloc(adap, dev, 0, 0,
+unittest_i2c_mux_select_chan, NULL);
+   if (!muxc)
return -ENOMEM;
-   }
-   stm->nchans = nchans;
+   ret = i2c_mux_reserve_adapters(muxc, nchans);
+   if (ret)
+   return ret;
for (i = 0; i < nchans; i++) {
-   stm->adap[i] = i2c_add_mux_adapter(adap, dev, client,
-   0, i, 0, unittest_i2c_mux_select_chan, NULL);
-   if (!stm->adap[i]) {
+   ret = i2c_mux_add_adapter(muxc, 0, i, 0);
+   if (ret) {
dev_err(dev, "Failed to register mux #%d\n", i);
-   for (i--; i >= 0; i--)
-   i2c_del_mux_adapter(stm->adap[i]);
+   i2c_mux_del_adapters(muxc);
return -ENODEV;
}
}
 
-   i2c_set_clientdata(client, stm);
+   i2c_set_clientdata(client, muxc);
 
return 0;
 };
@@ -1761,12 +1753,10 @@ static int unittest_i2c_mux_remove(struct i2c_client 
*client)
 {
struct device *dev = >dev;
struct device_node *np = client->dev.of_node;
-   struct unittest_i2c_mux_data *stm = i2c_get_clientdata(client);
-   int i;
+   struct i2c_mux_core *muxc = i2c_get_clientdata(client);
 
dev_dbg(dev, "%s for node @%s\n", __func__, np->full_name);
-   for (i = stm->nchans - 1; i >= 0; i--)
-   i2c_del_mux_adapter(stm->adap[i]);
+   i2c_mux_del_adapters(muxc);
return 0;
 }
 
-- 
2.1.4

--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html