OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [linux/] [linux-2.4/] [include/] [asm-alpha/] [irq.h] - Rev 1765

Compare with Previous | Blame | View Log

#ifndef _ALPHA_IRQ_H
#define _ALPHA_IRQ_H
 
/*
 *	linux/include/alpha/irq.h
 *
 *	(C) 1994 Linus Torvalds
 */
 
#include <linux/linkage.h>
#include <linux/config.h>
 
#if   defined(CONFIG_ALPHA_GENERIC)
 
/* Here NR_IRQS is not exact, but rather an upper bound.  This is used
   many places throughout the kernel to size static arrays.  That's ok,
   we'll use alpha_mv.nr_irqs when we want the real thing.  */
 
/* When LEGACY_START_ADDRESS is selected, we leave out:
     TITAN
     WILDFIRE
     MARVEL
*/
 
# if defined(CONFIG_ALPHA_LEGACY_START_ADDRESS)
#  define NR_IRQS	(128)		/* max is RAWHIDE/TAKARA */
# else
#  define NR_IRQS	(32768 + 16)	/* marvel - 32 pids */
# endif
 
#elif defined(CONFIG_ALPHA_CABRIOLET) || \
      defined(CONFIG_ALPHA_EB66P)     || \
      defined(CONFIG_ALPHA_EB164)     || \
      defined(CONFIG_ALPHA_PC164)     || \
      defined(CONFIG_ALPHA_LX164)
# define NR_IRQS	35
 
#elif defined(CONFIG_ALPHA_EB66)      || \
      defined(CONFIG_ALPHA_EB64P)     || \
      defined(CONFIG_ALPHA_MIKASA)
# define NR_IRQS	32
 
#elif defined(CONFIG_ALPHA_ALCOR)     || \
      defined(CONFIG_ALPHA_XLT)       || \
      defined(CONFIG_ALPHA_MIATA)     || \
      defined(CONFIG_ALPHA_RUFFIAN)   || \
      defined(CONFIG_ALPHA_RX164)     || \
      defined(CONFIG_ALPHA_NORITAKE)
# define NR_IRQS	48
 
#elif defined(CONFIG_ALPHA_SABLE)     || \
      defined(CONFIG_ALPHA_SX164)
# define NR_IRQS	40
 
#elif defined(CONFIG_ALPHA_DP264) || \
      defined(CONFIG_ALPHA_LYNX)  || \
      defined(CONFIG_ALPHA_SHARK) || \
      defined(CONFIG_ALPHA_EIGER)
# define NR_IRQS	64
 
#elif defined(CONFIG_ALPHA_TITAN)
#define NR_IRQS		80
 
#elif defined(CONFIG_ALPHA_RAWHIDE) || \
	defined(CONFIG_ALPHA_TAKARA)
# define NR_IRQS	128
 
#elif defined(CONFIG_ALPHA_WILDFIRE)
# define NR_IRQS	2048 /* enuff for 8 QBBs */
 
#elif defined(CONFIG_ALPHA_MARVEL)
# define NR_IRQS	(32768 + 16)	/* marvel - 32 pids */
 
#else /* everyone else */
# define NR_IRQS	16
#endif
 
static __inline__ int irq_cannonicalize(int irq)
{
	/*
	 * XXX is this true for all Alpha's?  The old serial driver
	 * did it this way for years without any complaints, so....
	 */
	return ((irq == 2) ? 9 : irq);
}
 
extern void disable_irq(unsigned int);
extern void disable_irq_nosync(unsigned int);
extern void enable_irq(unsigned int);
 
struct pt_regs;
extern void (*perf_irq)(unsigned long, struct pt_regs *);
 
 
#endif /* _ALPHA_IRQ_H */
 

Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.