mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-24 17:48:14 +01:00 
			
		
		
		
	Implement dma_get_cfg() interface to pass flow id information for DMA clients to use. This is needed because on K3 SoCs, CPSW (ethernet) and UDMA (DMA provider) support "flows" within a given RX DMA channel. This allows different network packets to be segregated while using same RX DMA channel. In order for basic ethernet to work, CPSW slave must be aware of the flow ID allocated for the RX channel by the DMA driver. This interface allows CPSW to query flow ID from DMA provider and configure it in CPSW HW. Signed-off-by: Vignesh Raghavendra <vigneshr@ti.com> Acked-by: Joe Hershberger <joe.hershberger@ni.com> Reviewed-by: Grygorii Strashko <grygorii.strashko@ti.com>
		
			
				
	
	
		
			44 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| /*
 | |
|  *  Copyright (C) 2018 Texas Instruments Incorporated - http://www.ti.com
 | |
|  *  Author: Peter Ujfalusi <peter.ujfalusi@ti.com>
 | |
|  */
 | |
| 
 | |
| #ifndef __TI_UDMA_H
 | |
| #define __TI_UDMA_H
 | |
| 
 | |
| /**
 | |
|  * struct ti_udma_drv_packet_data - TI UDMA transfer specific data
 | |
|  *
 | |
|  * @pkt_type: Packet Type - specific for each DMA client HW
 | |
|  * @dest_tag: Destination tag The source pointer.
 | |
|  *
 | |
|  * TI UDMA transfer specific data passed as part of DMA transfer to
 | |
|  * the DMA client HW in UDMA descriptors.
 | |
|  */
 | |
| struct ti_udma_drv_packet_data {
 | |
| 	u32	pkt_type;
 | |
| 	u32	dest_tag;
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * struct ti_udma_drv_chan_cfg_data - TI UDMA per channel specific
 | |
|  *                                     configuration data
 | |
|  *
 | |
|  * @flow_id_base: Start index of flow ID allocated to this channel
 | |
|  * @flow_id_cnt: Number of flows allocated for this channel starting at
 | |
|  *               flow_id_base
 | |
|  *
 | |
|  * TI UDMA channel specific data returned as part of dma_get_cfg() call
 | |
|  * from the DMA client driver.
 | |
|  */
 | |
| struct ti_udma_drv_chan_cfg_data {
 | |
| 	u32	flow_id_base;
 | |
| 	u32	flow_id_cnt;
 | |
| };
 | |
| 
 | |
| /* TI UDMA specific flag IDs for dma_get_cfg() call */
 | |
| #define TI_UDMA_CHAN_PRIV_INFO		0
 | |
| 
 | |
| #endif /* __TI_UDMA_H */
 |