AM64x MCU+ SDK  10.01.00
QoS

Majority of the initiator has a dedicated QoS block to provide the configurability of the transaction characteristic, such as orderID, priority/epriority, asel and etc. OrderID is a 4 bits value, which is associated with each transaction. By default, all the transactions have orderID value set to 0x0. The orderID is used as a mechanism to load balance the traffic to DDR through two parallel paths. The transactions with order ID 0-7 share one path, while transactions with 8-15 share a separate path. The OrderID value can be changed through QoS block for the initiators or through BCDMA and pktDMA configuration.

Each transaction in the system carries 3 bits priority information. The priority information is used for cbass for arbitration decision, which implements typical priority based round robin. Priority value 0x0 is the highest priority, while 0x7 is the lowest priority. By default, QoS has priority value set to 0x7( lowest priority).

Refer to the QoS programming guide in the SoC Technical Reference Manual(TRM) for more details.

Features Supported

  • Setup the QoS with the given configuration data.

SysConfig Features

Note
It is strongly recommend to use SysConfig where it is available instead of using direct SW API calls. This will help simplify the SW application and also catch common mistakes early in the development cycle.
  • Option to specify the QoS config generated using the "K3 Resource Partitioning" tool

Features not Supported

NA

Creating your own QoS config file

Step 1: Generate a QoS config file

  • QoS config file can be generated using the k3-resource-partitioning tool available in the ${SDK_INSALL_PATH}/tools/sysfw/boardcfg/respart/am64x/k3-respart-tool-0.5 directory directory.
  • Open the SysConfig tool GUI from the desktop shortcut and select the software product by navigating to the k3-resource-partitioning tool path in the SDK.
  • Click on Browse button and open the existing syscfg file at ${SDK_INSTALL_PATH}/tools/sysfw/boardcfg/respart/am64x/k3-respart-tool-0.5/out directory.

K3-Resource-Partitioning tool
  • Add the required number of QoS module instances and configure the parameters.
  • Select a device, choose the endpoints, and select a list of channels for which QoS should be programmed.
  • Note that it is possible to add multiple instances of QoS module with same device as long as the endpoints and channels do not overlap.
  • The tool will generate a am64x_qos_data.c file.

Configure the QoS
  • The QoS data generated can to be replaced in the default qos_data.h file located in the ${SDK_INSALL_PATH}/source/drivers/qos/v0/soc/am64x/ directory.
  • Copy the contents of the am64x_qos_data structure in the am64x_qos_data.c file and replace it in the gQosData structure of the qos_data.h file.
  • Or you can create a new copy of qos_data.h file and replace in it.

Copy the QoS data
  • Save the generated am64x_qos_data.c in your project workspace or work area if required.

Step 2: Add the generated QoS config file to your project

Add QoS via SysConfig
  • If you have created a new qos_data.h file, specify the path to your file including the filename in the sysconfig text box as shown above
    • Make sure to use forward slash "/" in the file path so that this will work with linux as well as windows build
    • Make sure that path to this is file set in your application include path, as needed.
  • Save the sysconfig project and build your application

Important Usage Guidelines

  • Priority, orderID and asel value from the QoS block shall only be modified as part of the initialization steps, when the SoC is idle.
  • Changing the QoS block configuration during the run time is prohibited and may cause system error or other undefined behavior. Hence it is recommended to do the QoS configuration in the bootloader(SBL).

Example Usage

Include the below file to access the APIs

#include <drivers/qos.h>
/* QoS configuration data file */
#include "drivers/qos/v0/soc/am64x/qos_data.h"

QoS initialization example

QOS_init(gQosData, gQosCount);

API

APIs for QoS

qos.h
QOS_init
void QOS_init(QOS_Config *qosData, uint32_t qosCount)
QoS Initialization function.