On 5/9/2023 12:09 PM, Gupta, Nipun wrote:
> [AMD Official Use Only - General]
> 
> 
> 
>> -----Original Message-----
>> From: Xia, Chenbo <chenbo....@intel.com>
>> Sent: Tuesday, May 9, 2023 12:25 PM
>> To: Gupta, Nipun <nipun.gu...@amd.com>; dev@dpdk.org;
>> tho...@monjalon.net; david.march...@redhat.com
>> Cc: Yigit, Ferruh <ferruh.yi...@amd.com>; Anand, Harpreet
>> <harpreet.an...@amd.com>; Agarwal, Nikhil <nikhil.agar...@amd.com>
>> Subject: RE: [PATCH v4 1/4] bus/cdx: introduce cdx bus
>>
>> Caution: This message originated from an External Source. Use proper
>> caution when opening attachments, clicking links, or responding.
>>
>>
>>> -----Original Message-----
>>> From: Nipun Gupta <nipun.gu...@amd.com>
>>> Sent: Monday, May 8, 2023 7:18 PM
>>> To: dev@dpdk.org; tho...@monjalon.net; david.march...@redhat.com
>>> Cc: ferruh.yi...@amd.com; harpreet.an...@amd.com;
>> nikhil.agar...@amd.com;
>>> Nipun Gupta <nipun.gu...@amd.com>
>>> Subject: [PATCH v4 1/4] bus/cdx: introduce cdx bus
>>>
>>> CDX bus supports multiple type of devices, which can be
>>> exposed to user-space via vfio-cdx.
>>>
>>> vfio-cdx provides the MMIO IO_MEMORY regions as well as the
>>> DMA interface for the device (IOMMU).
>>>
>>> This support aims to enable the DPDK to support the cdx
>>> devices in user-space using VFIO interface.
>>>
>>> Signed-off-by: Nipun Gupta <nipun.gu...@amd.com>
>>> ---
>>>  MAINTAINERS                            |   5 +
>>>  doc/guides/rel_notes/release_23_07.rst |   6 +
>>>  drivers/bus/cdx/bus_cdx_driver.h       | 201 ++++++++++
>>>  drivers/bus/cdx/cdx.c                  | 520 +++++++++++++++++++++++++
>>>  drivers/bus/cdx/cdx_logs.h             |  37 ++
>>>  drivers/bus/cdx/cdx_vfio.c             | 437 +++++++++++++++++++++
>>>  drivers/bus/cdx/meson.build            |  13 +
>>>  drivers/bus/cdx/private.h              |  49 +++
>>>  drivers/bus/cdx/version.map            |  11 +
>>>  drivers/bus/meson.build                |   1 +
>>>  10 files changed, 1280 insertions(+)
>>>  create mode 100644 drivers/bus/cdx/bus_cdx_driver.h
>>>  create mode 100644 drivers/bus/cdx/cdx.c
>>>  create mode 100644 drivers/bus/cdx/cdx_logs.h
>>>  create mode 100644 drivers/bus/cdx/cdx_vfio.c
>>>  create mode 100644 drivers/bus/cdx/meson.build
>>>  create mode 100644 drivers/bus/cdx/private.h
>>>  create mode 100644 drivers/bus/cdx/version.map
>>>
>>
>> ...
>>
>>> --- /dev/null
>>> +++ b/drivers/bus/cdx/cdx.c
>>> @@ -0,0 +1,520 @@
>>> +/* SPDX-License-Identifier: BSD-3-Clause
>>> + * Copyright (C) 2022-2023, Advanced Micro Devices, Inc.
>>> + */
>>> +
>>> +/*
>>> + * Architecture Overview
>>> + * =====================
>>> + * CDX is a Hardware Architecture designed for AMD FPGA devices. It
>>> + * consists of sophisticated mechanism for interaction between FPGA,
>>> + * Firmware and the APUs (Application CPUs).
>>> + *
>>> + * Firmware resides on RPU (Realtime CPUs) which interacts with
>>> + * the FPGA program manager and the APUs. The RPU provides memory-
>> mapped
>>> + * interface (RPU if) which is used to communicate with APUs.
>>> + *
>>> + * The diagram below shows an overview of the CDX architecture:
>>> + *
>>> + *          +--------------------------------------+
>>> + *          |   DPDK                               |
>>> + *          |                    DPDK CDX drivers  |
>>> + *          |                             |        |
>>> + *          |                      DPDK CDX bus    |
>>> + *          |                             |        |
>>> + *          +-----------------------------|--------+
>>> + *                                        |
>>> + *          +-----------------------------|--------+
>>> + *          |    Application CPUs (APU)   |        |
>>> + *          |                             |        |
>>> + *          |                     VFIO CDX driver  |
>>> + *          |     Linux OS                |        |
>>> + *          |                      Linux CDX bus   |
>>> + *          |                             |        |
>>> + *          +-----------------------------|--------+
>>> + *                                        |
>>> + *                                        |
>>> + *          +------------------------| RPU if |----+
>>> + *          |                             |        |
>>> + *          |                             V        |
>>> + *          |          Realtime CPUs (RPU)         |
>>> + *          |                                      |
>>> + *          +--------------------------------------+
>>> + *                                |
>>> + *          +---------------------|----------------+
>>> + *          |  FPGA               |                |
>>> + *          |      +-----------------------+       |
>>> + *          |      |           |           |       |
>>> + *          | +-------+    +-------+   +-------+   |
>>> + *          | | dev 1 |    | dev 2 |   | dev 3 |   |
>>> + *          | +-------+    +-------+   +-------+   |
>>> + *          +--------------------------------------+
>>> + *
>>> + * The RPU firmware extracts the device information from the loaded
>> FPGA
>>> + * image and implements a mechanism that allows the APU drivers to
>>> + * enumerate such devices (device personality and resource details) via
>>> + * a dedicated communication channel.
>>
>> What is APU? CPU resources that application uses? Then why cpu resources
>> that DPDK
>> Uses are not part of it?
> 
> Hi Chenbo,
> 
> APU's are application processor unit and are on-chip CPU's. So in short APUs
> are CPUs only on which applications like DPDK are running.
> 

There are two sets of processing unit in the SoC. FW runs on RPU,
everything else runs on APU (Arm cores), including OS, DPDK etc..

Reply via email to