diff options
| -rw-r--r-- | Documentation/i2c/busses/i2c-ocores | 17 | ||||
| -rw-r--r-- | drivers/i2c/busses/i2c-ocores.c | 5 | ||||
| -rw-r--r-- | include/linux/i2c-ocores.h | 2 |
3 files changed, 24 insertions, 0 deletions
diff --git a/Documentation/i2c/busses/i2c-ocores b/Documentation/i2c/busses/i2c-ocores index cfcebb10d14e..c269aaa2f26a 100644 --- a/Documentation/i2c/busses/i2c-ocores +++ b/Documentation/i2c/busses/i2c-ocores | |||
| @@ -20,6 +20,8 @@ platform_device with the base address and interrupt number. The | |||
| 20 | dev.platform_data of the device should also point to a struct | 20 | dev.platform_data of the device should also point to a struct |
| 21 | ocores_i2c_platform_data (see linux/i2c-ocores.h) describing the | 21 | ocores_i2c_platform_data (see linux/i2c-ocores.h) describing the |
| 22 | distance between registers and the input clock speed. | 22 | distance between registers and the input clock speed. |
| 23 | There is also a possibility to attach a list of i2c_board_info which | ||
| 24 | the i2c-ocores driver will add to the bus upon creation. | ||
| 23 | 25 | ||
| 24 | E.G. something like: | 26 | E.G. something like: |
| 25 | 27 | ||
| @@ -36,9 +38,24 @@ static struct resource ocores_resources[] = { | |||
| 36 | }, | 38 | }, |
| 37 | }; | 39 | }; |
| 38 | 40 | ||
| 41 | /* optional board info */ | ||
| 42 | struct i2c_board_info ocores_i2c_board_info[] = { | ||
| 43 | { | ||
| 44 | I2C_BOARD_INFO("tsc2003", 0x48), | ||
| 45 | .platform_data = &tsc2003_platform_data, | ||
| 46 | .irq = TSC_IRQ | ||
| 47 | }, | ||
| 48 | { | ||
| 49 | I2C_BOARD_INFO("adv7180", 0x42 >> 1), | ||
| 50 | .irq = ADV_IRQ | ||
| 51 | } | ||
| 52 | }; | ||
| 53 | |||
| 39 | static struct ocores_i2c_platform_data myi2c_data = { | 54 | static struct ocores_i2c_platform_data myi2c_data = { |
| 40 | .regstep = 2, /* two bytes between registers */ | 55 | .regstep = 2, /* two bytes between registers */ |
| 41 | .clock_khz = 50000, /* input clock of 50MHz */ | 56 | .clock_khz = 50000, /* input clock of 50MHz */ |
| 57 | .devices = ocores_i2c_board_info, /* optional table of devices */ | ||
| 58 | .num_devices = ARRAY_SIZE(ocores_i2c_board_info), /* table size */ | ||
| 42 | }; | 59 | }; |
| 43 | 60 | ||
| 44 | static struct platform_device myi2c = { | 61 | static struct platform_device myi2c = { |
diff --git a/drivers/i2c/busses/i2c-ocores.c b/drivers/i2c/busses/i2c-ocores.c index e5193bf75483..3542c6ba98f1 100644 --- a/drivers/i2c/busses/i2c-ocores.c +++ b/drivers/i2c/busses/i2c-ocores.c | |||
| @@ -216,6 +216,7 @@ static int __devinit ocores_i2c_probe(struct platform_device *pdev) | |||
| 216 | struct ocores_i2c_platform_data *pdata; | 216 | struct ocores_i2c_platform_data *pdata; |
| 217 | struct resource *res, *res2; | 217 | struct resource *res, *res2; |
| 218 | int ret; | 218 | int ret; |
| 219 | int i; | ||
| 219 | 220 | ||
| 220 | res = platform_get_resource(pdev, IORESOURCE_MEM, 0); | 221 | res = platform_get_resource(pdev, IORESOURCE_MEM, 0); |
| 221 | if (!res) | 222 | if (!res) |
| @@ -271,6 +272,10 @@ static int __devinit ocores_i2c_probe(struct platform_device *pdev) | |||
| 271 | goto add_adapter_failed; | 272 | goto add_adapter_failed; |
| 272 | } | 273 | } |
| 273 | 274 | ||
| 275 | /* add in known devices to the bus */ | ||
| 276 | for (i = 0; i < pdata->num_devices; i++) | ||
| 277 | i2c_new_device(&i2c->adap, pdata->devices + i); | ||
| 278 | |||
| 274 | return 0; | 279 | return 0; |
| 275 | 280 | ||
| 276 | add_adapter_failed: | 281 | add_adapter_failed: |
diff --git a/include/linux/i2c-ocores.h b/include/linux/i2c-ocores.h index 8ed591b0887e..4d5e57ff6614 100644 --- a/include/linux/i2c-ocores.h +++ b/include/linux/i2c-ocores.h | |||
| @@ -14,6 +14,8 @@ | |||
| 14 | struct ocores_i2c_platform_data { | 14 | struct ocores_i2c_platform_data { |
| 15 | u32 regstep; /* distance between registers */ | 15 | u32 regstep; /* distance between registers */ |
| 16 | u32 clock_khz; /* input clock in kHz */ | 16 | u32 clock_khz; /* input clock in kHz */ |
| 17 | u8 num_devices; /* number of devices in the devices list */ | ||
| 18 | struct i2c_board_info const *devices; /* devices connected to the bus */ | ||
| 17 | }; | 19 | }; |
| 18 | 20 | ||
| 19 | #endif /* _LINUX_I2C_OCORES_H */ | 21 | #endif /* _LINUX_I2C_OCORES_H */ |
