# Xilinx AXI DMA configuration options # Copyright (c) 2023 CISPA Helmholtz Center for Information Security gGmbH # SPDX-License-Identifier: Apache-2.0 config DMA_XILINX_AXI_DMA bool "Xilinx AXI DMA LogiCORE IP driver" default y depends on DT_HAS_XLNX_AXI_DMA_1_00_A_ENABLED || DT_HAS_XLNX_ETH_DMA_ENABLED help DMA driver for Xilinx AXI DMAs, usually found on FPGAs. config DMA_XILINX_AXI_DMA_DISABLE_CACHE_WHEN_ACCESSING_SG_DESCRIPTORS bool "Disable data cache while accessing Scatter-Gather Descriptors." depends on DMA_XILINX_AXI_DMA default n help Disable dcache while operating on Scatter-Gather descriptors. This allows the DMA to be used on architectures that do not provide coherency for DMA accesses. If you are unsure whether you need this feature, you should select n here. config DMA_XILINX_AXI_DMA_SG_DESCRIPTOR_NUM_TX int "Number of transfer descriptors allocated for transmission (TX)." depends on DMA_XILINX_AXI_DMA default 16 help The Xilinx AXI DMA uses a ring of in-memory DMA descriptors which reference the buffers containing the network packets and control and status information. Increasing the number of descriptors increases the amount of packets in flight, which benefits performance, while increasing memory usage. config DMA_XILINX_AXI_DMA_SG_DESCRIPTOR_NUM_RX int "Number of transfer descriptors allocated for reception (RX)." depends on DMA_XILINX_AXI_DMA default 16 help The AXI DMA driver currently allocates a single DMA descriptor for each RX transfer, because transfers need to be started by the upstream driver. choice prompt "IRQs to lock when manipulating per-channel data structures during dma_start." depends on DMA_XILINX_AXI_DMA default DMA_XILINX_AXI_DMA_LOCK_ALL_IRQS config DMA_XILINX_AXI_DMA_LOCK_ALL_IRQS bool "Lock all IRQs" help Lock all interrupts (including, e.g., timers and scheduler) when modifying channel data during dma_start. This is required when calling dma_start outside of the TX/RX callbacks. This is the safest option and the default, select this if you are unsure. config DMA_XILINX_AXI_DMA_LOCK_DMA_IRQS bool "Lock TX and RX IRQs" help Lock all interrupts of this DMA device when modifying channel data during dma_start. This is only safe when dma_start is only called from the TX/RX callbacks (and possibly once directly after initialization of the DMA). config DMA_XILINX_AXI_DMA_LOCK_CHANNEL_IRQ bool "Lock IRQs of the DMA channel" help Only lock the interrupt of the DMA channel whose data are to be modified during dma_start. Only select this when you can guarantee that dma_start is only called from the callback registered for the same channel. endchoice config DMA_XILINX_AXI_DMA_POLL_INTERVAL int "Period of the timer used for polling the DMA in milliseconds" depends on DMA_XILINX_AXI_DMA default 100 help On certain platforms (e.g., RISC-V), the DMA driver can sometimes miss interrupts. This can cause the DMA driver to stop processing completed transactions. In order to prevent this, the DMA driver periodically polls the DMA's registers and determines whether it needs to handle outstanding transactions. This configuration controls how often this happens. Choose a larger value to minimize overhead and a smaller value to minimize worst-case latency. config DMA_XILINX_AXI_DMA_INTERRUPT_THRESHOLD int "Number of completed transactions after which to trigger an interrupt" depends on DMA_XILINX_AXI_DMA range 1 255 default 8 help Number of completed transactions after which to trigger an interrupt. Decrease to minimize latency, increase to minimize overhead introduced by interrupts. config DMA_XILINX_AXI_DMA_INTERRUPT_TIMEOUT int "Timeout for triggering an interrupt" depends on DMA_XILINX_AXI_DMA range 0 255 default 16 help Trigger an interrupt at the latest after CONFIG_DMA_XILINX_AXI_DMA_INTERRUPT_TIMEOUT * 125 * DMA_CLOCK_PERIOD cycles. This is useful in conjunction with DMA_XILINX_AXI_DMA_INTERRUPT_THRESHOLD - the DMA can raise an interrupt before the threshold is reached, minimizing latency in scenarios where only few transactions per second are completed. Set to 0 to disable this feature, i.e., interrupts will only be raised when the threshold has been reached.