]> Pileus Git - ~andy/linux/commitdiff
MFD: twl6040: Use resource to provide irq number for slaves
authorPeter Ujfalusi <peter.ujfalusi@ti.com>
Tue, 5 Jul 2011 08:40:33 +0000 (11:40 +0300)
committerPeter Ujfalusi <peter.ujfalusi@ti.com>
Thu, 7 Jul 2011 11:23:10 +0000 (14:23 +0300)
Provide the irq number for slaves via resource on the
platform device.
The irq number configuration is done in the twl6040-core
at probe time, so machine drivers do not need to be
modified.

Signed-off-by: Peter Ujfalusi <peter.ujfalusi@ti.com>
Reviewed-by: Felipe Balbi <balbi@ti.com>
Acked-by: Samuel Ortiz <sameo@linux.intel.com>
drivers/mfd/twl6040-core.c

index cfaedb5581adf5323f5ac86868d1fefb03f1e51f..471f4895fb9089b490f406aaed35d10d72ef9d7e 100644 (file)
@@ -435,6 +435,18 @@ unsigned int twl6040_get_sysclk(struct twl6040 *twl6040)
 }
 EXPORT_SYMBOL(twl6040_get_sysclk);
 
+static struct resource twl6040_vibra_rsrc[] = {
+       {
+               .flags = IORESOURCE_IRQ,
+       },
+};
+
+static struct resource twl6040_codec_rsrc[] = {
+       {
+               .flags = IORESOURCE_IRQ,
+       },
+};
+
 static int __devinit twl6040_probe(struct platform_device *pdev)
 {
        struct twl4030_audio_data *pdata = pdev->dev.platform_data;
@@ -499,16 +511,29 @@ static int __devinit twl6040_probe(struct platform_device *pdev)
        twl6040_set_bits(twl6040, TWL6040_REG_ACCCTL, TWL6040_I2CSEL);
 
        if (pdata->codec) {
+               int irq = twl6040->irq_base + TWL6040_IRQ_PLUG;
+
                cell = &twl6040->cells[children];
                cell->name = "twl6040-codec";
+               twl6040_codec_rsrc[0].start = irq;
+               twl6040_codec_rsrc[0].end = irq;
+               cell->resources = twl6040_codec_rsrc;
+               cell->num_resources = ARRAY_SIZE(twl6040_codec_rsrc);
                cell->platform_data = pdata->codec;
                cell->pdata_size = sizeof(*pdata->codec);
                children++;
        }
 
        if (pdata->vibra) {
+               int irq = twl6040->irq_base + TWL6040_IRQ_VIB;
+
                cell = &twl6040->cells[children];
                cell->name = "twl6040-vibra";
+               twl6040_vibra_rsrc[0].start = irq;
+               twl6040_vibra_rsrc[0].end = irq;
+               cell->resources = twl6040_vibra_rsrc;
+               cell->num_resources = ARRAY_SIZE(twl6040_vibra_rsrc);
+
                cell->platform_data = pdata->vibra;
                cell->pdata_size = sizeof(*pdata->vibra);
                children++;