// SPDX-License-Identifier: GPL-2.0
/*
* Copyright (C) 2023 Texas Instruments Incorporated - https://www.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, \
.mapped_channel_id = -
1 , \
.default_flow_id = -
1 , \
}, \
}
#define PSIL_PDMA_XY_PKT(x) \
{ \
.thread_id = x, \
.ep_config = { \
.ep_type = PSIL_EP_PDMA_XY, \
.mapped_channel_id = -
1 , \
.default_flow_id = -
1 , \
.pkt_mode =
1 , \
}, \
}
#define PSIL_ETHERNET(x, ch, flow_base, flow_cnt) \
{ \
.thread_id = x, \
.ep_config = { \
.ep_type = PSIL_EP_NATIVE, \
.pkt_mode =
1 , \
.needs_epib =
1 , \
.psd_size =
16 , \
.mapped_channel_id = ch, \
.flow_start = flow_base, \
.flow_num = flow_cnt, \
.default_flow_id = flow_base, \
}, \
}
#define PSIL_SAUL(x, ch, flow_base, flow_cnt, default_flow, tx) \
{ \
.thread_id = x, \
.ep_config = { \
.ep_type = PSIL_EP_NATIVE, \
.pkt_mode =
1 , \
.needs_epib =
1 , \
.psd_size =
64 , \
.mapped_channel_id = ch, \
.flow_start = flow_base, \
.flow_num = flow_cnt, \
.default_flow_id = default_flow, \
.notdpkt = tx, \
}, \
}
#define PSIL_PDMA_MCASP(x) \
{ \
.thread_id = x, \
.ep_config = { \
.ep_type = PSIL_EP_PDMA_XY, \
.pdma_acc32 =
1 , \
.pdma_burst =
1 , \
}, \
}
#define PSIL_CSI2RX(x) \
{ \
.thread_id = x, \
.ep_config = { \
.ep_type = PSIL_EP_NATIVE, \
}, \
}
/* PSI-L source thread IDs, used for RX (DMA_DEV_TO_MEM) */
static struct psil_ep am62p_src_ep_map[] = {
/* SAUL */
PSIL_SAUL(
0 x7504,
20 ,
35 ,
8 ,
35 ,
0 ),
PSIL_SAUL(
0 x7505,
21 ,
35 ,
8 ,
36 ,
0 ),
PSIL_SAUL(
0 x7506,
22 ,
43 ,
8 ,
43 ,
0 ),
PSIL_SAUL(
0 x7507,
23 ,
43 ,
8 ,
44 ,
0 ),
/* PDMA_MAIN0 - SPI0-2 */
PSIL_PDMA_XY_PKT(
0 x4300),
PSIL_PDMA_XY_PKT(
0 x4301),
PSIL_PDMA_XY_PKT(
0 x4302),
PSIL_PDMA_XY_PKT(
0 x4303),
PSIL_PDMA_XY_PKT(
0 x4304),
PSIL_PDMA_XY_PKT(
0 x4305),
PSIL_PDMA_XY_PKT(
0 x4306),
PSIL_PDMA_XY_PKT(
0 x4307),
PSIL_PDMA_XY_PKT(
0 x4308),
PSIL_PDMA_XY_PKT(
0 x4309),
PSIL_PDMA_XY_PKT(
0 x430a),
PSIL_PDMA_XY_PKT(
0 x430b),
/* PDMA_MAIN1 - UART0-6 */
PSIL_PDMA_XY_PKT(
0 x4400),
PSIL_PDMA_XY_PKT(
0 x4401),
PSIL_PDMA_XY_PKT(
0 x4402),
PSIL_PDMA_XY_PKT(
0 x4403),
PSIL_PDMA_XY_PKT(
0 x4404),
PSIL_PDMA_XY_PKT(
0 x4405),
PSIL_PDMA_XY_PKT(
0 x4406),
/* PDMA_MAIN2 - MCASP0-2 */
PSIL_PDMA_MCASP(
0 x4500),
PSIL_PDMA_MCASP(
0 x4501),
PSIL_PDMA_MCASP(
0 x4502),
/* CPSW3G */
PSIL_ETHERNET(
0 x4600,
19 ,
19 ,
16 ),
/* CSI2RX */
PSIL_CSI2RX(
0 x5000),
PSIL_CSI2RX(
0 x5001),
PSIL_CSI2RX(
0 x5002),
PSIL_CSI2RX(
0 x5003),
PSIL_CSI2RX(
0 x5004),
PSIL_CSI2RX(
0 x5005),
PSIL_CSI2RX(
0 x5006),
PSIL_CSI2RX(
0 x5007),
PSIL_CSI2RX(
0 x5008),
PSIL_CSI2RX(
0 x5009),
PSIL_CSI2RX(
0 x500a),
PSIL_CSI2RX(
0 x500b),
PSIL_CSI2RX(
0 x500c),
PSIL_CSI2RX(
0 x500d),
PSIL_CSI2RX(
0 x500e),
PSIL_CSI2RX(
0 x500f),
PSIL_CSI2RX(
0 x5010),
PSIL_CSI2RX(
0 x5011),
PSIL_CSI2RX(
0 x5012),
PSIL_CSI2RX(
0 x5013),
PSIL_CSI2RX(
0 x5014),
PSIL_CSI2RX(
0 x5015),
PSIL_CSI2RX(
0 x5016),
PSIL_CSI2RX(
0 x5017),
PSIL_CSI2RX(
0 x5018),
PSIL_CSI2RX(
0 x5019),
PSIL_CSI2RX(
0 x501a),
PSIL_CSI2RX(
0 x501b),
PSIL_CSI2RX(
0 x501c),
PSIL_CSI2RX(
0 x501d),
PSIL_CSI2RX(
0 x501e),
PSIL_CSI2RX(
0 x501f),
PSIL_CSI2RX(
0 x5000),
PSIL_CSI2RX(
0 x5001),
PSIL_CSI2RX(
0 x5002),
PSIL_CSI2RX(
0 x5003),
PSIL_CSI2RX(
0 x5004),
PSIL_CSI2RX(
0 x5005),
PSIL_CSI2RX(
0 x5006),
PSIL_CSI2RX(
0 x5007),
PSIL_CSI2RX(
0 x5008),
PSIL_CSI2RX(
0 x5009),
PSIL_CSI2RX(
0 x500a),
PSIL_CSI2RX(
0 x500b),
PSIL_CSI2RX(
0 x500c),
PSIL_CSI2RX(
0 x500d),
PSIL_CSI2RX(
0 x500e),
PSIL_CSI2RX(
0 x500f),
PSIL_CSI2RX(
0 x5010),
PSIL_CSI2RX(
0 x5011),
PSIL_CSI2RX(
0 x5012),
PSIL_CSI2RX(
0 x5013),
PSIL_CSI2RX(
0 x5014),
PSIL_CSI2RX(
0 x5015),
PSIL_CSI2RX(
0 x5016),
PSIL_CSI2RX(
0 x5017),
PSIL_CSI2RX(
0 x5018),
PSIL_CSI2RX(
0 x5019),
PSIL_CSI2RX(
0 x501a),
PSIL_CSI2RX(
0 x501b),
PSIL_CSI2RX(
0 x501c),
PSIL_CSI2RX(
0 x501d),
PSIL_CSI2RX(
0 x501e),
PSIL_CSI2RX(
0 x501f),
/* CSIRX 1-3 (only for J722S) */
PSIL_CSI2RX(
0 x5100),
PSIL_CSI2RX(
0 x5101),
PSIL_CSI2RX(
0 x5102),
PSIL_CSI2RX(
0 x5103),
PSIL_CSI2RX(
0 x5104),
PSIL_CSI2RX(
0 x5105),
PSIL_CSI2RX(
0 x5106),
PSIL_CSI2RX(
0 x5107),
PSIL_CSI2RX(
0 x5108),
PSIL_CSI2RX(
0 x5109),
PSIL_CSI2RX(
0 x510a),
PSIL_CSI2RX(
0 x510b),
PSIL_CSI2RX(
0 x510c),
PSIL_CSI2RX(
0 x510d),
PSIL_CSI2RX(
0 x510e),
PSIL_CSI2RX(
0 x510f),
PSIL_CSI2RX(
0 x5110),
PSIL_CSI2RX(
0 x5111),
PSIL_CSI2RX(
0 x5112),
PSIL_CSI2RX(
0 x5113),
PSIL_CSI2RX(
0 x5114),
PSIL_CSI2RX(
0 x5115),
PSIL_CSI2RX(
0 x5116),
PSIL_CSI2RX(
0 x5117),
PSIL_CSI2RX(
0 x5118),
PSIL_CSI2RX(
0 x5119),
PSIL_CSI2RX(
0 x511a),
PSIL_CSI2RX(
0 x511b),
PSIL_CSI2RX(
0 x511c),
PSIL_CSI2RX(
0 x511d),
PSIL_CSI2RX(
0 x511e),
PSIL_CSI2RX(
0 x511f),
PSIL_CSI2RX(
0 x5200),
PSIL_CSI2RX(
0 x5201),
PSIL_CSI2RX(
0 x5202),
PSIL_CSI2RX(
0 x5203),
PSIL_CSI2RX(
0 x5204),
PSIL_CSI2RX(
0 x5205),
PSIL_CSI2RX(
0 x5206),
PSIL_CSI2RX(
0 x5207),
PSIL_CSI2RX(
0 x5208),
PSIL_CSI2RX(
0 x5209),
PSIL_CSI2RX(
0 x520a),
PSIL_CSI2RX(
0 x520b),
PSIL_CSI2RX(
0 x520c),
PSIL_CSI2RX(
0 x520d),
PSIL_CSI2RX(
0 x520e),
PSIL_CSI2RX(
0 x520f),
PSIL_CSI2RX(
0 x5210),
PSIL_CSI2RX(
0 x5211),
PSIL_CSI2RX(
0 x5212),
PSIL_CSI2RX(
0 x5213),
PSIL_CSI2RX(
0 x5214),
PSIL_CSI2RX(
0 x5215),
PSIL_CSI2RX(
0 x5216),
PSIL_CSI2RX(
0 x5217),
PSIL_CSI2RX(
0 x5218),
PSIL_CSI2RX(
0 x5219),
PSIL_CSI2RX(
0 x521a),
PSIL_CSI2RX(
0 x521b),
PSIL_CSI2RX(
0 x521c),
PSIL_CSI2RX(
0 x521d),
PSIL_CSI2RX(
0 x521e),
PSIL_CSI2RX(
0 x521f),
PSIL_CSI2RX(
0 x5300),
PSIL_CSI2RX(
0 x5301),
PSIL_CSI2RX(
0 x5302),
PSIL_CSI2RX(
0 x5303),
PSIL_CSI2RX(
0 x5304),
PSIL_CSI2RX(
0 x5305),
PSIL_CSI2RX(
0 x5306),
PSIL_CSI2RX(
0 x5307),
PSIL_CSI2RX(
0 x5308),
PSIL_CSI2RX(
0 x5309),
PSIL_CSI2RX(
0 x530a),
PSIL_CSI2RX(
0 x530b),
PSIL_CSI2RX(
0 x530c),
PSIL_CSI2RX(
0 x530d),
PSIL_CSI2RX(
0 x530e),
PSIL_CSI2RX(
0 x530f),
PSIL_CSI2RX(
0 x5310),
PSIL_CSI2RX(
0 x5311),
PSIL_CSI2RX(
0 x5312),
PSIL_CSI2RX(
0 x5313),
PSIL_CSI2RX(
0 x5314),
PSIL_CSI2RX(
0 x5315),
PSIL_CSI2RX(
0 x5316),
PSIL_CSI2RX(
0 x5317),
PSIL_CSI2RX(
0 x5318),
PSIL_CSI2RX(
0 x5319),
PSIL_CSI2RX(
0 x531a),
PSIL_CSI2RX(
0 x531b),
PSIL_CSI2RX(
0 x531c),
PSIL_CSI2RX(
0 x531d),
PSIL_CSI2RX(
0 x531e),
PSIL_CSI2RX(
0 x531f),
};
/* PSI-L destination thread IDs, used for TX (DMA_MEM_TO_DEV) */
static struct psil_ep am62p_dst_ep_map[] = {
/* SAUL */
PSIL_SAUL(
0 xf500,
27 ,
83 ,
8 ,
83 ,
1 ),
PSIL_SAUL(
0 xf501,
28 ,
91 ,
8 ,
91 ,
1 ),
/* PDMA_MAIN0 - SPI0-2 */
PSIL_PDMA_XY_PKT(
0 xc300),
PSIL_PDMA_XY_PKT(
0 xc301),
PSIL_PDMA_XY_PKT(
0 xc302),
PSIL_PDMA_XY_PKT(
0 xc303),
PSIL_PDMA_XY_PKT(
0 xc304),
PSIL_PDMA_XY_PKT(
0 xc305),
PSIL_PDMA_XY_PKT(
0 xc306),
PSIL_PDMA_XY_PKT(
0 xc307),
PSIL_PDMA_XY_PKT(
0 xc308),
PSIL_PDMA_XY_PKT(
0 xc309),
PSIL_PDMA_XY_PKT(
0 xc30a),
PSIL_PDMA_XY_PKT(
0 xc30b),
/* PDMA_MAIN1 - UART0-6 */
PSIL_PDMA_XY_PKT(
0 xc400),
PSIL_PDMA_XY_PKT(
0 xc401),
PSIL_PDMA_XY_PKT(
0 xc402),
PSIL_PDMA_XY_PKT(
0 xc403),
PSIL_PDMA_XY_PKT(
0 xc404),
PSIL_PDMA_XY_PKT(
0 xc405),
PSIL_PDMA_XY_PKT(
0 xc406),
/* PDMA_MAIN2 - MCASP0-2 */
PSIL_PDMA_MCASP(
0 xc500),
PSIL_PDMA_MCASP(
0 xc501),
PSIL_PDMA_MCASP(
0 xc502),
/* CPSW3G */
PSIL_ETHERNET(
0 xc600,
19 ,
19 ,
8 ),
PSIL_ETHERNET(
0 xc601,
20 ,
27 ,
8 ),
PSIL_ETHERNET(
0 xc602,
21 ,
35 ,
8 ),
PSIL_ETHERNET(
0 xc603,
22 ,
43 ,
8 ),
PSIL_ETHERNET(
0 xc604,
23 ,
51 ,
8 ),
PSIL_ETHERNET(
0 xc605,
24 ,
59 ,
8 ),
PSIL_ETHERNET(
0 xc606,
25 ,
67 ,
8 ),
PSIL_ETHERNET(
0 xc607,
26 ,
75 ,
8 ),
};
struct psil_ep_map am62p_ep_map = {
.name =
"am62p" ,
.src = am62p_src_ep_map,
.src_count = ARRAY_SIZE(am62p_src_ep_map),
.dst = am62p_dst_ep_map,
.dst_count = ARRAY_SIZE(am62p_dst_ep_map),
};
Messung V0.5 in Prozent C=96 H=94 G=94
¤ Dauer der Verarbeitung: 0.9 Sekunden
(vorverarbeitet am 2026-06-08)
¤
*© Formatika GbR, Deutschland