[PATCH v10 18/18] OMAP2, 3: DSS2: Get DSS IRQ from platform device

Semwal, Sumit sumit.semwal at ti.com
Mon Feb 14 13:35:10 EST 2011


Hi,

On Mon, Feb 14, 2011 at 7:39 PM, Tomi Valkeinen <tomi.valkeinen at ti.com> wrote:
> Hi,
>
> On Mon, 2011-01-24 at 11:52 +0530, ext Sumit Semwal wrote:
>> From: Senthilvadivu Guruswamy <svadivu at ti.com>
>>
>> DSS IRQ number can be obtained from platform_get_irq().  This API in turn
>> picks the right IRQ number belonging to HW IP from the hwmod database.
>> So hardcoding of IRQ number could be removed.
>>
>> Reviewed-by: Paul Walmsley <paul at pwsan.com>
>> Reviewed-by: Kevin Hilman <khilman at ti.com>
>> Tested-by: Kevin Hilman <khilman at ti.com>
>> Signed-off-by: Senthilvadivu Guruswamy <svadivu at ti.com>
>> Signed-off-by: Sumit Semwal <sumit.semwal at ti.com>
>> ---
>>  drivers/video/omap2/dss/dss.c |   21 ++++++++++++++-------
>>  1 files changed, 14 insertions(+), 7 deletions(-)
>>
>> diff --git a/drivers/video/omap2/dss/dss.c b/drivers/video/omap2/dss/dss.c
>> index 4d7a816..f9390b4 100644
>> --- a/drivers/video/omap2/dss/dss.c
>> +++ b/drivers/video/omap2/dss/dss.c
>> @@ -563,7 +563,7 @@ void dss_set_dac_pwrdn_bgz(bool enable)
>>
>>  static int dss_init(bool skip_init)
>>  {
>> -     int r;
>> +     int r, dss_irq;
>>       u32 rev;
>>       struct resource *dss_mem;
>>
>> @@ -609,11 +609,18 @@ static int dss_init(bool skip_init)
>>       REG_FLD_MOD(DSS_CONTROL, 0, 2, 2);      /* venc clock mode = normal */
>>  #endif
>>
>> -     r = request_irq(INT_24XX_DSS_IRQ,
>> -                     cpu_is_omap24xx()
>> -                     ? dss_irq_handler_omap2
>> -                     : dss_irq_handler_omap3,
>> -                     0, "OMAP DSS", NULL);
>> +     dss_irq = platform_get_irq(dss.pdev, 0);
>> +     if (dss_irq < 0) {
>> +             DSSERR("omap2 dss: platform_get_irq failed\n");
>> +             r = -ENODEV;
>> +             goto fail1;
>> +     }
>> +
>> +     r = request_irq(dss_irq,
>> +             cpu_is_omap24xx()
>> +             ? dss_irq_handler_omap2
>> +             : dss_irq_handler_omap3,
>> +             0, "OMAP DSS", NULL);
>>
>>       if (r < 0) {
>>               DSSERR("omap2 dss: request_irq failed\n");
>> @@ -641,7 +648,7 @@ static int dss_init(bool skip_init)
>>       return 0;
>>
>>  fail2:
>> -     free_irq(INT_24XX_DSS_IRQ, NULL);
>> +     free_irq(dss_irq, NULL);
>
> You change this free_irq, as you should, but you missed another a few
> lines later.
>
> Archit fixes it in his "OMAP: DSS2: Common IRQ handler for all OMAPs"
> patch silently, but I think it should be fixed here already, as the
> patches haven't been pulled to anywhere yet.
>
> Perhaps you could use the same method as Archit used, create a new field
> "irq" in the dss struct which can be used in the dss_exit's free_irq
> call.
Yes, you're right; I guess since it was already in your tree by the
time we noticed this oversight, we assumed Archit could submit a new
one. I can send you an updated one tomorrow for this.

Regards,
~Sumit.
>
>  Tomi
>
>
>



More information about the linux-arm-kernel mailing list