| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * IPIC external definitions and structure. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2005-11-13 16:06:30 -08:00
										 |  |  |  * Maintainer: Kumar Gala <galak@kernel.crashing.org> | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Copyright 2005 Freescale Semiconductor, Inc | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute  it and/or modify it | 
					
						
							|  |  |  |  * under  the terms of  the GNU General  Public License as published by the | 
					
						
							|  |  |  |  * Free Software Foundation;  either version 2 of the  License, or (at your | 
					
						
							|  |  |  |  * option) any later version. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #ifdef __KERNEL__
 | 
					
						
							|  |  |  | #ifndef __ASM_IPIC_H__
 | 
					
						
							|  |  |  | #define __ASM_IPIC_H__
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <linux/irq.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Flags when we init the IPIC */ | 
					
						
							|  |  |  | #define IPIC_SPREADMODE_GRP_A	0x00000001
 | 
					
						
							| 
									
										
										
										
											2007-10-19 19:38:43 +08:00
										 |  |  | #define IPIC_SPREADMODE_GRP_B	0x00000002
 | 
					
						
							|  |  |  | #define IPIC_SPREADMODE_GRP_C	0x00000004
 | 
					
						
							|  |  |  | #define IPIC_SPREADMODE_GRP_D	0x00000008
 | 
					
						
							|  |  |  | #define IPIC_SPREADMODE_MIX_A	0x00000010
 | 
					
						
							|  |  |  | #define IPIC_SPREADMODE_MIX_B	0x00000020
 | 
					
						
							|  |  |  | #define IPIC_DISABLE_MCP_OUT	0x00000040
 | 
					
						
							|  |  |  | #define IPIC_IRQ0_MCP		0x00000080
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* IPIC registers offsets */ | 
					
						
							|  |  |  | #define IPIC_SICFR	0x00	/* System Global Interrupt Configuration Register */
 | 
					
						
							|  |  |  | #define IPIC_SIVCR	0x04	/* System Global Interrupt Vector Register */
 | 
					
						
							|  |  |  | #define IPIC_SIPNR_H	0x08	/* System Internal Interrupt Pending Register (HIGH) */
 | 
					
						
							|  |  |  | #define IPIC_SIPNR_L	0x0C	/* System Internal Interrupt Pending Register (LOW) */
 | 
					
						
							|  |  |  | #define IPIC_SIPRR_A	0x10	/* System Internal Interrupt group A Priority Register */
 | 
					
						
							|  |  |  | #define IPIC_SIPRR_B	0x14	/* System Internal Interrupt group B Priority Register */
 | 
					
						
							|  |  |  | #define IPIC_SIPRR_C	0x18	/* System Internal Interrupt group C Priority Register */
 | 
					
						
							|  |  |  | #define IPIC_SIPRR_D	0x1C	/* System Internal Interrupt group D Priority Register */
 | 
					
						
							|  |  |  | #define IPIC_SIMSR_H	0x20	/* System Internal Interrupt Mask Register (HIGH) */
 | 
					
						
							|  |  |  | #define IPIC_SIMSR_L	0x24	/* System Internal Interrupt Mask Register (LOW) */
 | 
					
						
							|  |  |  | #define IPIC_SICNR	0x28	/* System Internal Interrupt Control Register */
 | 
					
						
							|  |  |  | #define IPIC_SEPNR	0x2C	/* System External Interrupt Pending Register */
 | 
					
						
							|  |  |  | #define IPIC_SMPRR_A	0x30	/* System Mixed Interrupt group A Priority Register */
 | 
					
						
							|  |  |  | #define IPIC_SMPRR_B	0x34	/* System Mixed Interrupt group B Priority Register */
 | 
					
						
							|  |  |  | #define IPIC_SEMSR	0x38	/* System External Interrupt Mask Register */
 | 
					
						
							|  |  |  | #define IPIC_SECNR	0x3C	/* System External Interrupt Control Register */
 | 
					
						
							|  |  |  | #define IPIC_SERSR	0x40	/* System Error Status Register */
 | 
					
						
							|  |  |  | #define IPIC_SERMR	0x44	/* System Error Mask Register */
 | 
					
						
							|  |  |  | #define IPIC_SERCR	0x48	/* System Error Control Register */
 | 
					
						
							|  |  |  | #define IPIC_SIFCR_H	0x50	/* System Internal Interrupt Force Register (HIGH) */
 | 
					
						
							|  |  |  | #define IPIC_SIFCR_L	0x54	/* System Internal Interrupt Force Register (LOW) */
 | 
					
						
							|  |  |  | #define IPIC_SEFCR	0x58	/* System External Interrupt Force Register */
 | 
					
						
							|  |  |  | #define IPIC_SERFR	0x5C	/* System Error Force Register */
 | 
					
						
							|  |  |  | #define IPIC_SCVCR	0x60	/* System Critical Interrupt Vector Register */
 | 
					
						
							|  |  |  | #define IPIC_SMVCR	0x64	/* System Management Interrupt Vector Register */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum ipic_prio_grp { | 
					
						
							|  |  |  | 	IPIC_INT_GRP_A = IPIC_SIPRR_A, | 
					
						
							|  |  |  | 	IPIC_INT_GRP_D = IPIC_SIPRR_D, | 
					
						
							|  |  |  | 	IPIC_MIX_GRP_A = IPIC_SMPRR_A, | 
					
						
							|  |  |  | 	IPIC_MIX_GRP_B = IPIC_SMPRR_B, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum ipic_mcp_irq { | 
					
						
							|  |  |  | 	IPIC_MCP_IRQ0 = 0, | 
					
						
							|  |  |  | 	IPIC_MCP_WDT  = 1, | 
					
						
							|  |  |  | 	IPIC_MCP_SBA  = 2, | 
					
						
							|  |  |  | 	IPIC_MCP_PCI1 = 5, | 
					
						
							|  |  |  | 	IPIC_MCP_PCI2 = 6, | 
					
						
							|  |  |  | 	IPIC_MCP_MU   = 7, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | extern int ipic_set_priority(unsigned int irq, unsigned int priority); | 
					
						
							|  |  |  | extern void ipic_set_highest_priority(unsigned int irq); | 
					
						
							|  |  |  | extern void ipic_set_default_priority(void); | 
					
						
							|  |  |  | extern void ipic_enable_mcp(enum ipic_mcp_irq mcp_irq); | 
					
						
							|  |  |  | extern void ipic_disable_mcp(enum ipic_mcp_irq mcp_irq); | 
					
						
							|  |  |  | extern u32 ipic_get_mcp_status(void); | 
					
						
							|  |  |  | extern void ipic_clear_mcp_status(u32 mask); | 
					
						
							| 
									
										
										
										
											2006-08-25 11:58:53 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-01-26 01:45:32 -06:00
										 |  |  | extern struct ipic * ipic_init(struct device_node *node, unsigned int flags); | 
					
						
							| 
									
										
										
										
											2006-10-07 22:08:26 +10:00
										 |  |  | extern unsigned int ipic_get_irq(void); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #endif /* __ASM_IPIC_H__ */
 | 
					
						
							|  |  |  | #endif /* __KERNEL__ */
 |