| Russell King | f27ecac | 2005-08-18 21:31:00 +0100 | [diff] [blame] | 1 | /* | 
| Rob Herring | 520f7bd | 2012-12-27 13:10:24 -0600 | [diff] [blame] | 2 | *  include/linux/irqchip/arm-gic.h | 
| Russell King | f27ecac | 2005-08-18 21:31:00 +0100 | [diff] [blame] | 3 | * | 
|  | 4 | *  Copyright (C) 2002 ARM Limited, All Rights Reserved. | 
|  | 5 | * | 
|  | 6 | * This program is free software; you can redistribute it and/or modify | 
|  | 7 | * it under the terms of the GNU General Public License version 2 as | 
|  | 8 | * published by the Free Software Foundation. | 
|  | 9 | */ | 
| Rob Herring | 520f7bd | 2012-12-27 13:10:24 -0600 | [diff] [blame] | 10 | #ifndef __LINUX_IRQCHIP_ARM_GIC_H | 
|  | 11 | #define __LINUX_IRQCHIP_ARM_GIC_H | 
| Russell King | f27ecac | 2005-08-18 21:31:00 +0100 | [diff] [blame] | 12 |  | 
| Russell King | f27ecac | 2005-08-18 21:31:00 +0100 | [diff] [blame] | 13 | #define GIC_CPU_CTRL			0x00 | 
|  | 14 | #define GIC_CPU_PRIMASK			0x04 | 
|  | 15 | #define GIC_CPU_BINPOINT		0x08 | 
|  | 16 | #define GIC_CPU_INTACK			0x0c | 
|  | 17 | #define GIC_CPU_EOI			0x10 | 
|  | 18 | #define GIC_CPU_RUNNINGPRI		0x14 | 
|  | 19 | #define GIC_CPU_HIGHPRI			0x18 | 
|  | 20 |  | 
|  | 21 | #define GIC_DIST_CTRL			0x000 | 
|  | 22 | #define GIC_DIST_CTR			0x004 | 
| Christoffer Dall | 7c7945a | 2013-01-23 13:18:03 -0500 | [diff] [blame] | 23 | #define GIC_DIST_IGROUP			0x080 | 
| Russell King | f27ecac | 2005-08-18 21:31:00 +0100 | [diff] [blame] | 24 | #define GIC_DIST_ENABLE_SET		0x100 | 
|  | 25 | #define GIC_DIST_ENABLE_CLEAR		0x180 | 
|  | 26 | #define GIC_DIST_PENDING_SET		0x200 | 
|  | 27 | #define GIC_DIST_PENDING_CLEAR		0x280 | 
| Christoffer Dall | 7c7945a | 2013-01-23 13:18:03 -0500 | [diff] [blame] | 28 | #define GIC_DIST_ACTIVE_SET		0x300 | 
|  | 29 | #define GIC_DIST_ACTIVE_CLEAR		0x380 | 
| Russell King | f27ecac | 2005-08-18 21:31:00 +0100 | [diff] [blame] | 30 | #define GIC_DIST_PRI			0x400 | 
|  | 31 | #define GIC_DIST_TARGET			0x800 | 
|  | 32 | #define GIC_DIST_CONFIG			0xc00 | 
|  | 33 | #define GIC_DIST_SOFTINT		0xf00 | 
|  | 34 |  | 
| Marc Zyngier | fdf77a7 | 2013-01-21 19:36:11 -0500 | [diff] [blame] | 35 | #define GICH_HCR			0x0 | 
|  | 36 | #define GICH_VTR			0x4 | 
|  | 37 | #define GICH_VMCR			0x8 | 
|  | 38 | #define GICH_MISR			0x10 | 
|  | 39 | #define GICH_EISR0 			0x20 | 
|  | 40 | #define GICH_EISR1 			0x24 | 
|  | 41 | #define GICH_ELRSR0 			0x30 | 
|  | 42 | #define GICH_ELRSR1 			0x34 | 
|  | 43 | #define GICH_APR			0xf0 | 
|  | 44 | #define GICH_LR0			0x100 | 
|  | 45 |  | 
|  | 46 | #define GICH_HCR_EN			(1 << 0) | 
|  | 47 | #define GICH_HCR_UIE			(1 << 1) | 
|  | 48 |  | 
|  | 49 | #define GICH_LR_VIRTUALID		(0x3ff << 0) | 
|  | 50 | #define GICH_LR_PHYSID_CPUID_SHIFT	(10) | 
|  | 51 | #define GICH_LR_PHYSID_CPUID		(7 << GICH_LR_PHYSID_CPUID_SHIFT) | 
|  | 52 | #define GICH_LR_STATE			(3 << 28) | 
|  | 53 | #define GICH_LR_PENDING_BIT		(1 << 28) | 
|  | 54 | #define GICH_LR_ACTIVE_BIT		(1 << 29) | 
|  | 55 | #define GICH_LR_EOI			(1 << 19) | 
|  | 56 |  | 
|  | 57 | #define GICH_MISR_EOI			(1 << 0) | 
|  | 58 | #define GICH_MISR_U			(1 << 1) | 
|  | 59 |  | 
| Marc Zyngier | a96ab03 | 2013-01-24 13:39:43 +0000 | [diff] [blame] | 60 | #ifndef __ASSEMBLY__ | 
|  | 61 |  | 
| Rob Herring | 4294f8b | 2011-09-28 21:25:31 -0500 | [diff] [blame] | 62 | struct device_node; | 
|  | 63 |  | 
| Santosh Shilimkar | d7ed36a | 2011-03-02 08:03:22 +0100 | [diff] [blame] | 64 | extern struct irq_chip gic_arch_extn; | 
| Russell King | ff2e27a | 2010-12-04 16:13:29 +0000 | [diff] [blame] | 65 |  | 
| Marc Zyngier | db0d4db | 2011-11-12 16:09:49 +0000 | [diff] [blame] | 66 | void gic_init_bases(unsigned int, int, void __iomem *, void __iomem *, | 
| Grant Likely | 7529495 | 2012-02-14 14:06:57 -0700 | [diff] [blame] | 67 | u32 offset, struct device_node *); | 
| Russell King | 3848953 | 2010-12-04 16:01:03 +0000 | [diff] [blame] | 68 | void gic_secondary_init(unsigned int); | 
| Catalin Marinas | b3a1bde | 2007-02-14 19:14:56 +0100 | [diff] [blame] | 69 | void gic_cascade_irq(unsigned int gic_nr, unsigned int irq); | 
| Changhwan Youn | e807acb | 2011-07-16 10:49:47 +0900 | [diff] [blame] | 70 |  | 
| Marc Zyngier | db0d4db | 2011-11-12 16:09:49 +0000 | [diff] [blame] | 71 | static inline void gic_init(unsigned int nr, int start, | 
|  | 72 | void __iomem *dist , void __iomem *cpu) | 
|  | 73 | { | 
| Grant Likely | 7529495 | 2012-02-14 14:06:57 -0700 | [diff] [blame] | 74 | gic_init_bases(nr, start, dist, cpu, 0, NULL); | 
| Marc Zyngier | db0d4db | 2011-11-12 16:09:49 +0000 | [diff] [blame] | 75 | } | 
|  | 76 |  | 
| Marc Zyngier | a96ab03 | 2013-01-24 13:39:43 +0000 | [diff] [blame] | 77 | #endif /* __ASSEMBLY */ | 
|  | 78 |  | 
| Russell King | f27ecac | 2005-08-18 21:31:00 +0100 | [diff] [blame] | 79 | #endif |