// SPDX-License-Identifier: GPL-2.0
/*
* Copyright (C) 2019 Texas Instruments Incorporated - http://www.ti.com
* Author: Peter Ujfalusi <peter.ujfalusi@ti.com>
*/
#include <linux/kernel.h>
#include "k3-psil-priv.h"
#define PSIL_PDMA_XY_TR(x) \
{ \
.thread_id = x, \
.ep_config = { \
.ep_type = PSIL_EP_PDMA_XY, \
}, \
}
#define PSIL_PDMA_XY_PKT(x) \
{ \
.thread_id = x, \
.ep_config = { \
.ep_type = PSIL_EP_PDMA_XY, \
.pkt_mode =
1 , \
}, \
}
#define PSIL_ETHERNET(x) \
{ \
.thread_id = x, \
.ep_config = { \
.ep_type = PSIL_EP_NATIVE, \
.pkt_mode =
1 , \
.needs_epib =
1 , \
.psd_size =
16 , \
}, \
}
#define PSIL_SA2UL(x, tx) \
{ \
.thread_id = x, \
.ep_config = { \
.ep_type = PSIL_EP_NATIVE, \
.pkt_mode =
1 , \
.needs_epib =
1 , \
.psd_size =
64 , \
.notdpkt = tx, \
}, \
}
/* PSI-L source thread IDs, used for RX (DMA_DEV_TO_MEM) */
static struct psil_ep am654_src_ep_map[] = {
/* SA2UL */
PSIL_SA2UL(
0 x4000,
0 ),
PSIL_SA2UL(
0 x4001,
0 ),
PSIL_SA2UL(
0 x4002,
0 ),
PSIL_SA2UL(
0 x4003,
0 ),
/* PRU_ICSSG0 */
PSIL_ETHERNET(
0 x4100),
PSIL_ETHERNET(
0 x4101),
PSIL_ETHERNET(
0 x4102),
PSIL_ETHERNET(
0 x4103),
/* PRU_ICSSG1 */
PSIL_ETHERNET(
0 x4200),
PSIL_ETHERNET(
0 x4201),
PSIL_ETHERNET(
0 x4202),
PSIL_ETHERNET(
0 x4203),
/* PRU_ICSSG2 */
PSIL_ETHERNET(
0 x4300),
PSIL_ETHERNET(
0 x4301),
PSIL_ETHERNET(
0 x4302),
PSIL_ETHERNET(
0 x4303),
/* PDMA0 - McASPs */
PSIL_PDMA_XY_TR(
0 x4400),
PSIL_PDMA_XY_TR(
0 x4401),
PSIL_PDMA_XY_TR(
0 x4402),
/* PDMA1 - SPI0-4 */
PSIL_PDMA_XY_PKT(
0 x4500),
PSIL_PDMA_XY_PKT(
0 x4501),
PSIL_PDMA_XY_PKT(
0 x4502),
PSIL_PDMA_XY_PKT(
0 x4503),
PSIL_PDMA_XY_PKT(
0 x4504),
PSIL_PDMA_XY_PKT(
0 x4505),
PSIL_PDMA_XY_PKT(
0 x4506),
PSIL_PDMA_XY_PKT(
0 x4507),
PSIL_PDMA_XY_PKT(
0 x4508),
PSIL_PDMA_XY_PKT(
0 x4509),
PSIL_PDMA_XY_PKT(
0 x450a),
PSIL_PDMA_XY_PKT(
0 x450b),
PSIL_PDMA_XY_PKT(
0 x450c),
PSIL_PDMA_XY_PKT(
0 x450d),
PSIL_PDMA_XY_PKT(
0 x450e),
PSIL_PDMA_XY_PKT(
0 x450f),
PSIL_PDMA_XY_PKT(
0 x4510),
PSIL_PDMA_XY_PKT(
0 x4511),
PSIL_PDMA_XY_PKT(
0 x4512),
PSIL_PDMA_XY_PKT(
0 x4513),
/* PDMA1 - USART0-2 */
PSIL_PDMA_XY_PKT(
0 x4514),
PSIL_PDMA_XY_PKT(
0 x4515),
PSIL_PDMA_XY_PKT(
0 x4516),
/* CPSW0 */
PSIL_ETHERNET(
0 x7000),
/* MCU_PDMA0 - ADCs */
PSIL_PDMA_XY_TR(
0 x7100),
PSIL_PDMA_XY_TR(
0 x7101),
PSIL_PDMA_XY_TR(
0 x7102),
PSIL_PDMA_XY_TR(
0 x7103),
/* MCU_PDMA1 - MCU_SPI0-2 */
PSIL_PDMA_XY_PKT(
0 x7200),
PSIL_PDMA_XY_PKT(
0 x7201),
PSIL_PDMA_XY_PKT(
0 x7202),
PSIL_PDMA_XY_PKT(
0 x7203),
PSIL_PDMA_XY_PKT(
0 x7204),
PSIL_PDMA_XY_PKT(
0 x7205),
PSIL_PDMA_XY_PKT(
0 x7206),
PSIL_PDMA_XY_PKT(
0 x7207),
PSIL_PDMA_XY_PKT(
0 x7208),
PSIL_PDMA_XY_PKT(
0 x7209),
PSIL_PDMA_XY_PKT(
0 x720a),
PSIL_PDMA_XY_PKT(
0 x720b),
/* MCU_PDMA1 - MCU_USART0 */
PSIL_PDMA_XY_PKT(
0 x7212),
};
/* PSI-L destination thread IDs, used for TX (DMA_MEM_TO_DEV) */
static struct psil_ep am654_dst_ep_map[] = {
/* SA2UL */
PSIL_SA2UL(
0 xc000,
1 ),
PSIL_SA2UL(
0 xc001,
1 ),
/* PRU_ICSSG0 */
PSIL_ETHERNET(
0 xc100),
PSIL_ETHERNET(
0 xc101),
PSIL_ETHERNET(
0 xc102),
PSIL_ETHERNET(
0 xc103),
PSIL_ETHERNET(
0 xc104),
PSIL_ETHERNET(
0 xc105),
PSIL_ETHERNET(
0 xc106),
PSIL_ETHERNET(
0 xc107),
/* PRU_ICSSG1 */
PSIL_ETHERNET(
0 xc200),
PSIL_ETHERNET(
0 xc201),
PSIL_ETHERNET(
0 xc202),
PSIL_ETHERNET(
0 xc203),
PSIL_ETHERNET(
0 xc204),
PSIL_ETHERNET(
0 xc205),
PSIL_ETHERNET(
0 xc206),
PSIL_ETHERNET(
0 xc207),
/* PRU_ICSSG2 */
PSIL_ETHERNET(
0 xc300),
PSIL_ETHERNET(
0 xc301),
PSIL_ETHERNET(
0 xc302),
PSIL_ETHERNET(
0 xc303),
PSIL_ETHERNET(
0 xc304),
PSIL_ETHERNET(
0 xc305),
PSIL_ETHERNET(
0 xc306),
PSIL_ETHERNET(
0 xc307),
/* CPSW0 */
PSIL_ETHERNET(
0 xf000),
PSIL_ETHERNET(
0 xf001),
PSIL_ETHERNET(
0 xf002),
PSIL_ETHERNET(
0 xf003),
PSIL_ETHERNET(
0 xf004),
PSIL_ETHERNET(
0 xf005),
PSIL_ETHERNET(
0 xf006),
PSIL_ETHERNET(
0 xf007),
};
struct psil_ep_map am654_ep_map = {
.name =
"am654" ,
.src = am654_src_ep_map,
.src_count = ARRAY_SIZE(am654_src_ep_map),
.dst = am654_dst_ep_map,
.dst_count = ARRAY_SIZE(am654_dst_ep_map),
};
Messung V0.5 in Prozent C=95 H=95 G=94
¤ Dauer der Verarbeitung: 0.11 Sekunden
(vorverarbeitet am 2026-06-07)
¤
*© Formatika GbR, Deutschland