/* Copyright (C) 2005-2006 by Texas Instruments */ #ifndef _CPPI_DMA_H_ #define _CPPI_DMA_H_ #include #include #include #include #include #include "dma.h" #include "musbdefs.h" #ifdef CONFIG_ARCH_DAVINCI #include "davinci.h" #endif #ifdef CONFIG_MIPS_UR8 #include "ur8.h" #endif /* hOptions bit masks for CPPI BDs */ #define CPPI_SOP_SET ((u32)(1 << 31)) #define CPPI_EOP_SET ((u32)(1 << 30)) #define CPPI_OWN_SET ((u32)(1 << 29)) /* owned by cppi */ #define CPPI_EOQ_MASK ((u32)(1 << 28)) #define CPPI_ZERO_SET ((u32)(1 << 23)) /* rx saw zlp; tx issues one */ #define CPPI_RXABT_MASK ((u32)(1 << 19)) /* need more rx buffers */ #define CPPI_RECV_PKTLEN_MASK 0xFFFF #define CPPI_BUFFER_LEN_MASK 0xFFFF #define CPPI_TEAR_READY ((u32)(1 << 31)) /* CPPI data structure definitions */ #define CPPI_DESCRIPTOR_ALIGN 16 // bytes; 5-dec docs say 4-byte align struct cppi_descriptor { /* Hardware Overlay */ u32 hNext; /**< Next(hardware) Buffer Descriptor Pointer */ u32 buffPtr; /**