diff options
| author | Olof Johansson <olof@lixom.net> | 2013-01-14 20:22:00 -0500 |
|---|---|---|
| committer | Olof Johansson <olof@lixom.net> | 2013-01-14 22:55:03 -0500 |
| commit | f8060f5446b1f2782f0a8ca9be2d870ea4198aee (patch) | |
| tree | 6bdce95a558843b00d692738150e8c06a227db50 /include/linux | |
| parent | 175dbc1eeadbdcf5f04d3a61fdc0ede4335c45c8 (diff) | |
| parent | 9e47b8bf9815523a5816f2f83e73b13812d74014 (diff) | |
Merge tag 'gic-vic-to-irqchip' of git://sources.calxeda.com/kernel/linux into next/cleanup
From Rob Herring:
Initial irqchip init infrastructure and GIC and VIC clean-ups
This creates irqchip initialization infrastructure from Thomas
Petazzoni. The VIC and GIC irqchip code is moved to drivers/irqchips
and adapted to use the new infrastructure. All DT enabled platforms
using GIC and VIC are converted over to use the new irqchip_init.
* tag 'gic-vic-to-irqchip' of git://sources.calxeda.com/kernel/linux:
irqchip: Move ARM vic.h to include/linux/irqchip/arm-vic.h
ARM: picoxcell: use common irqchip_init function
ARM: spear: use common irqchip_init function
irqchip: Move ARM VIC to drivers/irqchip
ARM: samsung: remove unused tick.h
ARM: remove unneeded vic.h includes
ARM: remove mach .handle_irq for VIC users
ARM: VIC: set handle_arch_irq in VIC initialization
ARM: VIC: shrink down vic.h
irqchip: Move ARM gic.h to include/linux/irqchip/arm-gic.h
ARM: use common irqchip_init for GIC init
irqchip: Move ARM GIC to drivers/irqchip
ARM: remove mach .handle_irq for GIC users
ARM: GIC: set handle_arch_irq in GIC initialization
ARM: GIC: remove direct use of gic_raise_softirq
ARM: GIC: remove assembly ifdefs from gic.h
ARM: mach-ux500: use SGI0 to wake up the other core
arm: add set_handle_irq() to register the parent IRQ controller handler function
irqchip: add basic infrastructure
irqchip: add to the directories part of the IRQ subsystem in MAINTAINERS
Fixed up massive merge conflicts with the timer cleanup due to adjacent changes:
Signed-off-by: Olof Johansson <olof@lixom.net>
Conflicts:
arch/arm/mach-bcm/board_bcm.c
arch/arm/mach-cns3xxx/cns3420vb.c
arch/arm/mach-ep93xx/adssphere.c
arch/arm/mach-ep93xx/edb93xx.c
arch/arm/mach-ep93xx/gesbc9312.c
arch/arm/mach-ep93xx/micro9.c
arch/arm/mach-ep93xx/simone.c
arch/arm/mach-ep93xx/snappercl15.c
arch/arm/mach-ep93xx/ts72xx.c
arch/arm/mach-ep93xx/vision_ep9307.c
arch/arm/mach-highbank/highbank.c
arch/arm/mach-imx/mach-imx6q.c
arch/arm/mach-msm/board-dt-8960.c
arch/arm/mach-netx/nxdb500.c
arch/arm/mach-netx/nxdkn.c
arch/arm/mach-netx/nxeb500hmi.c
arch/arm/mach-nomadik/board-nhk8815.c
arch/arm/mach-picoxcell/common.c
arch/arm/mach-realview/realview_eb.c
arch/arm/mach-realview/realview_pb1176.c
arch/arm/mach-realview/realview_pb11mp.c
arch/arm/mach-realview/realview_pba8.c
arch/arm/mach-realview/realview_pbx.c
arch/arm/mach-socfpga/socfpga.c
arch/arm/mach-spear13xx/spear1310.c
arch/arm/mach-spear13xx/spear1340.c
arch/arm/mach-spear13xx/spear13xx.c
arch/arm/mach-spear3xx/spear300.c
arch/arm/mach-spear3xx/spear310.c
arch/arm/mach-spear3xx/spear320.c
arch/arm/mach-spear3xx/spear3xx.c
arch/arm/mach-spear6xx/spear6xx.c
arch/arm/mach-tegra/board-dt-tegra20.c
arch/arm/mach-tegra/board-dt-tegra30.c
arch/arm/mach-u300/core.c
arch/arm/mach-ux500/board-mop500.c
arch/arm/mach-ux500/cpu-db8500.c
arch/arm/mach-versatile/versatile_ab.c
arch/arm/mach-versatile/versatile_dt.c
arch/arm/mach-versatile/versatile_pb.c
arch/arm/mach-vexpress/v2m.c
include/asm-generic/vmlinux.lds.h
Diffstat (limited to 'include/linux')
| -rw-r--r-- | include/linux/irqchip.h | 16 | ||||
| -rw-r--r-- | include/linux/irqchip/arm-gic.h | 48 | ||||
| -rw-r--r-- | include/linux/irqchip/arm-vic.h | 36 |
3 files changed, 100 insertions, 0 deletions
diff --git a/include/linux/irqchip.h b/include/linux/irqchip.h new file mode 100644 index 000000000000..e0006f1d35a0 --- /dev/null +++ b/include/linux/irqchip.h | |||
| @@ -0,0 +1,16 @@ | |||
| 1 | /* | ||
| 2 | * Copyright (C) 2012 Thomas Petazzoni | ||
| 3 | * | ||
| 4 | * Thomas Petazzoni <thomas.petazzoni@free-electrons.com> | ||
| 5 | * | ||
| 6 | * This file is licensed under the terms of the GNU General Public | ||
| 7 | * License version 2. This program is licensed "as is" without any | ||
| 8 | * warranty of any kind, whether express or implied. | ||
| 9 | */ | ||
| 10 | |||
| 11 | #ifndef _LINUX_IRQCHIP_H | ||
| 12 | #define _LINUX_IRQCHIP_H | ||
| 13 | |||
| 14 | void irqchip_init(void); | ||
| 15 | |||
| 16 | #endif | ||
diff --git a/include/linux/irqchip/arm-gic.h b/include/linux/irqchip/arm-gic.h new file mode 100644 index 000000000000..a67ca55e6f4e --- /dev/null +++ b/include/linux/irqchip/arm-gic.h | |||
| @@ -0,0 +1,48 @@ | |||
| 1 | /* | ||
| 2 | * include/linux/irqchip/arm-gic.h | ||
| 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 | */ | ||
| 10 | #ifndef __LINUX_IRQCHIP_ARM_GIC_H | ||
| 11 | #define __LINUX_IRQCHIP_ARM_GIC_H | ||
| 12 | |||
| 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 | ||
| 23 | #define GIC_DIST_ENABLE_SET 0x100 | ||
| 24 | #define GIC_DIST_ENABLE_CLEAR 0x180 | ||
| 25 | #define GIC_DIST_PENDING_SET 0x200 | ||
| 26 | #define GIC_DIST_PENDING_CLEAR 0x280 | ||
| 27 | #define GIC_DIST_ACTIVE_BIT 0x300 | ||
| 28 | #define GIC_DIST_PRI 0x400 | ||
| 29 | #define GIC_DIST_TARGET 0x800 | ||
| 30 | #define GIC_DIST_CONFIG 0xc00 | ||
| 31 | #define GIC_DIST_SOFTINT 0xf00 | ||
| 32 | |||
| 33 | struct device_node; | ||
| 34 | |||
| 35 | extern struct irq_chip gic_arch_extn; | ||
| 36 | |||
| 37 | void gic_init_bases(unsigned int, int, void __iomem *, void __iomem *, | ||
| 38 | u32 offset, struct device_node *); | ||
| 39 | void gic_secondary_init(unsigned int); | ||
| 40 | void gic_cascade_irq(unsigned int gic_nr, unsigned int irq); | ||
| 41 | |||
| 42 | static inline void gic_init(unsigned int nr, int start, | ||
| 43 | void __iomem *dist , void __iomem *cpu) | ||
| 44 | { | ||
| 45 | gic_init_bases(nr, start, dist, cpu, 0, NULL); | ||
| 46 | } | ||
| 47 | |||
| 48 | #endif | ||
diff --git a/include/linux/irqchip/arm-vic.h b/include/linux/irqchip/arm-vic.h new file mode 100644 index 000000000000..e3c82dc95756 --- /dev/null +++ b/include/linux/irqchip/arm-vic.h | |||
| @@ -0,0 +1,36 @@ | |||
| 1 | /* | ||
| 2 | * arch/arm/include/asm/hardware/vic.h | ||
| 3 | * | ||
| 4 | * Copyright (c) ARM Limited 2003. 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 as published by | ||
| 8 | * the Free Software Foundation; either version 2 of the License, or | ||
| 9 | * (at your option) any later version. | ||
| 10 | * | ||
| 11 | * This program is distributed in the hope that it will be useful, | ||
| 12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 14 | * GNU General Public License for more details. | ||
| 15 | * | ||
| 16 | * You should have received a copy of the GNU General Public License | ||
| 17 | * along with this program; if not, write to the Free Software | ||
| 18 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
| 19 | */ | ||
| 20 | #ifndef __ASM_ARM_HARDWARE_VIC_H | ||
| 21 | #define __ASM_ARM_HARDWARE_VIC_H | ||
| 22 | |||
| 23 | #include <linux/types.h> | ||
| 24 | |||
| 25 | #define VIC_RAW_STATUS 0x08 | ||
| 26 | #define VIC_INT_ENABLE 0x10 /* 1 = enable, 0 = disable */ | ||
| 27 | #define VIC_INT_ENABLE_CLEAR 0x14 | ||
| 28 | |||
| 29 | struct device_node; | ||
| 30 | struct pt_regs; | ||
| 31 | |||
| 32 | void __vic_init(void __iomem *base, int irq_start, u32 vic_sources, | ||
| 33 | u32 resume_sources, struct device_node *node); | ||
| 34 | void vic_init(void __iomem *base, unsigned int irq_start, u32 vic_sources, u32 resume_sources); | ||
| 35 | |||
| 36 | #endif | ||
