[PATCH v3 3/4] arm_ffa: introduce Arm FF-A low-level driver

Simon Glass sjg at chromium.org
Tue Nov 22 23:24:30 CET 2022


Hi Abdellatif,

On Tue, 22 Nov 2022 at 06:50, Abdellatif El Khlifi
<abdellatif.elkhlifi at arm.com> wrote:
>
> On Fri, Nov 18, 2022 at 01:50:26PM -0700, Simon Glass wrote:
> > Hi,
> >
> > On Wed, 16 Nov 2022 at 06:03, Abdellatif El Khlifi
> > <abdellatif.elkhlifi at arm.com> wrote:
> > >
> > > On Tue, Nov 15, 2022 at 08:24:24AM -0700, Simon Glass wrote:
> > > > Hi,
> > > >
> > > > On Mon, 1 Aug 2022 at 11:21, Abdellatif El Khlifi
> > > > <abdellatif.elkhlifi at arm.com> wrote:
> > > > >
> > > > > Add the driver implementing Arm Firmware Framework for Armv8-A v1.0
> > > > >
> > > > > The Firmware Framework for Arm A-profile processors (FF-A)
> > > > > describes interfaces (ABIs) that standardize communication
> > > > > between the Secure World and Normal World leveraging TrustZone
> > > > > technology.
> > > > >
> > > > > This driver uses 64-bit registers as per SMCCCv1.2 spec and comes
> > > > > on top of the SMCCC layer. The driver provides the FF-A ABIs needed for
> > > > > querying the FF-A framework from the secure world.
> > > > >
> > > > > 32-bit version of the ABIs is supported and 64-bit version of FFA_RXTX_MAP
> > > > > and FFA_MSG_SEND_DIRECT_{REQ, RESP}.
> > > > >
> > > > > In u-boot FF-A design, FF-A is considered as a discoverable bus.
> > > > > The Secure World is considered as one entity to communicate with
> > > > > using the FF-A bus. FF-A communication is handled by one device and
> > > > > one instance (the bus). This FF-A driver takes care of all the
> > > > > interactions between Normal world and Secure World.
> > > > >
> > > > > The driver exports its operations to be used by upper layers.
> > > > >
> > > > > Exported operations:
> > > > >
> > > > > - partition_info_get
> > > > > - sync_send_receive
> > > > > - rxtx_unmap
> > > > >
> > > > > This implementation provides an optional feature to copy the driver data
> > > > > to EFI runtime area.
> > > > >
> > > > > Signed-off-by: Abdellatif El Khlifi <abdellatif.elkhlifi at arm.com>
> > > > > Cc: Tom Rini <trini at konsulko.com>
> > > > > Cc: Ilias Apalodimas <ilias.apalodimas at linaro.org>
> > > > > Cc: Jens Wiklander <jens.wiklander at linaro.org>
> > > > > ---
> > > > >  MAINTAINERS                                |    6 +
> > > > >  common/board_r.c                           |    7 +
> > > > >  drivers/Kconfig                            |    2 +
> > > > >  drivers/Makefile                           |    1 +
> > > > >  drivers/arm-ffa/Kconfig                    |   33 +
> > > > >  drivers/arm-ffa/Makefile                   |    7 +
> > > > >  drivers/arm-ffa/arm-ffa-uclass.c           |   16 +
> > > > >  drivers/arm-ffa/arm_ffa_prv.h              |  219 ++++
> > > > >  drivers/arm-ffa/core.c                     | 1338 ++++++++++++++++++++
> > > > >  drivers/arm-ffa/efi_ffa_runtime_data_mgr.c |   94 ++
> > > > >  include/arm_ffa.h                          |  132 ++
> > > > >  include/dm/uclass-id.h                     |    1 +
> > > > >  include/uuid.h                             |    8 +
> > > > >  lib/efi_loader/efi_boottime.c              |   17 +
> > > > >  lib/uuid.c                                 |   65 +
> > > > >  15 files changed, 1946 insertions(+)
> > > > >  create mode 100644 drivers/arm-ffa/Kconfig
> > > > >  create mode 100644 drivers/arm-ffa/Makefile
> > > > >  create mode 100644 drivers/arm-ffa/arm-ffa-uclass.c
> > > > >  create mode 100644 drivers/arm-ffa/arm_ffa_prv.h
> > > > >  create mode 100644 drivers/arm-ffa/core.c
> > > > >  create mode 100644 drivers/arm-ffa/.c
> > > > >  create mode 100644 include/arm_ffa.h
> > > >

[..]

> > OK
> >
> > > - The driver is independent from EFI and can be compiled without EFI
> >
> > Oh, so what is ffa_copy_runtime_data() for?
>
> This has already been dropped in newer versions of the pachset. Could you please refer to the latest ? (v8)

OK I will take a look at the latest.

> >
> > > - FF-A bus discovery has been removed from the initcall level (board_r.c)
> >
> > Good.
> >
> > >   Discovery is done on demand. Clients can call ffa_bus_discover() when
> > >   they want to use the FF-A bus. As an example of how clients initiate
> > >   discovery please refer to the FF-A MM comms client [3].
> >
> > Is there a command to do this?
>
> If you mean whether there is a command to showcase this, yes.
>
> I already created the armffa command as an example of how to use the FF-A bus
> and how clients can discover it.
>
> Please refer to this commit [1].
>
> [1]: https://lore.kernel.org/all/20221122131751.22747-6-abdellatif.elkhlifi@arm.com/
>
> >
> > > - As done in the Linux kernel, the FF-A bus doesn't have a device tree
> > >   binding since there is no peripheral associated with FF-A. At the
> > >   early stages of this patchset, we double checked with the device tree
> > >   maintainer and the decision was no device tree for FF-A
> >
> > Sorry, but you must add one.
>
> We had a discussion on this on April 2022 with Rob Herring. We decided to do
> the same as the FF-A kernel driver: no device tree, we perform a manual bus discovery.
>
> Rob Herring stated the following:
>
> - There is not a 'kernel device tree' and a 'u-boot device tree'. There is only 1
> - The FFA DT binding was rejected in favor of making FFA discoverable.
>    The FFA spec was amended to address that. DT is only for what we
>    failed to make discoverable. For hardware, we're stuck with it. We
>    shouldn't repeat that for software interfaces.

OK. Rob and I will need to discuss this, but in the meantime, we
should hold off on this series.

I am certainly not saying there should be two device trees. But there
needs to be a binding for this thing.

>
> For more details please refer to [1].
>
> [1]: https://lore.kernel.org/all/CAL_Jsq+dwHqwDdALTAwU-VYW2=2kYCyHpv7mUP0zR04CwH101Q@mail.gmail.com/
>
> >
> > > - The links below are from the U-Boot mailing list mirror in lore.kernel.org
> >
> > Regards,
> > Simon
> >
> >
> > >
> > > Cheers.
> > >
> > > [1]: https://lore.kernel.org/all/20221107192055.21669-1-abdellatif.elkhlifi@arm.com/
> > > [2]: https://lore.kernel.org/all/20221107192055.21669-7-abdellatif.elkhlifi@arm.com/
> > >      https://lore.kernel.org/all/20221107192055.21669-8-abdellatif.elkhlifi@arm.com/
> > >      https://lore.kernel.org/all/20221107192055.21669-9-abdellatif.elkhlifi@arm.com/
> > > [3]: https://lore.kernel.org/all/20221107192055.21669-10-abdellatif.elkhlifi@arm.com/
> > > >
> > > > Regards,
> > > > Simon

Regards,
Simon


More information about the U-Boot mailing list