Blame view

kernel/linux-rt-4.4.41/arch/alpha/include/asm/irq.h 2.26 KB
5113f6f70   김현기   kernel add
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
  #ifndef _ALPHA_IRQ_H
  #define _ALPHA_IRQ_H
  
  /*
   *	linux/include/alpha/irq.h
   *
   *	(C) 1994 Linus Torvalds
   */
  
  #include <linux/linkage.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
  
     This helps keep the kernel object size reasonable for the majority
     of machines.
  */
  
  # 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_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_canonicalize(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);
  }
  
  struct pt_regs;
  extern void (*perf_irq)(unsigned long, struct pt_regs *);
  
  #endif /* _ALPHA_IRQ_H */