mirror of
https://github.com/AsahiLinux/u-boot
synced 2025-01-02 08:18:57 +00:00
28e5e95bf8
Enable Quality of Service (QoS) blocks for Display SubSystem (DSS), by servicing the DSS - DDR traffic from the Real-Time (RT) queue. This is done by setting the DSS DMA orderID to 8. The C7x and VPAC have been overwhelming the DSS's access to the DDR (when it was accessing via the Non Real-Time (NRT) Queue), primarily because their functional frequencies, and hence DDR accesses, were significantly higher than that of DSS. This led the display to flicker when certain edgeAI models were being run. With the DSS traffic serviced from the RT queue, the flickering issue has been found to be mitigated. The am62a qos files are auto generated from the k3 resource partitioning tool. Section-3.1.12, "QoS Programming Guide", in the AM62A TRM[1], provides more information about the QoS, and section-14.1, "System Interconnect Registers", provides the register descriptions. [1] AM62A Tech Ref Manual: https://www.ti.com/lit/pdf/spruj16 Signed-off-by: Aradhya Bhatia <a-bhatia1@ti.com>
47 lines
1.2 KiB
C
47 lines
1.2 KiB
C
// SPDX-License-Identifier: GPL-2.0+
|
|
/*
|
|
* am62a Quality of Service (QoS) Configuration Data
|
|
* Auto generated from K3 Resource Partitioning tool
|
|
*
|
|
* Copyright (C) 2022 Texas Instruments Incorporated - https://www.ti.com/
|
|
*/
|
|
#include <common.h>
|
|
#include <asm/arch/hardware.h>
|
|
#include "common.h"
|
|
|
|
struct k3_qos_data am62a_qos_data[] = {
|
|
/* modules_qosConfig0 - 1 endpoints, 4 channels */
|
|
{
|
|
.reg = K3_DSS_UL_MAIN_0_VBUSM_DMA + 0x100 + 0x4 * 0,
|
|
.val = ORDERID_8,
|
|
},
|
|
{
|
|
.reg = K3_DSS_UL_MAIN_0_VBUSM_DMA + 0x100 + 0x4 * 1,
|
|
.val = ORDERID_8,
|
|
},
|
|
{
|
|
.reg = K3_DSS_UL_MAIN_0_VBUSM_DMA + 0x100 + 0x4 * 2,
|
|
.val = ORDERID_8,
|
|
},
|
|
{
|
|
.reg = K3_DSS_UL_MAIN_0_VBUSM_DMA + 0x100 + 0x4 * 3,
|
|
.val = ORDERID_8,
|
|
},
|
|
|
|
/* Following registers set 1:1 mapping for orderID MAP1/MAP2
|
|
* remap registers. orderID x is remapped to orderID x again
|
|
* This is to ensure orderID from MAP register is unchanged
|
|
*/
|
|
|
|
/* K3_DSS_UL_MAIN_0_VBUSM_DMA - 1 groups */
|
|
{
|
|
.reg = K3_DSS_UL_MAIN_0_VBUSM_DMA + 0,
|
|
.val = 0x76543210,
|
|
},
|
|
{
|
|
.reg = K3_DSS_UL_MAIN_0_VBUSM_DMA + 4,
|
|
.val = 0xfedcba98,
|
|
},
|
|
};
|
|
|
|
uint32_t am62a_qos_count = sizeof(am62a_qos_data) / sizeof(am62a_qos_data[0]);
|