On Wed, 30 Sep 2015, Qais Yousef wrote:

> On 09/29/2015 09:48 PM, Thomas Gleixner wrote:
> > 
> >      Now how these hwirqs are allocated is a domain/architecture
> >      specific issue.
> > 
> >      x86 will just find a vector which is available on all target
> >      cpus and mark it as used. That's a single hw irq number.
> > 
> >      mips and others, which implement IPIs as regular hw interrupt
> >      numbers, will allocate a these (consecutive) hw interrupt
> >      numbers either from a reserved region or just from the
> >      regular space. That's a bunch of hw irq numbers and we need
> >      to come up with a proper storage format in the irqdata for
> >      that. That might be
> > 
> >            struct ipi_mapping {
> >                   unsigned int      nr_hwirqs;
> >                   unsigned int      cpumap[NR_CPUS];
> >            };
> 
> Can we use NR_CPUS here? If we run in UP configuration for instance, this will
> be one. The coprocessor could be outside the NR_CPUS range in general, no?
> 
> How about
> 
>                         struct ipi_mapping {
>                                 unsigned int        nr_hwirqs;
>                                 unsigned int        nr_cpus;
>                                 unsigned int        *cpumap;
>                         }
> 
> where cpumap is dynamically allocated by the controller which has better
> knowledge about the supported cpu range it can talk to?

Sure. As I said: 'That might be' ....
 
Thanks,

        tglx
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to