On Tue, Jun 02, 2009 at 07:52:40PM +0200, Richard R????jfors wrote: > There is sometimes a need for the ocores driver to add devices to the bus when installed. > > i2c_register_board_info can not always be used, because the I2C devices are not known at an early state, > they could for instance be connected on a I2C bus on a PCI device which has the Open Cores IP. > > i2c_new_device can not be used in all cases either since the resulting bus nummer might be unknown. > > The solution is the pass a list of I2C devices in the platform data to the Open Cores driver. Is > useful for MFD drivers for instance. Hi, these two minor issues here I'd like to get at-least a reply if not a fix for: > Signed-off-by: Richard R??jfors <richard.rojfors.ext@xxxxxxxxxxxxxxx> > --- > Index: linux-2.6.30-rc7/drivers/i2c/busses/i2c-ocores.c > =================================================================== > --- linux-2.6.30-rc7/drivers/i2c/busses/i2c-ocores.c (revision 861) > +++ linux-2.6.30-rc7/drivers/i2c/busses/i2c-ocores.c (revision 862) > @@ -216,6 +216,7 @@ > struct ocores_i2c_platform_data *pdata; > struct resource *res, *res2; > int ret; > + u8 i; Do you really need u8, doing the following would probably produce better code: unsigned i > res = platform_get_resource(pdev, IORESOURCE_MEM, 0); > if (!res) > @@ -271,6 +272,10 @@ > goto add_adapter_failed; > } > > + /* add in known devices to the bus */ > + for (i = 0; i < pdata->num_devices; i++) > + i2c_new_device(&i2c->adap, pdata->devices + i); > + > return 0; > > add_adapter_failed: > Index: linux-2.6.30-rc7/include/linux/i2c-ocores.h > =================================================================== > --- linux-2.6.30-rc7/include/linux/i2c-ocores.h (revision 861) > +++ linux-2.6.30-rc7/include/linux/i2c-ocores.h (revision 862) > @@ -14,6 +14,8 @@ > struct ocores_i2c_platform_data { > u32 regstep; /* distance between registers */ > u32 clock_khz; /* input clock in kHz */ > + u8 num_devices; /* number of devices in the devices list */ > + struct i2c_board_info const *devices; /* devices connected to the bus */ > }; Any chance of kerneldoc for this structure? -- Ben (ben@xxxxxxxxx, http://www.fluff.org/) 'a smiley only costs 4 bytes' -- To unsubscribe from this list: send the line "unsubscribe linux-i2c" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html