PageRenderTime 31ms CodeModel.GetById 29ms app.highlight 1ms RepoModel.GetById 0ms app.codeStats 0ms

/arch/blackfin/mach-bf533/include/mach/irq.h

https://bitbucket.org/thekraven/iscream_thunderc-2.6.35
C++ Header | 150 lines | 88 code | 12 blank | 50 comment | 0 complexity | b8dc850cb2ef3ba73835129ad0a973c8 MD5 | raw file
Possible License(s): GPL-2.0, LGPL-2.0, AGPL-1.0
  1/*
  2 * Copyright 2005-2008 Analog Devices Inc.
  3 *
  4 * Licensed under the GPL-2 or later
  5 */
  6
  7#ifndef _BF533_IRQ_H_
  8#define _BF533_IRQ_H_
  9
 10/*
 11 * Interrupt source definitions
 12             Event Source    Core Event Name
 13Core        Emulation               **
 14 Events         (highest priority)  EMU         0
 15            Reset                   RST         1
 16            NMI                     NMI         2
 17            Exception               EVX         3
 18            Reserved                --          4
 19            Hardware Error          IVHW        5
 20            Core Timer              IVTMR       6 *
 21	    PLL Wakeup Interrupt    IVG7	7
 22	    DMA Error (generic)	    IVG7	8
 23	    PPI Error Interrupt     IVG7	9
 24	    SPORT0 Error Interrupt  IVG7	10
 25	    SPORT1 Error Interrupt  IVG7	11
 26	    SPI Error Interrupt	    IVG7	12
 27	    UART Error Interrupt    IVG7	13
 28	    RTC Interrupt	    IVG8        14
 29	    DMA0 Interrupt (PPI)    IVG8	15
 30	    DMA1 (SPORT0 RX)	    IVG9	16
 31	    DMA2 (SPORT0 TX)	    IVG9        17
 32	    DMA3 (SPORT1 RX)        IVG9	18
 33	    DMA4 (SPORT1 TX)	    IVG9	19
 34	    DMA5 (PPI)		    IVG10	20
 35	    DMA6 (UART RX)	    IVG10	21
 36	    DMA7 (UART TX)	    IVG10	22
 37	    Timer0		    IVG11	23
 38	    Timer1		    IVG11	24
 39	    Timer2		    IVG11	25
 40	    PF Interrupt A	    IVG12	26
 41	    PF Interrupt B	    IVG12	27
 42	    DMA8/9 Interrupt	    IVG13	28
 43	    DMA10/11 Interrupt	    IVG13	29
 44	    Watchdog Timer	    IVG13	30
 45
 46            Softirq		    IVG14       31
 47            System Call    --
 48                 (lowest priority)  IVG15       32 *
 49 */
 50#define SYS_IRQS	31
 51#define NR_PERI_INTS	24
 52
 53/* The ABSTRACT IRQ definitions */
 54/** the first seven of the following are fixed, the rest you change if you need to **/
 55#define	IRQ_EMU			0	/*Emulation */
 56#define	IRQ_RST			1	/*reset */
 57#define	IRQ_NMI			2	/*Non Maskable */
 58#define	IRQ_EVX			3	/*Exception */
 59#define	IRQ_UNUSED		4	/*- unused interrupt*/
 60#define	IRQ_HWERR		5	/*Hardware Error */
 61#define	IRQ_CORETMR		6	/*Core timer */
 62
 63#define	IRQ_PLL_WAKEUP		7	/*PLL Wakeup Interrupt */
 64#define	IRQ_DMA_ERROR		8	/*DMA Error (general) */
 65#define	IRQ_PPI_ERROR		9	/*PPI Error Interrupt */
 66#define	IRQ_SPORT0_ERROR	10	/*SPORT0 Error Interrupt */
 67#define	IRQ_SPORT1_ERROR	11	/*SPORT1 Error Interrupt */
 68#define	IRQ_SPI_ERROR		12	/*SPI Error Interrupt */
 69#define	IRQ_UART0_ERROR		13	/*UART Error Interrupt */
 70#define	IRQ_RTC			14	/*RTC Interrupt */
 71#define	IRQ_PPI			15	/*DMA0 Interrupt (PPI) */
 72#define	IRQ_SPORT0_RX		16	/*DMA1 Interrupt (SPORT0 RX) */
 73#define	IRQ_SPORT0_TX		17	/*DMA2 Interrupt (SPORT0 TX) */
 74#define	IRQ_SPORT1_RX		18	/*DMA3 Interrupt (SPORT1 RX) */
 75#define	IRQ_SPORT1_TX		19	/*DMA4 Interrupt (SPORT1 TX) */
 76#define	IRQ_SPI			20	/*DMA5 Interrupt (SPI) */
 77#define	IRQ_UART0_RX		21	/*DMA6 Interrupt (UART RX) */
 78#define	IRQ_UART0_TX		22	/*DMA7 Interrupt (UART TX) */
 79#define	IRQ_TIMER0		23	/*Timer 0 */
 80#define	IRQ_TIMER1		24	/*Timer 1 */
 81#define	IRQ_TIMER2		25	/*Timer 2 */
 82#define	IRQ_PROG_INTA		26	/*Programmable Flags A (8) */
 83#define	IRQ_PROG_INTB		27	/*Programmable Flags B (8) */
 84#define	IRQ_MEM_DMA0		28	/*DMA8/9 Interrupt (Memory DMA Stream 0) */
 85#define	IRQ_MEM_DMA1		29	/*DMA10/11 Interrupt (Memory DMA Stream 1) */
 86#define	IRQ_WATCH	   	30	/*Watch Dog Timer */
 87
 88#define IRQ_PF0			33
 89#define IRQ_PF1			34
 90#define IRQ_PF2			35
 91#define IRQ_PF3			36
 92#define IRQ_PF4			37
 93#define IRQ_PF5			38
 94#define IRQ_PF6			39
 95#define IRQ_PF7			40
 96#define IRQ_PF8			41
 97#define IRQ_PF9			42
 98#define IRQ_PF10		43
 99#define IRQ_PF11		44
100#define IRQ_PF12		45
101#define IRQ_PF13		46
102#define IRQ_PF14		47
103#define IRQ_PF15		48
104
105#define GPIO_IRQ_BASE		IRQ_PF0
106
107#define NR_MACH_IRQS		(IRQ_PF15 + 1)
108#define NR_IRQS			(NR_MACH_IRQS + NR_SPARE_IRQS)
109
110#define IVG7			7
111#define IVG8			8
112#define IVG9			9
113#define IVG10			10
114#define IVG11			11
115#define IVG12			12
116#define IVG13			13
117#define IVG14			14
118#define IVG15			15
119
120/* IAR0 BIT FIELDS*/
121#define RTC_ERROR_POS			28
122#define UART_ERROR_POS			24
123#define SPORT1_ERROR_POS		20
124#define SPI_ERROR_POS			16
125#define SPORT0_ERROR_POS		12
126#define PPI_ERROR_POS			8
127#define DMA_ERROR_POS			4
128#define PLLWAKE_ERROR_POS		0
129
130/* IAR1 BIT FIELDS*/
131#define DMA7_UARTTX_POS			28
132#define DMA6_UARTRX_POS			24
133#define DMA5_SPI_POS			20
134#define DMA4_SPORT1TX_POS		16
135#define DMA3_SPORT1RX_POS		12
136#define DMA2_SPORT0TX_POS		8
137#define DMA1_SPORT0RX_POS		4
138#define DMA0_PPI_POS			0
139
140/* IAR2 BIT FIELDS*/
141#define WDTIMER_POS			28
142#define MEMDMA1_POS			24
143#define MEMDMA0_POS			20
144#define PFB_POS				16
145#define PFA_POS				12
146#define TIMER2_POS			8
147#define TIMER1_POS			4
148#define TIMER0_POS			0
149
150#endif				/* _BF533_IRQ_H_ */