blob: 35b360b82e43f9958d0f967347fcb2052a618578 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef _ASM_IA64_IRQ_H
2#define _ASM_IA64_IRQ_H
3
4/*
5 * Copyright (C) 1999-2000, 2002 Hewlett-Packard Co
6 * David Mosberger-Tang <davidm@hpl.hp.com>
7 * Stephane Eranian <eranian@hpl.hp.com>
8 *
9 * 11/24/98 S.Eranian updated TIMER_IRQ and irq_canonicalize
10 * 01/20/99 S.Eranian added keyboard interrupt
11 * 02/29/00 D.Mosberger moved most things into hw_irq.h
12 */
13
John Keller25d61572007-05-10 22:42:44 -070014#include <linux/types.h>
15#include <linux/cpumask.h>
16
Yasuaki Ishimatsu4994be12007-07-17 21:22:33 +090017#define NR_VECTORS 256
18
19#if (NR_VECTORS + 32 * NR_CPUS) < 1024
20#define NR_IRQS (NR_VECTORS + 32 * NR_CPUS)
21#else
22#define NR_IRQS 1024
23#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070024
25static __inline__ int
26irq_canonicalize (int irq)
27{
28 /*
29 * We do the legacy thing here of pretending that irqs < 16
30 * are 8259 irqs. This really shouldn't be necessary at all,
31 * but we keep it here as serial.c still uses it...
32 */
33 return ((irq == 2) ? 9 : irq);
34}
35
36extern void disable_irq (unsigned int);
37extern void disable_irq_nosync (unsigned int);
38extern void enable_irq (unsigned int);
39extern void set_irq_affinity_info (unsigned int irq, int dest, int redir);
John Keller25d61572007-05-10 22:42:44 -070040bool is_affinity_mask_valid(cpumask_t cpumask);
41
42#define is_affinity_mask_valid is_affinity_mask_valid
Linus Torvalds1da177e2005-04-16 15:20:36 -070043
Linus Torvalds1da177e2005-04-16 15:20:36 -070044#endif /* _ASM_IA64_IRQ_H */