| /* SPDX-License-Identifier: GPL-2.0 */ |
| /* Defines for using and allocating dma channels. */ |
| |
| #ifndef _ASM_ARCH_DMA_H |
| #define _ASM_ARCH_DMA_H |
| |
| #define MAX_DMA_CHANNELS 10 |
| |
| /* dma0 and dma1 used for network (ethernet) */ |
| #define NETWORK_TX_DMA_NBR 0 |
| #define NETWORK_RX_DMA_NBR 1 |
| |
| /* dma2 and dma3 shared by par0, scsi0, ser2 and ata */ |
| #define PAR0_TX_DMA_NBR 2 |
| #define PAR0_RX_DMA_NBR 3 |
| #define SCSI0_TX_DMA_NBR 2 |
| #define SCSI0_RX_DMA_NBR 3 |
| #define SER2_TX_DMA_NBR 2 |
| #define SER2_RX_DMA_NBR 3 |
| #define ATA_TX_DMA_NBR 2 |
| #define ATA_RX_DMA_NBR 3 |
| |
| /* dma4 and dma5 shared by par1, scsi1, ser3 and extdma0 */ |
| #define PAR1_TX_DMA_NBR 4 |
| #define PAR1_RX_DMA_NBR 5 |
| #define SCSI1_TX_DMA_NBR 4 |
| #define SCSI1_RX_DMA_NBR 5 |
| #define SER3_TX_DMA_NBR 4 |
| #define SER3_RX_DMA_NBR 5 |
| #define EXTDMA0_TX_DMA_NBR 4 |
| #define EXTDMA0_RX_DMA_NBR 5 |
| |
| /* dma6 and dma7 shared by ser0, extdma1 and mem2mem */ |
| #define SER0_TX_DMA_NBR 6 |
| #define SER0_RX_DMA_NBR 7 |
| #define EXTDMA1_TX_DMA_NBR 6 |
| #define EXTDMA1_RX_DMA_NBR 7 |
| #define MEM2MEM_TX_DMA_NBR 6 |
| #define MEM2MEM_RX_DMA_NBR 7 |
| |
| /* dma8 and dma9 shared by ser1 and usb */ |
| #define SER1_TX_DMA_NBR 8 |
| #define SER1_RX_DMA_NBR 9 |
| #define USB_TX_DMA_NBR 8 |
| #define USB_RX_DMA_NBR 9 |
| |
| #endif |
| |
| enum dma_owner |
| { |
| dma_eth, |
| dma_ser0, |
| dma_ser1, /* Async and sync */ |
| dma_ser2, |
| dma_ser3, /* Async and sync */ |
| dma_ata, |
| dma_par0, |
| dma_par1, |
| dma_ext0, |
| dma_ext1, |
| dma_int6, |
| dma_int7, |
| dma_usb, |
| dma_scsi0, |
| dma_scsi1 |
| }; |
| |
| /* Masks used by cris_request_dma options: */ |
| #define DMA_VERBOSE_ON_ERROR (1<<0) |
| #define DMA_PANIC_ON_ERROR ((1<<1)|DMA_VERBOSE_ON_ERROR) |
| |
| int cris_request_dma(unsigned int dmanr, const char * device_id, |
| unsigned options, enum dma_owner owner); |
| |
| void cris_free_dma(unsigned int dmanr, const char * device_id); |