RE: [EXT] Re: [PATCH] bus: fsl-mc: Add ACPI support for fsl-mc

From: Pankaj Bansal (OSS)
Date: Tue Feb 18 2020 - 03:02:47 EST




> -----Original Message-----
> From: Lorenzo Pieralisi <lorenzo.pieralisi@xxxxxxx>
> Sent: Monday, February 17, 2020 8:55 PM
> To: Pankaj Bansal <pankaj.bansal@xxxxxxx>
> Cc: Marc Zyngier <maz@xxxxxxxxxx>; Ard Biesheuvel
> <ard.biesheuvel@xxxxxxxxxx>; Makarand Pawagi <makarand.pawagi@xxxxxxx>;
> Calvin Johnson <calvin.johnson@xxxxxxx>; stuyoder@xxxxxxxxx;
> nleeder@xxxxxxxxxxxxxx; Ioana Ciornei <ioana.ciornei@xxxxxxx>; Cristi
> Sovaiala <cristian.sovaiala@xxxxxxx>; Hanjun Guo <guohanjun@xxxxxxxxxx>;
> Will Deacon <will@xxxxxxxxxx>; jon@xxxxxxxxxxxxx; Russell King
> <linux@xxxxxxxxxxxxxxx>; ACPI Devel Maling List <linux-acpi@xxxxxxxxxxxxxxx>;
> Len Brown <lenb@xxxxxxxxxx>; Jason Cooper <jason@xxxxxxxxxxxxxx>; Andy
> Wang <Andy.Wang@xxxxxxx>; Varun Sethi <V.Sethi@xxxxxxx>; Thomas
> Gleixner <tglx@xxxxxxxxxxxxx>; linux-arm-kernel <linux-arm-
> kernel@xxxxxxxxxxxxxxxxxxx>; Laurentiu Tudor <laurentiu.tudor@xxxxxxx>; Paul
> Yang <Paul.Yang@xxxxxxx>; netdev@xxxxxxxxxxxxxxx; Rafael J. Wysocki
> <rjw@xxxxxxxxxxxxx>; Linux Kernel Mailing List <linux-kernel@xxxxxxxxxxxxxxx>;
> Shameerali Kolothum Thodi <shameerali.kolothum.thodi@xxxxxxxxxx>;
> Sudeep Holla <sudeep.holla@xxxxxxx>; Robin Murphy
> <robin.murphy@xxxxxxx>
> Subject: Re: [EXT] Re: [PATCH] bus: fsl-mc: Add ACPI support for fsl-mc
>
> On Mon, Feb 17, 2020 at 12:35:12PM +0000, Pankaj Bansal wrote:
> >
> >
> > > -----Original Message-----
> > > From: Lorenzo Pieralisi <lorenzo.pieralisi@xxxxxxx>
> > > Sent: Friday, February 14, 2020 11:20 PM
> > > To: Pankaj Bansal <pankaj.bansal@xxxxxxx>
> > > Cc: Marc Zyngier <maz@xxxxxxxxxx>; Ard Biesheuvel
> > > <ard.biesheuvel@xxxxxxxxxx>; Makarand Pawagi
> <makarand.pawagi@xxxxxxx>;
> > > Calvin Johnson <calvin.johnson@xxxxxxx>; stuyoder@xxxxxxxxx;
> > > nleeder@xxxxxxxxxxxxxx; Ioana Ciornei <ioana.ciornei@xxxxxxx>; Cristi
> > > Sovaiala <cristian.sovaiala@xxxxxxx>; Hanjun Guo
> <guohanjun@xxxxxxxxxx>;
> > > Will Deacon <will@xxxxxxxxxx>; jon@xxxxxxxxxxxxx; Russell King
> > > <linux@xxxxxxxxxxxxxxx>; ACPI Devel Maling List <linux-
> acpi@xxxxxxxxxxxxxxx>;
> > > Len Brown <lenb@xxxxxxxxxx>; Jason Cooper <jason@xxxxxxxxxxxxxx>;
> Andy
> > > Wang <Andy.Wang@xxxxxxx>; Varun Sethi <V.Sethi@xxxxxxx>; Thomas
> > > Gleixner <tglx@xxxxxxxxxxxxx>; linux-arm-kernel <linux-arm-
> > > kernel@xxxxxxxxxxxxxxxxxxx>; Laurentiu Tudor <laurentiu.tudor@xxxxxxx>;
> Paul
> > > Yang <Paul.Yang@xxxxxxx>; netdev@xxxxxxxxxxxxxxx; Rafael J. Wysocki
> > > <rjw@xxxxxxxxxxxxx>; Linux Kernel Mailing List <linux-
> kernel@xxxxxxxxxxxxxxx>;
> > > Shameerali Kolothum Thodi <shameerali.kolothum.thodi@xxxxxxxxxx>;
> > > Sudeep Holla <sudeep.holla@xxxxxxx>; Robin Murphy
> > > <robin.murphy@xxxxxxx>
> > > Subject: Re: [EXT] Re: [PATCH] bus: fsl-mc: Add ACPI support for fsl-mc
> > >
> > > On Fri, Feb 14, 2020 at 04:35:10PM +0000, Pankaj Bansal wrote:
> > >
> > > [...]
> > >
> > > > > -----Original Message-----
> > > > > From: Lorenzo Pieralisi <lorenzo.pieralisi@xxxxxxx>
> > > > > Sent: Friday, February 14, 2020 9:50 PM
> > > > > To: Pankaj Bansal <pankaj.bansal@xxxxxxx>
> > > > > Cc: Marc Zyngier <maz@xxxxxxxxxx>; Ard Biesheuvel
> > > > > <ard.biesheuvel@xxxxxxxxxx>; Makarand Pawagi
> > > <makarand.pawagi@xxxxxxx>;
> > > > > Calvin Johnson <calvin.johnson@xxxxxxx>; stuyoder@xxxxxxxxx;
> > > > > nleeder@xxxxxxxxxxxxxx; Ioana Ciornei <ioana.ciornei@xxxxxxx>; Cristi
> > > > > Sovaiala <cristian.sovaiala@xxxxxxx>; Hanjun Guo
> > > <guohanjun@xxxxxxxxxx>;
> > > > > Will Deacon <will@xxxxxxxxxx>; jon@xxxxxxxxxxxxx; Russell King
> > > > > <linux@xxxxxxxxxxxxxxx>; ACPI Devel Maling List <linux-
> > > acpi@xxxxxxxxxxxxxxx>;
> > > > > Len Brown <lenb@xxxxxxxxxx>; Jason Cooper <jason@xxxxxxxxxxxxxx>;
> > > Andy
> > > > > Wang <Andy.Wang@xxxxxxx>; Varun Sethi <V.Sethi@xxxxxxx>;
> Thomas
> > > > > Gleixner <tglx@xxxxxxxxxxxxx>; linux-arm-kernel <linux-arm-
> > > > > kernel@xxxxxxxxxxxxxxxxxxx>; Laurentiu Tudor
> <laurentiu.tudor@xxxxxxx>;
> > > Paul
> > > > > Yang <Paul.Yang@xxxxxxx>; netdev@xxxxxxxxxxxxxxx; Rafael J. Wysocki
> > > > > <rjw@xxxxxxxxxxxxx>; Linux Kernel Mailing List <linux-
> > > kernel@xxxxxxxxxxxxxxx>;
> > > > > Shameerali Kolothum Thodi <shameerali.kolothum.thodi@xxxxxxxxxx>;
> > > > > Sudeep Holla <sudeep.holla@xxxxxxx>; Robin Murphy
> > > > > <robin.murphy@xxxxxxx>
> > > > > Subject: Re: [EXT] Re: [PATCH] bus: fsl-mc: Add ACPI support for fsl-mc
> > > Side note: would you mind removing the email headers (as above) in your
> > > replies please ?
>
> Read the question above please.
>
> [...]
>
> > > > As stated above, in Linux MC is a bus (just like PCI bus, AMBA bus etc)
> > > > There can be multiple devices attached to this bus. Moreover, we can
> > > dynamically create/destroy these devices.
> > > > Now, we want to represent this BUS (not individual devices connected to
> bus)
> > > in IORT table.
> > > > The only possible way right now we see is that we describe it as Named
> > > components having a pool of ID mappings.
> > > > As and when devices are created and attached to bus, we sift through this
> pool
> > > to correctly determine the output ID for the device.
> > > > Now the input ID that we provide, can come from device itself.
> > > > Then we can use the Platform MSI framework for MC bus devices.
> > >
> > > So are you asking me if that's OK ? Or there is something you can't
> > > describe with IORT ?
> >
> > I am asking if that would be acceptable?
> > i.e. we represent MC bus as Named component is IORT table with a pool of IDs
> (without single ID mapping flag)
> > and then we use the Platform MSI framework for all children devices of MC
> bus.
> > Note that it would require the Platform MSI layer to correctly pass an input id
> for a platform device to IORT layer.
>
> How is this solved in DT ? You don't seem to need any DT binding on top
> of the msi-parent property, which is equivalent to IORT single mappings
> AFAICS so I would like to understand the whole DT flow (so that I
> understand how this FSL bus works) before commenting any further.

In DT case, we create the domain DOMAIN_BUS_FSL_MC_MSI for MC bus and it's children.
And then when MC child device is created, we search the "msi-parent" property from the MC
DT node and get the ITS associated with MC bus. Then we search DOMAIN_BUS_FSL_MC_MSI
on that ITS. Once we find the domain, we can call msi_domain_alloc_irqs for that domain.

This is exactly what we tried to do initially with ACPI. But the searching DOMAIN_BUS_FSL_MC_MSI
associated to an ITS, is something that is part of drivers/acpi/arm64/iort.c.
(similar to DOMAIN_BUS_PLATFORM_MSI and DOMAIN_BUS_PCI_MSI)

>
> > And IORT layer ought to retrieve the output id based on single ID mapping flag
> as well as input id.
> >
> > >
> > > Side note: can you explain to me please how the MSI allocation flow
> > > and kernel data structures/drivers are modeled in DT ? I had a quick
> > > look at:
> > >
> > > drivers/irqchip/irq-gic-v3-its-fsl-mc-msi.c
> > >
> > > and to start with, does that code imply that we create a
> > > DOMAIN_BUS_FSL_MC_MSI on ALL DT systems with an ITS device node ?
> >
> > Yes. It's being done for all DT systems having ITS node.
>
> This does not seem correct to me, I will let Marc comment on
> the matter.
>
> > The domain creation is handled in drivers/bus/fsl-mc/fsl-mc-msi.c
>
> Thanks,
> Lorenzo