On Thu, 2015-07-05 at 03:16:15 UTC, Alistair Popple wrote:
> diff --git a/arch/powerpc/platforms/powernv/opal.c 
> b/arch/powerpc/platforms/powernv/opal.c
> index 4399ff2..0196220 100644
> --- a/arch/powerpc/platforms/powernv/opal.c
> +++ b/arch/powerpc/platforms/powernv/opal.c
> @@ -362,33 +362,34 @@ static void opal_handle_message(void)
>       opal_message_do_notify(type, (void *)&msg);
>  }
>  
> -static int opal_message_notify(struct notifier_block *nb,
> -                       unsigned long events, void *change)
> +static irqreturn_t opal_message_notify(int irq, void *data)
>  {
> -     if (events & OPAL_EVENT_MSG_PENDING)
> -             opal_handle_message();
> -     return 0;
> +     opal_handle_message();
> +     return IRQ_HANDLED;
>  }
>  
> -static struct notifier_block opal_message_nb = {
> -     .notifier_call  = opal_message_notify,
> -     .next           = NULL,
> -     .priority       = 0,
> -};
> -
>  static int __init opal_message_init(void)
>  {
> -     int ret, i;
> +     int ret, i, irq;
>  
>       for (i = 0; i < OPAL_MSG_TYPE_MAX; i++)
>               ATOMIC_INIT_NOTIFIER_HEAD(&opal_msg_notifier_head[i]);
>  
> -     ret = opal_notifier_register(&opal_message_nb);
> +     irq = opal_event_request(ilog2(OPAL_EVENT_MSG_PENDING));
> +     if (!irq) {
> +             pr_err("%s: Can't register OPAL event irq (%d)\n",
> +                    __func__, irq);
> +             return irq;
> +     }


On mambo this is giving me:

  irq: XICS didn't like hwirq-0xb to VIRQ17 mapping (rc=-22)
  opal: opal_message_init: Can't register OPAL event irq (0)


Which suggests your irq domain is NULL and it's falling back to XICS?

And it never gets to userspace, which I guess is related, but might not be.

cheers
_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev

Reply via email to