Added register offsets and bits.

git-svn-id: https://urjtag.svn.sourceforge.net/svnroot/urjtag/trunk@148 b68d4a1b-bc3d-0410-92ed-d4ac073336b7
master
Marcel Telka 22 years ago
parent d510d3bff5
commit 85158fdc92

@ -24,22 +24,23 @@
* Documentation:
* [1] Intel Corporation, "Intel PXA250 and PXA210 Application Processors
* Developer's Manual", February 2002, Order Number: 278522-001
* [2] Intel Corporation, "Intel PXA250 and PXA210 Application Processors
* Specification Update", May 2002, Order Number: 278534-005
*
*/
#ifndef PXA2X0_DMA_H
#define PXA2X0_DMA_H
#ifndef uint32_t
typedef unsigned int uint32_t;
#include <common.h>
#if LANGUAGE == C
#include <stdint.h>
#endif
/* DMA Controller Registers */
#define DMA_BASE 0x40000000
#if LANGUAGE == C
typedef struct _DMA_dar {
uint32_t ddadr;
uint32_t dsadr;
@ -57,16 +58,62 @@ typedef volatile struct DMA_registers {
_DMA_dar dar[16];
} DMA_registers;
#ifndef DMA_pointer
#define DMA_pointer ((DMA_registers*) DMA_BASE)
#ifdef PXA2X0_UNMAPPED
#define DMA_pointer ((DMA_registers*) DMA_BASE)
#endif
#define DCSR(i) DMA_pointer->dcsr[i]
#define DINT DMA_pointer->dint
#define DRCMR(i) DMA_pointer->drcmr[i]
#define DDADR(i) DMA_pointer->dar[i].ddadr
#define DSADR(i) DMA_pointer->dar[i].dsadr
#define DTADR(i) DMA_pointer->dar[i].dtadr
#define DCMD(i) DMA_pointer->dar[i].dcmd
#define DCSR(i) DMA_pointer->dcsr[i]
#define DINT DMA_pointer->dint
#define DRCMR(i) DMA_pointer->drcmr[i]
#define DDADR(i) DMA_pointer->dar[i].ddadr
#define DSADR(i) DMA_pointer->dar[i].dsadr
#define DTADR(i) DMA_pointer->dar[i].dtadr
#define DCMD(i) DMA_pointer->dar[i].dcmd
#endif /* LANGUAGE == C */
#define DCSR_OFFSET(i) (i << 2)
#define DINT_OFFSET 0xF0
#define DRCMR_OFFSET(i) (0x100 + (i << 2))
#define DDADR_OFFSET(i) (0x200 + (i << 4))
#define DSADR_OFFSET(i) (0x204 + (i << 4))
#define DTADR_OFFSET(i) (0x208 + (i << 4))
#define DCMD_OFFSET(i) (0x20C + (i << 4))
/* DCSRx bits - see Table 5-7 in [1] */
#define DCSR_RUN bit(31)
#define DCSR_NODESCFETCH bit(30)
#define DCSR_STOPIRQEN bit(29)
#define DCSR_REQPEND bit(8)
#define DCSR_STOPSTATE bit(3)
#define DCSR_ENDINTR bit(2)
#define DCSR_STARTINTR bit(1)
#define DSCR_BUSERRINTR bit(0)
/* DRCMRx bits - see Table 5-8 in [1] */
#define DRCMR_MAPVLD bit(7)
#define DRCMR_CHLNUM_MASK 0x0000000F
#define DRCMR_CHLNUM(x) (x & DRCMR_CHLNUM_MASK)
/* DDADRx bits - see Table 5-9 in [1] */
#define DDADR_STOP bit(0)
/* DCMDx bits - see Table 5-12 in [1] */
#define DCMD_INCSRCADDR bit(31)
#define DCMD_INCTRGADDR bit(30)
#define DCMD_FLOWSRC bit(29)
#define DCMD_FLOWTRG bit(28)
#define DCMD_STARTIRQEN bit(22)
#define DCMD_ENDIRQEN bit(21)
#define DCMD_ENDIAN bit(18)
#define DCMD_SIZE_MASK 0x00030000
#define DCMD_SIZE(x) ((x << 16) & DCMD_SIZE_MASK)
#define DCMD_WIDTH_MASK 0x0000C000
#define DCMD_WIDTH(x) ((x << 14) & DCMD_WIDTH_MASK)
#define DCMD_LENGTH_MASK 0x00001FFF
#define DCMD_LENGTH(x) (x & DCMD_LENGTH_MASK)
#endif /* PXA2X0_DMA_H */
#endif /* PXA2X0_DMA_H */

Loading…
Cancel
Save