| 
									
										
										
										
											2005-08-18 21:31:00 +01:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2012-12-27 13:10:24 -06:00
										 |  |  |  *  include/linux/irqchip/arm-gic.h | 
					
						
							| 
									
										
										
										
											2005-08-18 21:31:00 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  *  Copyright (C) 2002 ARM Limited, All Rights Reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU General Public License version 2 as | 
					
						
							|  |  |  |  * published by the Free Software Foundation. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2012-12-27 13:10:24 -06:00
										 |  |  | #ifndef __LINUX_IRQCHIP_ARM_GIC_H
 | 
					
						
							|  |  |  | #define __LINUX_IRQCHIP_ARM_GIC_H
 | 
					
						
							| 
									
										
										
										
											2005-08-18 21:31:00 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define GIC_CPU_CTRL			0x00
 | 
					
						
							|  |  |  | #define GIC_CPU_PRIMASK			0x04
 | 
					
						
							|  |  |  | #define GIC_CPU_BINPOINT		0x08
 | 
					
						
							|  |  |  | #define GIC_CPU_INTACK			0x0c
 | 
					
						
							|  |  |  | #define GIC_CPU_EOI			0x10
 | 
					
						
							|  |  |  | #define GIC_CPU_RUNNINGPRI		0x14
 | 
					
						
							|  |  |  | #define GIC_CPU_HIGHPRI			0x18
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define GIC_DIST_CTRL			0x000
 | 
					
						
							|  |  |  | #define GIC_DIST_CTR			0x004
 | 
					
						
							| 
									
										
										
										
											2013-01-23 13:18:03 -05:00
										 |  |  | #define GIC_DIST_IGROUP			0x080
 | 
					
						
							| 
									
										
										
										
											2005-08-18 21:31:00 +01:00
										 |  |  | #define GIC_DIST_ENABLE_SET		0x100
 | 
					
						
							|  |  |  | #define GIC_DIST_ENABLE_CLEAR		0x180
 | 
					
						
							|  |  |  | #define GIC_DIST_PENDING_SET		0x200
 | 
					
						
							|  |  |  | #define GIC_DIST_PENDING_CLEAR		0x280
 | 
					
						
							| 
									
										
										
										
											2013-01-23 13:18:03 -05:00
										 |  |  | #define GIC_DIST_ACTIVE_SET		0x300
 | 
					
						
							|  |  |  | #define GIC_DIST_ACTIVE_CLEAR		0x380
 | 
					
						
							| 
									
										
										
										
											2005-08-18 21:31:00 +01:00
										 |  |  | #define GIC_DIST_PRI			0x400
 | 
					
						
							|  |  |  | #define GIC_DIST_TARGET			0x800
 | 
					
						
							|  |  |  | #define GIC_DIST_CONFIG			0xc00
 | 
					
						
							|  |  |  | #define GIC_DIST_SOFTINT		0xf00
 | 
					
						
							| 
									
										
										
										
											2012-04-12 01:40:31 -04:00
										 |  |  | #define GIC_DIST_SGI_PENDING_CLEAR	0xf10
 | 
					
						
							|  |  |  | #define GIC_DIST_SGI_PENDING_SET	0xf20
 | 
					
						
							| 
									
										
										
										
											2005-08-18 21:31:00 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-21 19:36:11 -05:00
										 |  |  | #define GICH_HCR			0x0
 | 
					
						
							|  |  |  | #define GICH_VTR			0x4
 | 
					
						
							|  |  |  | #define GICH_VMCR			0x8
 | 
					
						
							|  |  |  | #define GICH_MISR			0x10
 | 
					
						
							|  |  |  | #define GICH_EISR0 			0x20
 | 
					
						
							|  |  |  | #define GICH_EISR1 			0x24
 | 
					
						
							|  |  |  | #define GICH_ELRSR0 			0x30
 | 
					
						
							|  |  |  | #define GICH_ELRSR1 			0x34
 | 
					
						
							|  |  |  | #define GICH_APR			0xf0
 | 
					
						
							|  |  |  | #define GICH_LR0			0x100
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define GICH_HCR_EN			(1 << 0)
 | 
					
						
							|  |  |  | #define GICH_HCR_UIE			(1 << 1)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define GICH_LR_VIRTUALID		(0x3ff << 0)
 | 
					
						
							|  |  |  | #define GICH_LR_PHYSID_CPUID_SHIFT	(10)
 | 
					
						
							|  |  |  | #define GICH_LR_PHYSID_CPUID		(7 << GICH_LR_PHYSID_CPUID_SHIFT)
 | 
					
						
							|  |  |  | #define GICH_LR_STATE			(3 << 28)
 | 
					
						
							|  |  |  | #define GICH_LR_PENDING_BIT		(1 << 28)
 | 
					
						
							|  |  |  | #define GICH_LR_ACTIVE_BIT		(1 << 29)
 | 
					
						
							|  |  |  | #define GICH_LR_EOI			(1 << 19)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define GICH_MISR_EOI			(1 << 0)
 | 
					
						
							|  |  |  | #define GICH_MISR_U			(1 << 1)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-24 13:39:43 +00:00
										 |  |  | #ifndef __ASSEMBLY__
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-28 21:25:31 -05:00
										 |  |  | struct device_node; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-02 08:03:22 +01:00
										 |  |  | extern struct irq_chip gic_arch_extn; | 
					
						
							| 
									
										
										
										
											2010-12-04 16:13:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-12 16:09:49 +00:00
										 |  |  | void gic_init_bases(unsigned int, int, void __iomem *, void __iomem *, | 
					
						
							| 
									
										
										
										
											2012-02-14 14:06:57 -07:00
										 |  |  | 		    u32 offset, struct device_node *); | 
					
						
							| 
									
										
										
										
											2007-02-14 19:14:56 +01:00
										 |  |  | void gic_cascade_irq(unsigned int gic_nr, unsigned int irq); | 
					
						
							| 
									
										
										
										
											2013-03-19 23:59:04 -04:00
										 |  |  | void gic_cpu_if_down(void); | 
					
						
							| 
									
										
										
										
											2011-07-16 10:49:47 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-12 16:09:49 +00:00
										 |  |  | static inline void gic_init(unsigned int nr, int start, | 
					
						
							|  |  |  | 			    void __iomem *dist , void __iomem *cpu) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-02-14 14:06:57 -07:00
										 |  |  | 	gic_init_bases(nr, start, dist, cpu, 0, NULL); | 
					
						
							| 
									
										
										
										
											2011-11-12 16:09:49 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-28 18:48:19 -05:00
										 |  |  | void gic_send_sgi(unsigned int cpu_id, unsigned int irq); | 
					
						
							| 
									
										
										
										
											2012-07-05 21:33:26 -04:00
										 |  |  | int gic_get_cpu_id(unsigned int cpu); | 
					
						
							| 
									
										
										
										
											2012-04-12 01:40:31 -04:00
										 |  |  | void gic_migrate_target(unsigned int new_cpu_id); | 
					
						
							| 
									
										
										
										
											2012-11-28 18:17:25 -05:00
										 |  |  | unsigned long gic_get_sgir_physaddr(void); | 
					
						
							| 
									
										
										
										
											2012-04-12 01:40:31 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-24 13:39:43 +00:00
										 |  |  | #endif /* __ASSEMBLY */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-08-18 21:31:00 +01:00
										 |  |  | #endif
 |