1 // SPDX-License-Identifier: GPL-2.0+
3 * Copyright (C) 2018 Texas Instruments Incorporated - http://www.ti.com
6 #define pr_fmt(fmt) "udma: " fmt
11 #include <asm/cache.h>
13 #include <asm/bitops.h>
15 #include <linux/bitops.h>
16 #include <linux/dma-mapping.h>
18 #include <dm/device_compat.h>
19 #include <dm/devres.h>
21 #include <dm/of_access.h>
23 #include <dma-uclass.h>
24 #include <linux/delay.h>
25 #include <linux/bitmap.h>
26 #include <linux/err.h>
27 #include <linux/soc/ti/k3-navss-ringacc.h>
28 #include <linux/soc/ti/cppi5.h>
29 #include <linux/soc/ti/ti-udma.h>
30 #include <linux/soc/ti/ti_sci_protocol.h>
32 #include "k3-udma-hwdef.h"
33 #include "k3-psil-priv.h"
35 #define K3_UDMA_MAX_RFLOWS 1024
46 static const char * const mmr_names[] = {
47 "gcfg", "rchanrt", "tchanrt"
54 struct k3_nav_ring *t_ring; /* Transmit ring */
55 struct k3_nav_ring *tc_ring; /* Transmit Completion ring */
64 #define UDMA_FLAG_PDMA_ACC32 BIT(0)
65 #define UDMA_FLAG_PDMA_BURST BIT(1)
66 #define UDMA_FLAG_TDTYPE BIT(2)
68 struct udma_match_data {
70 bool enable_memcpy_support;
76 u32 level_start_idx[];
82 struct k3_nav_ring *fd_ring; /* Free Descriptor ring */
83 struct k3_nav_ring *r_ring; /* Receive ring*/
93 struct udma_tisci_rm {
94 const struct ti_sci_handle *tisci;
95 const struct ti_sci_rm_udmap_ops *tisci_udmap_ops;
98 /* tisci information for PSI-L thread pairing/unpairing */
99 const struct ti_sci_rm_psil_ops *tisci_psil_ops;
100 u32 tisci_navss_dev_id;
102 struct ti_sci_resource *rm_ranges[RM_RANGE_LAST];
107 void __iomem *mmrs[MMR_LAST];
109 struct udma_tisci_rm tisci_rm;
110 struct k3_nav_ringacc *ringacc;
118 unsigned long *tchan_map;
119 unsigned long *rchan_map;
120 unsigned long *rflow_map;
121 unsigned long *rflow_map_reserved;
123 struct udma_tchan *tchans;
124 struct udma_rchan *rchans;
125 struct udma_rflow *rflows;
127 struct udma_match_data *match_data;
129 struct udma_chan *channels;
135 struct udma_chan_config {
136 u32 psd_size; /* size of Protocol Specific Data */
137 u32 metadata_size; /* (needs_epib ? 16:0) + psd_size */
138 u32 hdesc_size; /* Size of a packet descriptor in packet mode */
139 int remote_thread_id;
143 enum psil_endpoint_type ep_type;
144 enum udma_tp_level channel_tpl; /* Channel Throughput Level */
146 enum dma_direction dir;
148 unsigned int pkt_mode:1; /* TR or packet */
149 unsigned int needs_epib:1; /* EPIB is needed for the communication or not */
150 unsigned int enable_acc32:1;
151 unsigned int enable_burst:1;
152 unsigned int notdpkt:1; /* Suppress sending TDC packet */
159 struct udma_tchan *tchan;
160 struct udma_rchan *rchan;
161 struct udma_rflow *rflow;
163 struct ti_udma_drv_chan_cfg_data cfg_data;
165 u32 bcnt; /* number of bytes completed since the start of the channel */
167 struct udma_chan_config config;
171 struct cppi5_host_desc_t *desc_tx;
179 #define UDMA_CH_1000(ch) (ch * 0x1000)
180 #define UDMA_CH_100(ch) (ch * 0x100)
181 #define UDMA_CH_40(ch) (ch * 0x40)
184 #define UDMA_RX_DESC_NUM PKTBUFSRX
186 #define UDMA_RX_DESC_NUM 4
189 /* Generic register access functions */
190 static inline u32 udma_read(void __iomem *base, int reg)
194 v = __raw_readl(base + reg);
195 pr_debug("READL(32): v(%08X)<--reg(%p)\n", v, base + reg);
199 static inline void udma_write(void __iomem *base, int reg, u32 val)
201 pr_debug("WRITEL(32): v(%08X)-->reg(%p)\n", val, base + reg);
202 __raw_writel(val, base + reg);
205 static inline void udma_update_bits(void __iomem *base, int reg,
210 orig = udma_read(base, reg);
215 udma_write(base, reg, tmp);
219 static inline u32 udma_tchanrt_read(struct udma_tchan *tchan, int reg)
223 return udma_read(tchan->reg_rt, reg);
226 static inline void udma_tchanrt_write(struct udma_tchan *tchan,
231 udma_write(tchan->reg_rt, reg, val);
235 static inline u32 udma_rchanrt_read(struct udma_rchan *rchan, int reg)
239 return udma_read(rchan->reg_rt, reg);
242 static inline void udma_rchanrt_write(struct udma_rchan *rchan,
247 udma_write(rchan->reg_rt, reg, val);
250 static inline int udma_navss_psil_pair(struct udma_dev *ud, u32 src_thread,
253 struct udma_tisci_rm *tisci_rm = &ud->tisci_rm;
255 dst_thread |= UDMA_PSIL_DST_THREAD_ID_OFFSET;
257 return tisci_rm->tisci_psil_ops->pair(tisci_rm->tisci,
258 tisci_rm->tisci_navss_dev_id,
259 src_thread, dst_thread);
262 static inline int udma_navss_psil_unpair(struct udma_dev *ud, u32 src_thread,
265 struct udma_tisci_rm *tisci_rm = &ud->tisci_rm;
267 dst_thread |= UDMA_PSIL_DST_THREAD_ID_OFFSET;
269 return tisci_rm->tisci_psil_ops->unpair(tisci_rm->tisci,
270 tisci_rm->tisci_navss_dev_id,
271 src_thread, dst_thread);
274 static inline char *udma_get_dir_text(enum dma_direction dir)
292 static inline bool udma_is_chan_running(struct udma_chan *uc)
297 switch (uc->config.dir) {
299 rrt_ctl = udma_rchanrt_read(uc->rchan, UDMA_RCHAN_RT_CTL_REG);
300 pr_debug("%s: rrt_ctl: 0x%08x (peer: 0x%08x)\n",
302 udma_rchanrt_read(uc->rchan,
303 UDMA_RCHAN_RT_PEER_RT_EN_REG));
306 trt_ctl = udma_tchanrt_read(uc->tchan, UDMA_TCHAN_RT_CTL_REG);
307 pr_debug("%s: trt_ctl: 0x%08x (peer: 0x%08x)\n",
309 udma_tchanrt_read(uc->tchan,
310 UDMA_TCHAN_RT_PEER_RT_EN_REG));
313 trt_ctl = udma_tchanrt_read(uc->tchan, UDMA_TCHAN_RT_CTL_REG);
314 rrt_ctl = udma_rchanrt_read(uc->rchan, UDMA_RCHAN_RT_CTL_REG);
320 if (trt_ctl & UDMA_CHAN_RT_CTL_EN || rrt_ctl & UDMA_CHAN_RT_CTL_EN)
326 static int udma_pop_from_ring(struct udma_chan *uc, dma_addr_t *addr)
328 struct k3_nav_ring *ring = NULL;
331 switch (uc->config.dir) {
333 ring = uc->rflow->r_ring;
336 ring = uc->tchan->tc_ring;
339 ring = uc->tchan->tc_ring;
345 if (ring && k3_nav_ringacc_ring_get_occ(ring))
346 ret = k3_nav_ringacc_ring_pop(ring, addr);
351 static void udma_reset_rings(struct udma_chan *uc)
353 struct k3_nav_ring *ring1 = NULL;
354 struct k3_nav_ring *ring2 = NULL;
356 switch (uc->config.dir) {
358 ring1 = uc->rflow->fd_ring;
359 ring2 = uc->rflow->r_ring;
362 ring1 = uc->tchan->t_ring;
363 ring2 = uc->tchan->tc_ring;
366 ring1 = uc->tchan->t_ring;
367 ring2 = uc->tchan->tc_ring;
374 k3_nav_ringacc_ring_reset_dma(ring1, 0);
376 k3_nav_ringacc_ring_reset(ring2);
379 static void udma_reset_counters(struct udma_chan *uc)
384 val = udma_tchanrt_read(uc->tchan, UDMA_TCHAN_RT_BCNT_REG);
385 udma_tchanrt_write(uc->tchan, UDMA_TCHAN_RT_BCNT_REG, val);
387 val = udma_tchanrt_read(uc->tchan, UDMA_TCHAN_RT_SBCNT_REG);
388 udma_tchanrt_write(uc->tchan, UDMA_TCHAN_RT_SBCNT_REG, val);
390 val = udma_tchanrt_read(uc->tchan, UDMA_TCHAN_RT_PCNT_REG);
391 udma_tchanrt_write(uc->tchan, UDMA_TCHAN_RT_PCNT_REG, val);
393 val = udma_tchanrt_read(uc->tchan, UDMA_TCHAN_RT_PEER_BCNT_REG);
394 udma_tchanrt_write(uc->tchan, UDMA_TCHAN_RT_PEER_BCNT_REG, val);
398 val = udma_rchanrt_read(uc->rchan, UDMA_RCHAN_RT_BCNT_REG);
399 udma_rchanrt_write(uc->rchan, UDMA_RCHAN_RT_BCNT_REG, val);
401 val = udma_rchanrt_read(uc->rchan, UDMA_RCHAN_RT_SBCNT_REG);
402 udma_rchanrt_write(uc->rchan, UDMA_RCHAN_RT_SBCNT_REG, val);
404 val = udma_rchanrt_read(uc->rchan, UDMA_RCHAN_RT_PCNT_REG);
405 udma_rchanrt_write(uc->rchan, UDMA_RCHAN_RT_PCNT_REG, val);
407 val = udma_rchanrt_read(uc->rchan, UDMA_RCHAN_RT_PEER_BCNT_REG);
408 udma_rchanrt_write(uc->rchan, UDMA_RCHAN_RT_PEER_BCNT_REG, val);
414 static inline int udma_stop_hard(struct udma_chan *uc)
416 pr_debug("%s: ENTER (chan%d)\n", __func__, uc->id);
418 switch (uc->config.dir) {
420 udma_rchanrt_write(uc->rchan, UDMA_RCHAN_RT_PEER_RT_EN_REG, 0);
421 udma_rchanrt_write(uc->rchan, UDMA_RCHAN_RT_CTL_REG, 0);
424 udma_tchanrt_write(uc->tchan, UDMA_TCHAN_RT_CTL_REG, 0);
425 udma_tchanrt_write(uc->tchan, UDMA_TCHAN_RT_PEER_RT_EN_REG, 0);
428 udma_rchanrt_write(uc->rchan, UDMA_RCHAN_RT_CTL_REG, 0);
429 udma_tchanrt_write(uc->tchan, UDMA_TCHAN_RT_CTL_REG, 0);
438 static int udma_start(struct udma_chan *uc)
440 /* Channel is already running, no need to proceed further */
441 if (udma_is_chan_running(uc))
444 pr_debug("%s: chan:%d dir:%s\n",
445 __func__, uc->id, udma_get_dir_text(uc->config.dir));
447 /* Make sure that we clear the teardown bit, if it is set */
450 /* Reset all counters */
451 udma_reset_counters(uc);
453 switch (uc->config.dir) {
455 udma_rchanrt_write(uc->rchan, UDMA_RCHAN_RT_CTL_REG,
456 UDMA_CHAN_RT_CTL_EN);
459 udma_rchanrt_write(uc->rchan, UDMA_RCHAN_RT_PEER_RT_EN_REG,
460 UDMA_PEER_RT_EN_ENABLE);
462 pr_debug("%s(rx): RT_CTL:0x%08x PEER RT_ENABLE:0x%08x\n",
464 udma_rchanrt_read(uc->rchan,
465 UDMA_RCHAN_RT_CTL_REG),
466 udma_rchanrt_read(uc->rchan,
467 UDMA_RCHAN_RT_PEER_RT_EN_REG));
471 udma_tchanrt_write(uc->tchan, UDMA_TCHAN_RT_PEER_RT_EN_REG,
472 UDMA_PEER_RT_EN_ENABLE);
474 udma_tchanrt_write(uc->tchan, UDMA_TCHAN_RT_CTL_REG,
475 UDMA_CHAN_RT_CTL_EN);
477 pr_debug("%s(tx): RT_CTL:0x%08x PEER RT_ENABLE:0x%08x\n",
479 udma_tchanrt_read(uc->tchan,
480 UDMA_TCHAN_RT_CTL_REG),
481 udma_tchanrt_read(uc->tchan,
482 UDMA_TCHAN_RT_PEER_RT_EN_REG));
485 udma_rchanrt_write(uc->rchan, UDMA_RCHAN_RT_CTL_REG,
486 UDMA_CHAN_RT_CTL_EN);
487 udma_tchanrt_write(uc->tchan, UDMA_TCHAN_RT_CTL_REG,
488 UDMA_CHAN_RT_CTL_EN);
495 pr_debug("%s: DONE chan:%d\n", __func__, uc->id);
500 static inline void udma_stop_mem2dev(struct udma_chan *uc, bool sync)
505 udma_tchanrt_write(uc->tchan, UDMA_TCHAN_RT_CTL_REG,
506 UDMA_CHAN_RT_CTL_EN |
507 UDMA_CHAN_RT_CTL_TDOWN);
509 val = udma_tchanrt_read(uc->tchan, UDMA_TCHAN_RT_CTL_REG);
511 while (sync && (val & UDMA_CHAN_RT_CTL_EN)) {
512 val = udma_tchanrt_read(uc->tchan, UDMA_TCHAN_RT_CTL_REG);
515 printf(" %s TIMEOUT !\n", __func__);
521 val = udma_tchanrt_read(uc->tchan, UDMA_TCHAN_RT_PEER_RT_EN_REG);
522 if (val & UDMA_PEER_RT_EN_ENABLE)
523 printf("%s: peer not stopped TIMEOUT !\n", __func__);
526 static inline void udma_stop_dev2mem(struct udma_chan *uc, bool sync)
531 udma_rchanrt_write(uc->rchan, UDMA_RCHAN_RT_PEER_RT_EN_REG,
532 UDMA_PEER_RT_EN_ENABLE |
533 UDMA_PEER_RT_EN_TEARDOWN);
535 val = udma_rchanrt_read(uc->rchan, UDMA_RCHAN_RT_CTL_REG);
537 while (sync && (val & UDMA_CHAN_RT_CTL_EN)) {
538 val = udma_rchanrt_read(uc->rchan, UDMA_RCHAN_RT_CTL_REG);
541 printf("%s TIMEOUT !\n", __func__);
547 val = udma_rchanrt_read(uc->rchan, UDMA_RCHAN_RT_PEER_RT_EN_REG);
548 if (val & UDMA_PEER_RT_EN_ENABLE)
549 printf("%s: peer not stopped TIMEOUT !\n", __func__);
552 static inline int udma_stop(struct udma_chan *uc)
554 pr_debug("%s: chan:%d dir:%s\n",
555 __func__, uc->id, udma_get_dir_text(uc->config.dir));
557 udma_reset_counters(uc);
558 switch (uc->config.dir) {
560 udma_stop_dev2mem(uc, true);
563 udma_stop_mem2dev(uc, true);
566 udma_rchanrt_write(uc->rchan, UDMA_RCHAN_RT_CTL_REG, 0);
567 udma_tchanrt_write(uc->tchan, UDMA_TCHAN_RT_CTL_REG, 0);
576 static void udma_poll_completion(struct udma_chan *uc, dma_addr_t *paddr)
580 while (udma_pop_from_ring(uc, paddr)) {
588 static struct udma_rflow *__udma_reserve_rflow(struct udma_dev *ud, int id)
590 DECLARE_BITMAP(tmp, K3_UDMA_MAX_RFLOWS);
593 if (test_bit(id, ud->rflow_map)) {
594 dev_err(ud->dev, "rflow%d is in use\n", id);
595 return ERR_PTR(-ENOENT);
598 bitmap_or(tmp, ud->rflow_map, ud->rflow_map_reserved,
601 id = find_next_zero_bit(tmp, ud->rflow_cnt, ud->rchan_cnt);
602 if (id >= ud->rflow_cnt)
603 return ERR_PTR(-ENOENT);
606 __set_bit(id, ud->rflow_map);
607 return &ud->rflows[id];
610 #define UDMA_RESERVE_RESOURCE(res) \
611 static struct udma_##res *__udma_reserve_##res(struct udma_dev *ud, \
615 if (test_bit(id, ud->res##_map)) { \
616 dev_err(ud->dev, "res##%d is in use\n", id); \
617 return ERR_PTR(-ENOENT); \
620 id = find_first_zero_bit(ud->res##_map, ud->res##_cnt); \
621 if (id == ud->res##_cnt) { \
622 return ERR_PTR(-ENOENT); \
626 __set_bit(id, ud->res##_map); \
627 return &ud->res##s[id]; \
630 UDMA_RESERVE_RESOURCE(tchan);
631 UDMA_RESERVE_RESOURCE(rchan);
633 static int udma_get_tchan(struct udma_chan *uc)
635 struct udma_dev *ud = uc->ud;
638 dev_dbg(ud->dev, "chan%d: already have tchan%d allocated\n",
639 uc->id, uc->tchan->id);
643 uc->tchan = __udma_reserve_tchan(ud, -1);
644 if (IS_ERR(uc->tchan))
645 return PTR_ERR(uc->tchan);
647 pr_debug("chan%d: got tchan%d\n", uc->id, uc->tchan->id);
652 static int udma_get_rchan(struct udma_chan *uc)
654 struct udma_dev *ud = uc->ud;
657 dev_dbg(ud->dev, "chan%d: already have rchan%d allocated\n",
658 uc->id, uc->rchan->id);
662 uc->rchan = __udma_reserve_rchan(ud, -1);
663 if (IS_ERR(uc->rchan))
664 return PTR_ERR(uc->rchan);
666 pr_debug("chan%d: got rchan%d\n", uc->id, uc->rchan->id);
671 static int udma_get_chan_pair(struct udma_chan *uc)
673 struct udma_dev *ud = uc->ud;
676 if ((uc->tchan && uc->rchan) && uc->tchan->id == uc->rchan->id) {
677 dev_info(ud->dev, "chan%d: already have %d pair allocated\n",
678 uc->id, uc->tchan->id);
683 dev_err(ud->dev, "chan%d: already have tchan%d allocated\n",
684 uc->id, uc->tchan->id);
686 } else if (uc->rchan) {
687 dev_err(ud->dev, "chan%d: already have rchan%d allocated\n",
688 uc->id, uc->rchan->id);
692 /* Can be optimized, but let's have it like this for now */
693 end = min(ud->tchan_cnt, ud->rchan_cnt);
694 for (chan_id = 0; chan_id < end; chan_id++) {
695 if (!test_bit(chan_id, ud->tchan_map) &&
696 !test_bit(chan_id, ud->rchan_map))
703 __set_bit(chan_id, ud->tchan_map);
704 __set_bit(chan_id, ud->rchan_map);
705 uc->tchan = &ud->tchans[chan_id];
706 uc->rchan = &ud->rchans[chan_id];
708 pr_debug("chan%d: got t/rchan%d pair\n", uc->id, chan_id);
713 static int udma_get_rflow(struct udma_chan *uc, int flow_id)
715 struct udma_dev *ud = uc->ud;
718 dev_dbg(ud->dev, "chan%d: already have rflow%d allocated\n",
719 uc->id, uc->rflow->id);
724 dev_warn(ud->dev, "chan%d: does not have rchan??\n", uc->id);
726 uc->rflow = __udma_reserve_rflow(ud, flow_id);
727 if (IS_ERR(uc->rflow))
728 return PTR_ERR(uc->rflow);
730 pr_debug("chan%d: got rflow%d\n", uc->id, uc->rflow->id);
734 static void udma_put_rchan(struct udma_chan *uc)
736 struct udma_dev *ud = uc->ud;
739 dev_dbg(ud->dev, "chan%d: put rchan%d\n", uc->id,
741 __clear_bit(uc->rchan->id, ud->rchan_map);
746 static void udma_put_tchan(struct udma_chan *uc)
748 struct udma_dev *ud = uc->ud;
751 dev_dbg(ud->dev, "chan%d: put tchan%d\n", uc->id,
753 __clear_bit(uc->tchan->id, ud->tchan_map);
758 static void udma_put_rflow(struct udma_chan *uc)
760 struct udma_dev *ud = uc->ud;
763 dev_dbg(ud->dev, "chan%d: put rflow%d\n", uc->id,
765 __clear_bit(uc->rflow->id, ud->rflow_map);
770 static void udma_free_tx_resources(struct udma_chan *uc)
775 k3_nav_ringacc_ring_free(uc->tchan->t_ring);
776 k3_nav_ringacc_ring_free(uc->tchan->tc_ring);
777 uc->tchan->t_ring = NULL;
778 uc->tchan->tc_ring = NULL;
783 static int udma_alloc_tx_resources(struct udma_chan *uc)
785 struct k3_nav_ring_cfg ring_cfg;
786 struct udma_dev *ud = uc->ud;
789 ret = udma_get_tchan(uc);
793 ret = k3_nav_ringacc_request_rings_pair(ud->ringacc, uc->tchan->id, -1,
795 &uc->tchan->tc_ring);
801 memset(&ring_cfg, 0, sizeof(ring_cfg));
803 ring_cfg.elm_size = K3_NAV_RINGACC_RING_ELSIZE_8;
804 ring_cfg.mode = K3_NAV_RINGACC_RING_MODE_RING;
806 ret = k3_nav_ringacc_ring_cfg(uc->tchan->t_ring, &ring_cfg);
807 ret |= k3_nav_ringacc_ring_cfg(uc->tchan->tc_ring, &ring_cfg);
815 k3_nav_ringacc_ring_free(uc->tchan->tc_ring);
816 uc->tchan->tc_ring = NULL;
817 k3_nav_ringacc_ring_free(uc->tchan->t_ring);
818 uc->tchan->t_ring = NULL;
825 static void udma_free_rx_resources(struct udma_chan *uc)
831 k3_nav_ringacc_ring_free(uc->rflow->fd_ring);
832 k3_nav_ringacc_ring_free(uc->rflow->r_ring);
833 uc->rflow->fd_ring = NULL;
834 uc->rflow->r_ring = NULL;
842 static int udma_alloc_rx_resources(struct udma_chan *uc)
844 struct k3_nav_ring_cfg ring_cfg;
845 struct udma_dev *ud = uc->ud;
846 struct udma_rflow *rflow;
850 ret = udma_get_rchan(uc);
854 /* For MEM_TO_MEM we don't need rflow or rings */
855 if (uc->config.dir == DMA_MEM_TO_MEM)
858 ret = udma_get_rflow(uc, uc->rchan->id);
864 fd_ring_id = ud->tchan_cnt + ud->echan_cnt + uc->rchan->id;
867 ret = k3_nav_ringacc_request_rings_pair(ud->ringacc, fd_ring_id, -1,
868 &rflow->fd_ring, &rflow->r_ring);
874 memset(&ring_cfg, 0, sizeof(ring_cfg));
876 ring_cfg.elm_size = K3_NAV_RINGACC_RING_ELSIZE_8;
877 ring_cfg.mode = K3_NAV_RINGACC_RING_MODE_RING;
879 ret = k3_nav_ringacc_ring_cfg(rflow->fd_ring, &ring_cfg);
880 ret |= k3_nav_ringacc_ring_cfg(rflow->r_ring, &ring_cfg);
887 k3_nav_ringacc_ring_free(rflow->r_ring);
888 rflow->r_ring = NULL;
889 k3_nav_ringacc_ring_free(rflow->fd_ring);
890 rflow->fd_ring = NULL;
899 static int udma_alloc_tchan_sci_req(struct udma_chan *uc)
901 struct udma_dev *ud = uc->ud;
902 int tc_ring = k3_nav_ringacc_get_ring_id(uc->tchan->tc_ring);
903 struct ti_sci_msg_rm_udmap_tx_ch_cfg req;
904 struct udma_tisci_rm *tisci_rm = &ud->tisci_rm;
908 if (uc->config.pkt_mode)
909 mode = TI_SCI_RM_UDMAP_CHAN_TYPE_PKT_PBRR;
911 mode = TI_SCI_RM_UDMAP_CHAN_TYPE_3RDP_BCOPY_PBRR;
913 req.valid_params = TI_SCI_MSG_VALUE_RM_UDMAP_CH_CHAN_TYPE_VALID |
914 TI_SCI_MSG_VALUE_RM_UDMAP_CH_FETCH_SIZE_VALID |
915 TI_SCI_MSG_VALUE_RM_UDMAP_CH_CQ_QNUM_VALID;
916 req.nav_id = tisci_rm->tisci_dev_id;
917 req.index = uc->tchan->id;
918 req.tx_chan_type = mode;
919 if (uc->config.dir == DMA_MEM_TO_MEM)
920 req.tx_fetch_size = sizeof(struct cppi5_desc_hdr_t) >> 2;
922 req.tx_fetch_size = cppi5_hdesc_calc_size(uc->config.needs_epib,
925 req.txcq_qnum = tc_ring;
927 ret = tisci_rm->tisci_udmap_ops->tx_ch_cfg(tisci_rm->tisci, &req);
929 dev_err(ud->dev, "tisci tx alloc failed %d\n", ret);
934 static int udma_alloc_rchan_sci_req(struct udma_chan *uc)
936 struct udma_dev *ud = uc->ud;
937 int fd_ring = k3_nav_ringacc_get_ring_id(uc->rflow->fd_ring);
938 int rx_ring = k3_nav_ringacc_get_ring_id(uc->rflow->r_ring);
939 int tc_ring = k3_nav_ringacc_get_ring_id(uc->tchan->tc_ring);
940 struct ti_sci_msg_rm_udmap_rx_ch_cfg req = { 0 };
941 struct ti_sci_msg_rm_udmap_flow_cfg flow_req = { 0 };
942 struct udma_tisci_rm *tisci_rm = &ud->tisci_rm;
946 if (uc->config.pkt_mode)
947 mode = TI_SCI_RM_UDMAP_CHAN_TYPE_PKT_PBRR;
949 mode = TI_SCI_RM_UDMAP_CHAN_TYPE_3RDP_BCOPY_PBRR;
951 req.valid_params = TI_SCI_MSG_VALUE_RM_UDMAP_CH_FETCH_SIZE_VALID |
952 TI_SCI_MSG_VALUE_RM_UDMAP_CH_CQ_QNUM_VALID |
953 TI_SCI_MSG_VALUE_RM_UDMAP_CH_CHAN_TYPE_VALID |
954 TI_SCI_MSG_VALUE_RM_UDMAP_CH_RX_FLOWID_START_VALID |
955 TI_SCI_MSG_VALUE_RM_UDMAP_CH_RX_FLOWID_CNT_VALID;
956 req.nav_id = tisci_rm->tisci_dev_id;
957 req.index = uc->rchan->id;
958 req.rx_chan_type = mode;
959 if (uc->config.dir == DMA_MEM_TO_MEM) {
960 req.rx_fetch_size = sizeof(struct cppi5_desc_hdr_t) >> 2;
961 req.rxcq_qnum = tc_ring;
963 req.rx_fetch_size = cppi5_hdesc_calc_size(uc->config.needs_epib,
966 req.rxcq_qnum = rx_ring;
968 if (uc->rflow->id != uc->rchan->id && uc->config.dir != DMA_MEM_TO_MEM) {
969 req.flowid_start = uc->rflow->id;
973 ret = tisci_rm->tisci_udmap_ops->rx_ch_cfg(tisci_rm->tisci, &req);
975 dev_err(ud->dev, "tisci rx %u cfg failed %d\n",
979 if (uc->config.dir == DMA_MEM_TO_MEM)
982 flow_req.valid_params =
983 TI_SCI_MSG_VALUE_RM_UDMAP_FLOW_EINFO_PRESENT_VALID |
984 TI_SCI_MSG_VALUE_RM_UDMAP_FLOW_PSINFO_PRESENT_VALID |
985 TI_SCI_MSG_VALUE_RM_UDMAP_FLOW_ERROR_HANDLING_VALID |
986 TI_SCI_MSG_VALUE_RM_UDMAP_FLOW_DESC_TYPE_VALID |
987 TI_SCI_MSG_VALUE_RM_UDMAP_FLOW_DEST_QNUM_VALID |
988 TI_SCI_MSG_VALUE_RM_UDMAP_FLOW_SRC_TAG_HI_SEL_VALID |
989 TI_SCI_MSG_VALUE_RM_UDMAP_FLOW_SRC_TAG_LO_SEL_VALID |
990 TI_SCI_MSG_VALUE_RM_UDMAP_FLOW_DEST_TAG_HI_SEL_VALID |
991 TI_SCI_MSG_VALUE_RM_UDMAP_FLOW_DEST_TAG_LO_SEL_VALID |
992 TI_SCI_MSG_VALUE_RM_UDMAP_FLOW_FDQ0_SZ0_QNUM_VALID |
993 TI_SCI_MSG_VALUE_RM_UDMAP_FLOW_FDQ1_QNUM_VALID |
994 TI_SCI_MSG_VALUE_RM_UDMAP_FLOW_FDQ2_QNUM_VALID |
995 TI_SCI_MSG_VALUE_RM_UDMAP_FLOW_FDQ3_QNUM_VALID |
996 TI_SCI_MSG_VALUE_RM_UDMAP_FLOW_PS_LOCATION_VALID;
998 flow_req.nav_id = tisci_rm->tisci_dev_id;
999 flow_req.flow_index = uc->rflow->id;
1001 if (uc->config.needs_epib)
1002 flow_req.rx_einfo_present = 1;
1004 flow_req.rx_einfo_present = 0;
1006 if (uc->config.psd_size)
1007 flow_req.rx_psinfo_present = 1;
1009 flow_req.rx_psinfo_present = 0;
1011 flow_req.rx_error_handling = 0;
1012 flow_req.rx_desc_type = 0;
1013 flow_req.rx_dest_qnum = rx_ring;
1014 flow_req.rx_src_tag_hi_sel = 2;
1015 flow_req.rx_src_tag_lo_sel = 4;
1016 flow_req.rx_dest_tag_hi_sel = 5;
1017 flow_req.rx_dest_tag_lo_sel = 4;
1018 flow_req.rx_fdq0_sz0_qnum = fd_ring;
1019 flow_req.rx_fdq1_qnum = fd_ring;
1020 flow_req.rx_fdq2_qnum = fd_ring;
1021 flow_req.rx_fdq3_qnum = fd_ring;
1022 flow_req.rx_ps_location = 0;
1024 ret = tisci_rm->tisci_udmap_ops->rx_flow_cfg(tisci_rm->tisci,
1027 dev_err(ud->dev, "tisci rx %u flow %u cfg failed %d\n",
1028 uc->rchan->id, uc->rflow->id, ret);
1033 static int udma_alloc_chan_resources(struct udma_chan *uc)
1035 struct udma_dev *ud = uc->ud;
1038 pr_debug("%s: chan:%d as %s\n",
1039 __func__, uc->id, udma_get_dir_text(uc->config.dir));
1041 switch (uc->config.dir) {
1042 case DMA_MEM_TO_MEM:
1043 /* Non synchronized - mem to mem type of transfer */
1044 uc->config.pkt_mode = false;
1045 ret = udma_get_chan_pair(uc);
1049 ret = udma_alloc_tx_resources(uc);
1053 ret = udma_alloc_rx_resources(uc);
1057 uc->config.src_thread = ud->psil_base + uc->tchan->id;
1058 uc->config.dst_thread = (ud->psil_base + uc->rchan->id) | 0x8000;
1060 case DMA_MEM_TO_DEV:
1061 /* Slave transfer synchronized - mem to dev (TX) trasnfer */
1062 ret = udma_alloc_tx_resources(uc);
1066 uc->config.src_thread = ud->psil_base + uc->tchan->id;
1067 uc->config.dst_thread = uc->config.remote_thread_id;
1068 uc->config.dst_thread |= 0x8000;
1071 case DMA_DEV_TO_MEM:
1072 /* Slave transfer synchronized - dev to mem (RX) trasnfer */
1073 ret = udma_alloc_rx_resources(uc);
1077 uc->config.src_thread = uc->config.remote_thread_id;
1078 uc->config.dst_thread = (ud->psil_base + uc->rchan->id) | 0x8000;
1082 /* Can not happen */
1083 pr_debug("%s: chan:%d invalid direction (%u)\n",
1084 __func__, uc->id, uc->config.dir);
1088 /* We have channel indexes and rings */
1089 if (uc->config.dir == DMA_MEM_TO_MEM) {
1090 ret = udma_alloc_tchan_sci_req(uc);
1094 ret = udma_alloc_rchan_sci_req(uc);
1098 /* Slave transfer */
1099 if (uc->config.dir == DMA_MEM_TO_DEV) {
1100 ret = udma_alloc_tchan_sci_req(uc);
1104 ret = udma_alloc_rchan_sci_req(uc);
1110 if (udma_is_chan_running(uc)) {
1111 dev_warn(ud->dev, "chan%d: is running!\n", uc->id);
1113 if (udma_is_chan_running(uc)) {
1114 dev_err(ud->dev, "chan%d: won't stop!\n", uc->id);
1120 ret = udma_navss_psil_pair(ud, uc->config.src_thread, uc->config.dst_thread);
1122 dev_err(ud->dev, "k3_nav_psil_request_link fail\n");
1129 udma_free_tx_resources(uc);
1130 udma_free_rx_resources(uc);
1131 uc->config.remote_thread_id = -1;
1135 static void udma_free_chan_resources(struct udma_chan *uc)
1137 /* Hard reset UDMA channel */
1139 udma_reset_counters(uc);
1141 /* Release PSI-L pairing */
1142 udma_navss_psil_unpair(uc->ud, uc->config.src_thread, uc->config.dst_thread);
1144 /* Reset the rings for a new start */
1145 udma_reset_rings(uc);
1146 udma_free_tx_resources(uc);
1147 udma_free_rx_resources(uc);
1149 uc->config.remote_thread_id = -1;
1150 uc->config.dir = DMA_MEM_TO_MEM;
1153 static int udma_get_mmrs(struct udevice *dev)
1155 struct udma_dev *ud = dev_get_priv(dev);
1158 for (i = 0; i < MMR_LAST; i++) {
1159 ud->mmrs[i] = (uint32_t *)devfdt_get_addr_name(dev,
1168 static int udma_setup_resources(struct udma_dev *ud)
1170 struct udevice *dev = ud->dev;
1173 struct ti_sci_resource_desc *rm_desc;
1174 struct ti_sci_resource *rm_res;
1175 struct udma_tisci_rm *tisci_rm = &ud->tisci_rm;
1176 static const char * const range_names[] = { "ti,sci-rm-range-tchan",
1177 "ti,sci-rm-range-rchan",
1178 "ti,sci-rm-range-rflow" };
1180 cap2 = udma_read(ud->mmrs[MMR_GCFG], 0x28);
1181 cap3 = udma_read(ud->mmrs[MMR_GCFG], 0x2c);
1183 ud->rflow_cnt = cap3 & 0x3fff;
1184 ud->tchan_cnt = cap2 & 0x1ff;
1185 ud->echan_cnt = (cap2 >> 9) & 0x1ff;
1186 ud->rchan_cnt = (cap2 >> 18) & 0x1ff;
1187 ch_count = ud->tchan_cnt + ud->rchan_cnt;
1189 ud->tchan_map = devm_kmalloc_array(dev, BITS_TO_LONGS(ud->tchan_cnt),
1190 sizeof(unsigned long), GFP_KERNEL);
1191 ud->tchans = devm_kcalloc(dev, ud->tchan_cnt, sizeof(*ud->tchans),
1193 ud->rchan_map = devm_kmalloc_array(dev, BITS_TO_LONGS(ud->rchan_cnt),
1194 sizeof(unsigned long), GFP_KERNEL);
1195 ud->rchans = devm_kcalloc(dev, ud->rchan_cnt, sizeof(*ud->rchans),
1197 ud->rflow_map = devm_kmalloc_array(dev, BITS_TO_LONGS(ud->rflow_cnt),
1198 sizeof(unsigned long), GFP_KERNEL);
1199 ud->rflow_map_reserved = devm_kcalloc(dev, BITS_TO_LONGS(ud->rflow_cnt),
1200 sizeof(unsigned long),
1202 ud->rflows = devm_kcalloc(dev, ud->rflow_cnt, sizeof(*ud->rflows),
1205 if (!ud->tchan_map || !ud->rchan_map || !ud->rflow_map ||
1206 !ud->rflow_map_reserved || !ud->tchans || !ud->rchans ||
1211 * RX flows with the same Ids as RX channels are reserved to be used
1212 * as default flows if remote HW can't generate flow_ids. Those
1213 * RX flows can be requested only explicitly by id.
1215 bitmap_set(ud->rflow_map_reserved, 0, ud->rchan_cnt);
1217 /* Get resource ranges from tisci */
1218 for (i = 0; i < RM_RANGE_LAST; i++)
1219 tisci_rm->rm_ranges[i] =
1220 devm_ti_sci_get_of_resource(tisci_rm->tisci, dev,
1221 tisci_rm->tisci_dev_id,
1222 (char *)range_names[i]);
1225 rm_res = tisci_rm->rm_ranges[RM_RANGE_TCHAN];
1226 if (IS_ERR(rm_res)) {
1227 bitmap_zero(ud->tchan_map, ud->tchan_cnt);
1229 bitmap_fill(ud->tchan_map, ud->tchan_cnt);
1230 for (i = 0; i < rm_res->sets; i++) {
1231 rm_desc = &rm_res->desc[i];
1232 bitmap_clear(ud->tchan_map, rm_desc->start,
1237 /* rchan and matching default flow ranges */
1238 rm_res = tisci_rm->rm_ranges[RM_RANGE_RCHAN];
1239 if (IS_ERR(rm_res)) {
1240 bitmap_zero(ud->rchan_map, ud->rchan_cnt);
1241 bitmap_zero(ud->rflow_map, ud->rchan_cnt);
1243 bitmap_fill(ud->rchan_map, ud->rchan_cnt);
1244 bitmap_fill(ud->rflow_map, ud->rchan_cnt);
1245 for (i = 0; i < rm_res->sets; i++) {
1246 rm_desc = &rm_res->desc[i];
1247 bitmap_clear(ud->rchan_map, rm_desc->start,
1249 bitmap_clear(ud->rflow_map, rm_desc->start,
1254 /* GP rflow ranges */
1255 rm_res = tisci_rm->rm_ranges[RM_RANGE_RFLOW];
1256 if (IS_ERR(rm_res)) {
1257 bitmap_clear(ud->rflow_map, ud->rchan_cnt,
1258 ud->rflow_cnt - ud->rchan_cnt);
1260 bitmap_set(ud->rflow_map, ud->rchan_cnt,
1261 ud->rflow_cnt - ud->rchan_cnt);
1262 for (i = 0; i < rm_res->sets; i++) {
1263 rm_desc = &rm_res->desc[i];
1264 bitmap_clear(ud->rflow_map, rm_desc->start,
1269 ch_count -= bitmap_weight(ud->tchan_map, ud->tchan_cnt);
1270 ch_count -= bitmap_weight(ud->rchan_map, ud->rchan_cnt);
1274 ud->channels = devm_kcalloc(dev, ch_count, sizeof(*ud->channels),
1280 "Channels: %d (tchan: %u, echan: %u, rchan: %u, rflow: %u)\n",
1281 ch_count, ud->tchan_cnt, ud->echan_cnt, ud->rchan_cnt,
1286 static int udma_probe(struct udevice *dev)
1288 struct dma_dev_priv *uc_priv = dev_get_uclass_priv(dev);
1289 struct udma_dev *ud = dev_get_priv(dev);
1291 struct udevice *tmp;
1292 struct udevice *tisci_dev = NULL;
1293 struct udma_tisci_rm *tisci_rm = &ud->tisci_rm;
1294 ofnode navss_ofnode = ofnode_get_parent(dev_ofnode(dev));
1297 ret = udma_get_mmrs(dev);
1301 ret = uclass_get_device_by_phandle(UCLASS_MISC, dev,
1302 "ti,ringacc", &tmp);
1303 ud->ringacc = dev_get_priv(tmp);
1304 if (IS_ERR(ud->ringacc))
1305 return PTR_ERR(ud->ringacc);
1307 ud->match_data = (void *)dev_get_driver_data(dev);
1308 ud->psil_base = ud->match_data->psil_base;
1310 ret = uclass_get_device_by_phandle(UCLASS_FIRMWARE, dev,
1311 "ti,sci", &tisci_dev);
1313 debug("Failed to get TISCI phandle (%d)\n", ret);
1314 tisci_rm->tisci = NULL;
1317 tisci_rm->tisci = (struct ti_sci_handle *)
1318 (ti_sci_get_handle_from_sysfw(tisci_dev));
1320 tisci_rm->tisci_dev_id = -1;
1321 ret = dev_read_u32(dev, "ti,sci-dev-id", &tisci_rm->tisci_dev_id);
1323 dev_err(dev, "ti,sci-dev-id read failure %d\n", ret);
1327 tisci_rm->tisci_navss_dev_id = -1;
1328 ret = ofnode_read_u32(navss_ofnode, "ti,sci-dev-id",
1329 &tisci_rm->tisci_navss_dev_id);
1331 dev_err(dev, "navss sci-dev-id read failure %d\n", ret);
1335 tisci_rm->tisci_udmap_ops = &tisci_rm->tisci->ops.rm_udmap_ops;
1336 tisci_rm->tisci_psil_ops = &tisci_rm->tisci->ops.rm_psil_ops;
1339 ud->ch_count = udma_setup_resources(ud);
1340 if (ud->ch_count <= 0)
1341 return ud->ch_count;
1344 "Number of channels: %u (tchan: %u, echan: %u, rchan: %u dev-id %u)\n",
1345 ud->ch_count, ud->tchan_cnt, ud->echan_cnt, ud->rchan_cnt,
1346 tisci_rm->tisci_dev_id);
1347 dev_info(dev, "Number of rflows: %u\n", ud->rflow_cnt);
1349 for (i = 0; i < ud->tchan_cnt; i++) {
1350 struct udma_tchan *tchan = &ud->tchans[i];
1353 tchan->reg_rt = ud->mmrs[MMR_TCHANRT] + UDMA_CH_1000(i);
1356 for (i = 0; i < ud->rchan_cnt; i++) {
1357 struct udma_rchan *rchan = &ud->rchans[i];
1360 rchan->reg_rt = ud->mmrs[MMR_RCHANRT] + UDMA_CH_1000(i);
1363 for (i = 0; i < ud->rflow_cnt; i++) {
1364 struct udma_rflow *rflow = &ud->rflows[i];
1369 for (i = 0; i < ud->ch_count; i++) {
1370 struct udma_chan *uc = &ud->channels[i];
1374 uc->config.remote_thread_id = -1;
1377 uc->config.dir = DMA_MEM_TO_MEM;
1378 sprintf(uc->name, "UDMA chan%d\n", i);
1383 pr_debug("UDMA(rev: 0x%08x) CAP0-3: 0x%08x, 0x%08x, 0x%08x, 0x%08x\n",
1384 udma_read(ud->mmrs[MMR_GCFG], 0),
1385 udma_read(ud->mmrs[MMR_GCFG], 0x20),
1386 udma_read(ud->mmrs[MMR_GCFG], 0x24),
1387 udma_read(ud->mmrs[MMR_GCFG], 0x28),
1388 udma_read(ud->mmrs[MMR_GCFG], 0x2c));
1390 uc_priv->supported = DMA_SUPPORTS_MEM_TO_MEM | DMA_SUPPORTS_MEM_TO_DEV;
1395 static int udma_push_to_ring(struct k3_nav_ring *ring, void *elem)
1399 memcpy(&addr, &elem, sizeof(elem));
1400 return k3_nav_ringacc_ring_push(ring, &addr);
1403 static int *udma_prep_dma_memcpy(struct udma_chan *uc, dma_addr_t dest,
1404 dma_addr_t src, size_t len)
1406 u32 tc_ring_id = k3_nav_ringacc_get_ring_id(uc->tchan->tc_ring);
1407 struct cppi5_tr_type15_t *tr_req;
1409 size_t tr_size = sizeof(struct cppi5_tr_type15_t);
1410 u16 tr0_cnt0, tr0_cnt1, tr1_cnt0;
1411 unsigned long dummy;
1420 unsigned long align_to = __ffs(src | dest);
1425 * Keep simple: tr0: SZ_64K-alignment blocks,
1426 * tr1: the remaining
1429 tr0_cnt0 = (SZ_64K - BIT(align_to));
1430 if (len / tr0_cnt0 >= SZ_64K) {
1431 dev_err(uc->ud->dev, "size %zu is not supported\n",
1436 tr0_cnt1 = len / tr0_cnt0;
1437 tr1_cnt0 = len % tr0_cnt0;
1440 desc_size = cppi5_trdesc_calc_size(num_tr, tr_size);
1441 tr_desc = dma_alloc_coherent(desc_size, &dummy);
1444 memset(tr_desc, 0, desc_size);
1446 cppi5_trdesc_init(tr_desc, num_tr, tr_size, 0, 0);
1447 cppi5_desc_set_pktids(tr_desc, uc->id, 0x3fff);
1448 cppi5_desc_set_retpolicy(tr_desc, 0, tc_ring_id);
1450 tr_req = tr_desc + tr_size;
1452 cppi5_tr_init(&tr_req[0].flags, CPPI5_TR_TYPE15, false, true,
1453 CPPI5_TR_EVENT_SIZE_COMPLETION, 1);
1454 cppi5_tr_csf_set(&tr_req[0].flags, CPPI5_TR_CSF_SUPR_EVT);
1456 tr_req[0].addr = src;
1457 tr_req[0].icnt0 = tr0_cnt0;
1458 tr_req[0].icnt1 = tr0_cnt1;
1459 tr_req[0].icnt2 = 1;
1460 tr_req[0].icnt3 = 1;
1461 tr_req[0].dim1 = tr0_cnt0;
1463 tr_req[0].daddr = dest;
1464 tr_req[0].dicnt0 = tr0_cnt0;
1465 tr_req[0].dicnt1 = tr0_cnt1;
1466 tr_req[0].dicnt2 = 1;
1467 tr_req[0].dicnt3 = 1;
1468 tr_req[0].ddim1 = tr0_cnt0;
1471 cppi5_tr_init(&tr_req[1].flags, CPPI5_TR_TYPE15, false, true,
1472 CPPI5_TR_EVENT_SIZE_COMPLETION, 0);
1473 cppi5_tr_csf_set(&tr_req[1].flags, CPPI5_TR_CSF_SUPR_EVT);
1475 tr_req[1].addr = src + tr0_cnt1 * tr0_cnt0;
1476 tr_req[1].icnt0 = tr1_cnt0;
1477 tr_req[1].icnt1 = 1;
1478 tr_req[1].icnt2 = 1;
1479 tr_req[1].icnt3 = 1;
1481 tr_req[1].daddr = dest + tr0_cnt1 * tr0_cnt0;
1482 tr_req[1].dicnt0 = tr1_cnt0;
1483 tr_req[1].dicnt1 = 1;
1484 tr_req[1].dicnt2 = 1;
1485 tr_req[1].dicnt3 = 1;
1488 cppi5_tr_csf_set(&tr_req[num_tr - 1].flags, CPPI5_TR_CSF_EOP);
1490 flush_dcache_range((unsigned long)tr_desc,
1491 ALIGN((unsigned long)tr_desc + desc_size,
1492 ARCH_DMA_MINALIGN));
1494 udma_push_to_ring(uc->tchan->t_ring, tr_desc);
1499 static int udma_transfer(struct udevice *dev, int direction,
1500 void *dst, void *src, size_t len)
1502 struct udma_dev *ud = dev_get_priv(dev);
1503 /* Channel0 is reserved for memcpy */
1504 struct udma_chan *uc = &ud->channels[0];
1505 dma_addr_t paddr = 0;
1508 ret = udma_alloc_chan_resources(uc);
1512 udma_prep_dma_memcpy(uc, (dma_addr_t)dst, (dma_addr_t)src, len);
1514 udma_poll_completion(uc, &paddr);
1517 udma_free_chan_resources(uc);
1521 static int udma_request(struct dma *dma)
1523 struct udma_dev *ud = dev_get_priv(dma->dev);
1524 struct udma_chan_config *ucc;
1525 struct udma_chan *uc;
1526 unsigned long dummy;
1529 if (dma->id >= (ud->rchan_cnt + ud->tchan_cnt)) {
1530 dev_err(dma->dev, "invalid dma ch_id %lu\n", dma->id);
1534 uc = &ud->channels[dma->id];
1536 ret = udma_alloc_chan_resources(uc);
1538 dev_err(dma->dev, "alloc dma res failed %d\n", ret);
1542 if (uc->config.dir == DMA_MEM_TO_DEV) {
1543 uc->desc_tx = dma_alloc_coherent(ucc->hdesc_size, &dummy);
1544 memset(uc->desc_tx, 0, ucc->hdesc_size);
1546 uc->desc_rx = dma_alloc_coherent(
1547 ucc->hdesc_size * UDMA_RX_DESC_NUM, &dummy);
1548 memset(uc->desc_rx, 0, ucc->hdesc_size * UDMA_RX_DESC_NUM);
1552 uc->desc_rx_cur = 0;
1553 uc->num_rx_bufs = 0;
1555 if (uc->config.dir == DMA_DEV_TO_MEM) {
1556 uc->cfg_data.flow_id_base = uc->rflow->id;
1557 uc->cfg_data.flow_id_cnt = 1;
1563 static int udma_rfree(struct dma *dma)
1565 struct udma_dev *ud = dev_get_priv(dma->dev);
1566 struct udma_chan *uc;
1568 if (dma->id >= (ud->rchan_cnt + ud->tchan_cnt)) {
1569 dev_err(dma->dev, "invalid dma ch_id %lu\n", dma->id);
1572 uc = &ud->channels[dma->id];
1574 if (udma_is_chan_running(uc))
1576 udma_free_chan_resources(uc);
1583 static int udma_enable(struct dma *dma)
1585 struct udma_dev *ud = dev_get_priv(dma->dev);
1586 struct udma_chan *uc;
1589 if (dma->id >= (ud->rchan_cnt + ud->tchan_cnt)) {
1590 dev_err(dma->dev, "invalid dma ch_id %lu\n", dma->id);
1593 uc = &ud->channels[dma->id];
1595 ret = udma_start(uc);
1600 static int udma_disable(struct dma *dma)
1602 struct udma_dev *ud = dev_get_priv(dma->dev);
1603 struct udma_chan *uc;
1606 if (dma->id >= (ud->rchan_cnt + ud->tchan_cnt)) {
1607 dev_err(dma->dev, "invalid dma ch_id %lu\n", dma->id);
1610 uc = &ud->channels[dma->id];
1612 if (udma_is_chan_running(uc))
1613 ret = udma_stop(uc);
1615 dev_err(dma->dev, "%s not running\n", __func__);
1620 static int udma_send(struct dma *dma, void *src, size_t len, void *metadata)
1622 struct udma_dev *ud = dev_get_priv(dma->dev);
1623 struct cppi5_host_desc_t *desc_tx;
1624 dma_addr_t dma_src = (dma_addr_t)src;
1625 struct ti_udma_drv_packet_data packet_data = { 0 };
1627 struct udma_chan *uc;
1632 packet_data = *((struct ti_udma_drv_packet_data *)metadata);
1634 if (dma->id >= (ud->rchan_cnt + ud->tchan_cnt)) {
1635 dev_err(dma->dev, "invalid dma ch_id %lu\n", dma->id);
1638 uc = &ud->channels[dma->id];
1640 if (uc->config.dir != DMA_MEM_TO_DEV)
1643 tc_ring_id = k3_nav_ringacc_get_ring_id(uc->tchan->tc_ring);
1645 desc_tx = uc->desc_tx;
1647 cppi5_hdesc_reset_hbdesc(desc_tx);
1649 cppi5_hdesc_init(desc_tx,
1650 uc->config.needs_epib ? CPPI5_INFO0_HDESC_EPIB_PRESENT : 0,
1651 uc->config.psd_size);
1652 cppi5_hdesc_set_pktlen(desc_tx, len);
1653 cppi5_hdesc_attach_buf(desc_tx, dma_src, len, dma_src, len);
1654 cppi5_desc_set_pktids(&desc_tx->hdr, uc->id, 0x3fff);
1655 cppi5_desc_set_retpolicy(&desc_tx->hdr, 0, tc_ring_id);
1656 /* pass below information from caller */
1657 cppi5_hdesc_set_pkttype(desc_tx, packet_data.pkt_type);
1658 cppi5_desc_set_tags_ids(&desc_tx->hdr, 0, packet_data.dest_tag);
1660 flush_dcache_range((unsigned long)dma_src,
1661 ALIGN((unsigned long)dma_src + len,
1662 ARCH_DMA_MINALIGN));
1663 flush_dcache_range((unsigned long)desc_tx,
1664 ALIGN((unsigned long)desc_tx + uc->config.hdesc_size,
1665 ARCH_DMA_MINALIGN));
1667 ret = udma_push_to_ring(uc->tchan->t_ring, uc->desc_tx);
1669 dev_err(dma->dev, "TX dma push fail ch_id %lu %d\n",
1674 udma_poll_completion(uc, &paddr);
1679 static int udma_receive(struct dma *dma, void **dst, void *metadata)
1681 struct udma_dev *ud = dev_get_priv(dma->dev);
1682 struct udma_chan_config *ucc;
1683 struct cppi5_host_desc_t *desc_rx;
1685 struct udma_chan *uc;
1686 u32 buf_dma_len, pkt_len;
1690 if (dma->id >= (ud->rchan_cnt + ud->tchan_cnt)) {
1691 dev_err(dma->dev, "invalid dma ch_id %lu\n", dma->id);
1694 uc = &ud->channels[dma->id];
1697 if (uc->config.dir != DMA_DEV_TO_MEM)
1699 if (!uc->num_rx_bufs)
1702 ret = k3_nav_ringacc_ring_pop(uc->rflow->r_ring, &desc_rx);
1703 if (ret && ret != -ENODATA) {
1704 dev_err(dma->dev, "rx dma fail ch_id:%lu %d\n", dma->id, ret);
1706 } else if (ret == -ENODATA) {
1710 /* invalidate cache data */
1711 invalidate_dcache_range((ulong)desc_rx,
1712 (ulong)(desc_rx + ucc->hdesc_size));
1714 cppi5_hdesc_get_obuf(desc_rx, &buf_dma, &buf_dma_len);
1715 pkt_len = cppi5_hdesc_get_pktlen(desc_rx);
1717 /* invalidate cache data */
1718 invalidate_dcache_range((ulong)buf_dma,
1719 (ulong)(buf_dma + buf_dma_len));
1721 cppi5_desc_get_tags_ids(&desc_rx->hdr, &port_id, NULL);
1723 *dst = (void *)buf_dma;
1729 static int udma_of_xlate(struct dma *dma, struct ofnode_phandle_args *args)
1731 struct udma_chan_config *ucc;
1732 struct udma_dev *ud = dev_get_priv(dma->dev);
1733 struct udma_chan *uc = &ud->channels[0];
1734 struct psil_endpoint_config *ep_config;
1737 for (val = 0; val < ud->ch_count; val++) {
1738 uc = &ud->channels[val];
1743 if (val == ud->ch_count)
1747 ucc->remote_thread_id = args->args[0];
1748 if (ucc->remote_thread_id & K3_PSIL_DST_THREAD_ID_OFFSET)
1749 ucc->dir = DMA_MEM_TO_DEV;
1751 ucc->dir = DMA_DEV_TO_MEM;
1753 ep_config = psil_get_ep_config(ucc->remote_thread_id);
1754 if (IS_ERR(ep_config)) {
1755 dev_err(ud->dev, "No configuration for psi-l thread 0x%04x\n",
1756 uc->config.remote_thread_id);
1757 ucc->dir = DMA_MEM_TO_MEM;
1758 ucc->remote_thread_id = -1;
1762 ucc->pkt_mode = ep_config->pkt_mode;
1763 ucc->channel_tpl = ep_config->channel_tpl;
1764 ucc->notdpkt = ep_config->notdpkt;
1765 ucc->ep_type = ep_config->ep_type;
1767 ucc->needs_epib = ep_config->needs_epib;
1768 ucc->psd_size = ep_config->psd_size;
1769 ucc->metadata_size = (ucc->needs_epib ? CPPI5_INFO0_HDESC_EPIB_SIZE : 0) + ucc->psd_size;
1771 ucc->hdesc_size = cppi5_hdesc_calc_size(ucc->needs_epib,
1773 ucc->hdesc_size = ALIGN(ucc->hdesc_size, ARCH_DMA_MINALIGN);
1776 pr_debug("Allocated dma chn:%lu epib:%d psdata:%u meta:%u thread_id:%x\n",
1777 dma->id, ucc->needs_epib,
1778 ucc->psd_size, ucc->metadata_size,
1779 ucc->remote_thread_id);
1784 int udma_prepare_rcv_buf(struct dma *dma, void *dst, size_t size)
1786 struct udma_dev *ud = dev_get_priv(dma->dev);
1787 struct cppi5_host_desc_t *desc_rx;
1789 struct udma_chan *uc;
1792 if (dma->id >= (ud->rchan_cnt + ud->tchan_cnt)) {
1793 dev_err(dma->dev, "invalid dma ch_id %lu\n", dma->id);
1796 uc = &ud->channels[dma->id];
1798 if (uc->config.dir != DMA_DEV_TO_MEM)
1801 if (uc->num_rx_bufs >= UDMA_RX_DESC_NUM)
1804 desc_num = uc->desc_rx_cur % UDMA_RX_DESC_NUM;
1805 desc_rx = uc->desc_rx + (desc_num * uc->config.hdesc_size);
1806 dma_dst = (dma_addr_t)dst;
1808 cppi5_hdesc_reset_hbdesc(desc_rx);
1810 cppi5_hdesc_init(desc_rx,
1811 uc->config.needs_epib ? CPPI5_INFO0_HDESC_EPIB_PRESENT : 0,
1812 uc->config.psd_size);
1813 cppi5_hdesc_set_pktlen(desc_rx, size);
1814 cppi5_hdesc_attach_buf(desc_rx, dma_dst, size, dma_dst, size);
1816 flush_dcache_range((unsigned long)desc_rx,
1817 ALIGN((unsigned long)desc_rx + uc->config.hdesc_size,
1818 ARCH_DMA_MINALIGN));
1820 udma_push_to_ring(uc->rflow->fd_ring, desc_rx);
1828 static int udma_get_cfg(struct dma *dma, u32 id, void **data)
1830 struct udma_dev *ud = dev_get_priv(dma->dev);
1831 struct udma_chan *uc;
1833 if (dma->id >= (ud->rchan_cnt + ud->tchan_cnt)) {
1834 dev_err(dma->dev, "invalid dma ch_id %lu\n", dma->id);
1839 case TI_UDMA_CHAN_PRIV_INFO:
1840 uc = &ud->channels[dma->id];
1841 *data = &uc->cfg_data;
1848 static const struct dma_ops udma_ops = {
1849 .transfer = udma_transfer,
1850 .of_xlate = udma_of_xlate,
1851 .request = udma_request,
1852 .rfree = udma_rfree,
1853 .enable = udma_enable,
1854 .disable = udma_disable,
1856 .receive = udma_receive,
1857 .prepare_rcv_buf = udma_prepare_rcv_buf,
1858 .get_cfg = udma_get_cfg,
1861 static struct udma_match_data am654_main_data = {
1862 .psil_base = 0x1000,
1863 .enable_memcpy_support = true,
1864 .statictr_z_mask = GENMASK(11, 0),
1865 .rchan_oes_offset = 0x200,
1867 .level_start_idx = {
1868 [0] = 8, /* Normal channels */
1869 [1] = 0, /* High Throughput channels */
1873 static struct udma_match_data am654_mcu_data = {
1874 .psil_base = 0x6000,
1875 .enable_memcpy_support = true,
1876 .statictr_z_mask = GENMASK(11, 0),
1877 .rchan_oes_offset = 0x200,
1879 .level_start_idx = {
1880 [0] = 2, /* Normal channels */
1881 [1] = 0, /* High Throughput channels */
1885 static struct udma_match_data j721e_main_data = {
1886 .psil_base = 0x1000,
1887 .enable_memcpy_support = true,
1888 .flags = UDMA_FLAG_PDMA_ACC32 | UDMA_FLAG_PDMA_BURST | UDMA_FLAG_TDTYPE,
1889 .statictr_z_mask = GENMASK(23, 0),
1890 .rchan_oes_offset = 0x400,
1892 .level_start_idx = {
1893 [0] = 16, /* Normal channels */
1894 [1] = 4, /* High Throughput channels */
1895 [2] = 0, /* Ultra High Throughput channels */
1899 static struct udma_match_data j721e_mcu_data = {
1900 .psil_base = 0x6000,
1901 .enable_memcpy_support = true,
1902 .flags = UDMA_FLAG_PDMA_ACC32 | UDMA_FLAG_PDMA_BURST | UDMA_FLAG_TDTYPE,
1903 .statictr_z_mask = GENMASK(23, 0),
1904 .rchan_oes_offset = 0x400,
1906 .level_start_idx = {
1907 [0] = 2, /* Normal channels */
1908 [1] = 0, /* High Throughput channels */
1912 static const struct udevice_id udma_ids[] = {
1914 .compatible = "ti,am654-navss-main-udmap",
1915 .data = (ulong)&am654_main_data,
1918 .compatible = "ti,am654-navss-mcu-udmap",
1919 .data = (ulong)&am654_mcu_data,
1921 .compatible = "ti,j721e-navss-main-udmap",
1922 .data = (ulong)&j721e_main_data,
1924 .compatible = "ti,j721e-navss-mcu-udmap",
1925 .data = (ulong)&j721e_mcu_data,
1930 U_BOOT_DRIVER(ti_edma3) = {
1933 .of_match = udma_ids,
1935 .probe = udma_probe,
1936 .priv_auto = sizeof(struct udma_dev),