mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-27 09:26:23 +07:00
8c6bb62f6b
In K3 architecture the DMA operates within threads. One end of the thread is UDMAP, the other is on the peripheral side. The UDMAP channel configuration depends on the needs of the remote endpoint and it can be differ from peripheral to peripheral. This patch adds database for am654 and j721e and small API to fetch the PSI-L endpoint configuration from the database which should only used by the DMA driver(s). Another API is added for native peripherals to give possibility to pass new configuration for the threads they are using, which is needed to be able to handle changes caused by different firmware loaded for the peripheral for example. Signed-off-by: Peter Ujfalusi <peter.ujfalusi@ti.com> Tested-by: Keerthy <j-keerthy@ti.com> Reviewed-by: Grygorii Strashko <grygorii.strashko@ti.com> Link: https://lore.kernel.org/r/20191223110458.30766-9-peter.ujfalusi@ti.com Signed-off-by: Vinod Koul <vkoul@kernel.org>
72 lines
1.7 KiB
C
72 lines
1.7 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Copyright (C) 2019 Texas Instruments Incorporated - http://www.ti.com
|
|
*/
|
|
|
|
#ifndef K3_PSIL_H_
|
|
#define K3_PSIL_H_
|
|
|
|
#include <linux/types.h>
|
|
|
|
#define K3_PSIL_DST_THREAD_ID_OFFSET 0x8000
|
|
|
|
struct device;
|
|
|
|
/**
|
|
* enum udma_tp_level - Channel Throughput Levels
|
|
* @UDMA_TP_NORMAL: Normal channel
|
|
* @UDMA_TP_HIGH: High Throughput channel
|
|
* @UDMA_TP_ULTRAHIGH: Ultra High Throughput channel
|
|
*/
|
|
enum udma_tp_level {
|
|
UDMA_TP_NORMAL = 0,
|
|
UDMA_TP_HIGH,
|
|
UDMA_TP_ULTRAHIGH,
|
|
UDMA_TP_LAST,
|
|
};
|
|
|
|
/**
|
|
* enum psil_endpoint_type - PSI-L Endpoint type
|
|
* @PSIL_EP_NATIVE: Normal channel
|
|
* @PSIL_EP_PDMA_XY: XY mode PDMA
|
|
* @PSIL_EP_PDMA_MCAN: MCAN mode PDMA
|
|
* @PSIL_EP_PDMA_AASRC: AASRC mode PDMA
|
|
*/
|
|
enum psil_endpoint_type {
|
|
PSIL_EP_NATIVE = 0,
|
|
PSIL_EP_PDMA_XY,
|
|
PSIL_EP_PDMA_MCAN,
|
|
PSIL_EP_PDMA_AASRC,
|
|
};
|
|
|
|
/**
|
|
* struct psil_endpoint_config - PSI-L Endpoint configuration
|
|
* @ep_type: PSI-L endpoint type
|
|
* @pkt_mode: If set, the channel must be in Packet mode, otherwise in
|
|
* TR mode
|
|
* @notdpkt: TDCM must be suppressed on the TX channel
|
|
* @needs_epib: Endpoint needs EPIB
|
|
* @psd_size: If set, PSdata is used by the endpoint
|
|
* @channel_tpl: Desired throughput level for the channel
|
|
* @pdma_acc32: ACC32 must be enabled on the PDMA side
|
|
* @pdma_burst: BURST must be enabled on the PDMA side
|
|
*/
|
|
struct psil_endpoint_config {
|
|
enum psil_endpoint_type ep_type;
|
|
|
|
unsigned pkt_mode:1;
|
|
unsigned notdpkt:1;
|
|
unsigned needs_epib:1;
|
|
u32 psd_size;
|
|
enum udma_tp_level channel_tpl;
|
|
|
|
/* PDMA properties, valid for PSIL_EP_PDMA_* */
|
|
unsigned pdma_acc32:1;
|
|
unsigned pdma_burst:1;
|
|
};
|
|
|
|
int psil_set_new_ep_config(struct device *dev, const char *name,
|
|
struct psil_endpoint_config *ep_config);
|
|
|
|
#endif /* K3_PSIL_H_ */
|