blob: d526dd8e87d3b9927bd579339c59dab50070f397 [file] [log] [blame]
Rabin Vincent39ae7022010-07-26 11:12:15 +01001/*
2 * Copyright (C) ST-Ericsson SA 2010
3 *
4 * Author: Rabin Vincent <rabin.vincent@stericsson.com>
5 * License terms: GNU General Public License (GPL) version 2
6 */
7
8#ifndef __MACH_IRQS_BOARD_MOP500_H
9#define __MACH_IRQS_BOARD_MOP500_H
10
Mattias Wallina5de3dc2010-12-02 13:46:00 +010011/* Number of AB8500 irqs is taken from header file */
Linus Walleijee66e652011-12-02 14:16:33 +010012#include <linux/mfd/abx500/ab8500.h>
Rabin Vincent39ae7022010-07-26 11:12:15 +010013
14#define MOP500_AB8500_IRQ_BASE IRQ_BOARD_START
15#define MOP500_AB8500_IRQ_END (MOP500_AB8500_IRQ_BASE \
Linus Walleijd6255522012-02-20 21:42:24 +010016 + AB8500_MAX_NR_IRQS)
Rabin Vincentb8410a12010-08-09 19:18:17 +053017
Sundar Iyer556fb032010-12-03 20:35:38 +053018/* TC35892 */
Rabin Vincentb8410a12010-08-09 19:18:17 +053019#define TC35892_NR_INTERNAL_IRQS 8
20#define TC35892_INT_GPIO(x) (TC35892_NR_INTERNAL_IRQS + (x))
21#define TC35892_NR_GPIOS 24
22#define TC35892_NR_IRQS TC35892_INT_GPIO(TC35892_NR_GPIOS)
23
24#define MOP500_EGPIO_NR_IRQS TC35892_NR_IRQS
25
26#define MOP500_EGPIO_IRQ_BASE MOP500_AB8500_IRQ_END
27#define MOP500_EGPIO_IRQ_END (MOP500_EGPIO_IRQ_BASE \
28 + MOP500_EGPIO_NR_IRQS)
Sundar Iyer556fb032010-12-03 20:35:38 +053029/* STMPE1601 irqs */
30#define STMPE_NR_INTERNAL_IRQS 9
31#define STMPE_INT_GPIO(x) (STMPE_NR_INTERNAL_IRQS + (x))
32#define STMPE_NR_GPIOS 24
33#define STMPE_NR_IRQS STMPE_INT_GPIO(STMPE_NR_GPIOS)
Rabin Vincentb8410a12010-08-09 19:18:17 +053034
Sundar Iyer556fb032010-12-03 20:35:38 +053035#define MOP500_STMPE1601_IRQBASE MOP500_EGPIO_IRQ_END
36#define MOP500_STMPE1601_IRQ(x) (MOP500_STMPE1601_IRQBASE + (x))
37
Bibek Basu3ef374a2011-02-15 12:56:16 +053038#define MOP500_STMPE1601_IRQ_END \
39 MOP500_STMPE1601_IRQ(STMPE_NR_INTERNAL_IRQS)
Sundar Iyer556fb032010-12-03 20:35:38 +053040
Lee Jonesc3f78f02013-01-15 16:41:43 +000041#define MOP500_NR_IRQS MOP500_STMPE1601_IRQ_END
Bibek Basu3ef374a2011-02-15 12:56:16 +053042
43#define MOP500_IRQ_END MOP500_NR_IRQS
Rabin Vincent39ae7022010-07-26 11:12:15 +010044
Rabin Vincent06be2ef2011-03-29 21:59:51 +020045/*
46 * We may have several boards, but only one will run at a
47 * time, so the one with most IRQs will bump this ahead,
48 * but the IRQ_BOARD_START remains the same for either board.
49 */
Rabin Vincent39ae7022010-07-26 11:12:15 +010050#if MOP500_IRQ_END > IRQ_BOARD_END
51#undef IRQ_BOARD_END
52#define IRQ_BOARD_END MOP500_IRQ_END
53#endif
54
55#endif