irq.c 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. /*
  2. * arch/sh/boards/saturn/irq.c
  3. *
  4. * Copyright (C) 2002 Paul Mundt
  5. *
  6. * Released under the terms of the GNU GPL v2.0.
  7. */
  8. #include <linux/kernel.h>
  9. #include <linux/init.h>
  10. #include <linux/interrupt.h>
  11. #include <asm/irq.h>
  12. #include <asm/io.h>
  13. /*
  14. * Interrupts map out as follows:
  15. *
  16. * Vector Name Mask
  17. *
  18. * 64 VBLANKIN 0x0001
  19. * 65 VBLANKOUT 0x0002
  20. * 66 HBLANKIN 0x0004
  21. * 67 TIMER0 0x0008
  22. * 68 TIMER1 0x0010
  23. * 69 DSPEND 0x0020
  24. * 70 SOUNDREQUEST 0x0040
  25. * 71 SYSTEMMANAGER 0x0080
  26. * 72 PAD 0x0100
  27. * 73 LEVEL2DMAEND 0x0200
  28. * 74 LEVEL1DMAEND 0x0400
  29. * 75 LEVEL0DMAEND 0x0800
  30. * 76 DMAILLEGAL 0x1000
  31. * 77 SRITEDRAWEND 0x2000
  32. * 78 ABUS 0x8000
  33. *
  34. */
  35. #define SATURN_IRQ_MIN 64 /* VBLANKIN */
  36. #define SATURN_IRQ_MAX 78 /* ABUS */
  37. #define SATURN_IRQ_MASK 0xbfff
  38. static inline u32 saturn_irq_mask(unsigned int irq_nr)
  39. {
  40. u32 mask;
  41. mask = (1 << (irq_nr - SATURN_IRQ_MIN));
  42. mask <<= (irq_nr == SATURN_IRQ_MAX);
  43. mask &= SATURN_IRQ_MASK;
  44. return mask;
  45. }
  46. static inline void mask_saturn_irq(unsigned int irq_nr)
  47. {
  48. u32 mask;
  49. mask = ctrl_inl(SATURN_IMR);
  50. mask |= saturn_irq_mask(irq_nr);
  51. ctrl_outl(mask, SATURN_IMR);
  52. }
  53. static inline void unmask_saturn_irq(unsigned int irq_nr)
  54. {
  55. u32 mask;
  56. mask = ctrl_inl(SATURN_IMR);
  57. mask &= ~saturn_irq_mask(irq_nr);
  58. ctrl_outl(mask, SATURN_IMR);
  59. }
  60. static void disable_saturn_irq(unsigned int irq_nr)
  61. {
  62. mask_saturn_irq(irq_nr);
  63. }
  64. static void enable_saturn_irq(unsigned int irq_nr)
  65. {
  66. unmask_saturn_irq(irq_nr);
  67. }
  68. static void mask_and_ack_saturn_irq(unsigned int irq_nr)
  69. {
  70. mask_saturn_irq(irq_nr);
  71. }
  72. static void end_saturn_irq(unsigned int irq_nr)
  73. {
  74. if (!(irq_desc[irq_nr].status & (IRQ_DISABLED | IRQ_INPROGRESS)))
  75. unmask_saturn_irq(irq_nr);
  76. }
  77. static unsigned int startup_saturn_irq(unsigned int irq_nr)
  78. {
  79. unmask_saturn_irq(irq_nr);
  80. return 0;
  81. }
  82. static void shutdown_saturn_irq(unsigned int irq_nr)
  83. {
  84. mask_saturn_irq(irq_nr);
  85. }
  86. static struct hw_interrupt_type saturn_int = {
  87. .typename = "Saturn",
  88. .enable = enable_saturn_irq,
  89. .disable = disable_saturn_irq,
  90. .ack = mask_and_ack_saturn_irq,
  91. .end = end_saturn_irq,
  92. .startup = startup_saturn_irq,
  93. .shutdown = shutdown_saturn_irq,
  94. };
  95. int saturn_irq_demux(int irq_nr)
  96. {
  97. /* FIXME */
  98. return irq_nr;
  99. }