ints.c 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. /*
  2. * linux/arch/$(ARCH)/platform/$(PLATFORM)/ints.c
  3. *
  4. * This file is subject to the terms and conditions of the GNU General Public
  5. * License. See the file COPYING in the main directory of this archive
  6. * for more details.
  7. *
  8. * Copyright (c) 2000 Michael Leslie <mleslie@lineo.com>
  9. * Copyright (c) 1996 Roman Zippel
  10. * Copyright (c) 1999 D. Jeff Dionne <jeff@uclinux.org>
  11. */
  12. #include <linux/types.h>
  13. #include <linux/kernel.h>
  14. #include <linux/init.h>
  15. #include <linux/interrupt.h>
  16. #include <linux/irq.h>
  17. #include <asm/traps.h>
  18. #include <asm/machdep.h>
  19. #include <asm/m68360.h>
  20. /* from quicc/commproc.c: */
  21. extern QUICC *pquicc;
  22. extern void cpm_interrupt_init(void);
  23. #define INTERNAL_IRQS (96)
  24. /* assembler routines */
  25. asmlinkage void system_call(void);
  26. asmlinkage void buserr(void);
  27. asmlinkage void trap(void);
  28. asmlinkage void bad_interrupt(void);
  29. asmlinkage void inthandler(void);
  30. extern void *_ramvec[];
  31. /* The number of spurious interrupts */
  32. volatile unsigned int num_spurious;
  33. /*
  34. * This function should be called during kernel startup to initialize
  35. * the vector table.
  36. */
  37. void init_vectors(void)
  38. {
  39. int i;
  40. int vba = (CPM_VECTOR_BASE<<4);
  41. /* set up the vectors */
  42. _ramvec[2] = buserr;
  43. _ramvec[3] = trap;
  44. _ramvec[4] = trap;
  45. _ramvec[5] = trap;
  46. _ramvec[6] = trap;
  47. _ramvec[7] = trap;
  48. _ramvec[8] = trap;
  49. _ramvec[9] = trap;
  50. _ramvec[10] = trap;
  51. _ramvec[11] = trap;
  52. _ramvec[12] = trap;
  53. _ramvec[13] = trap;
  54. _ramvec[14] = trap;
  55. _ramvec[15] = trap;
  56. _ramvec[32] = system_call;
  57. _ramvec[33] = trap;
  58. cpm_interrupt_init();
  59. /* set up CICR for vector base address and irq level */
  60. /* irl = 4, hp = 1f - see MC68360UM p 7-377 */
  61. pquicc->intr_cicr = 0x00e49f00 | vba;
  62. /* CPM interrupt vectors: (p 7-376) */
  63. _ramvec[vba+CPMVEC_ERROR] = bad_interrupt; /* Error */
  64. _ramvec[vba+CPMVEC_PIO_PC11] = inthandler; /* pio - pc11 */
  65. _ramvec[vba+CPMVEC_PIO_PC10] = inthandler; /* pio - pc10 */
  66. _ramvec[vba+CPMVEC_SMC2] = inthandler; /* smc2/pip */
  67. _ramvec[vba+CPMVEC_SMC1] = inthandler; /* smc1 */
  68. _ramvec[vba+CPMVEC_SPI] = inthandler; /* spi */
  69. _ramvec[vba+CPMVEC_PIO_PC9] = inthandler; /* pio - pc9 */
  70. _ramvec[vba+CPMVEC_TIMER4] = inthandler; /* timer 4 */
  71. _ramvec[vba+CPMVEC_RESERVED1] = inthandler; /* reserved */
  72. _ramvec[vba+CPMVEC_PIO_PC8] = inthandler; /* pio - pc8 */
  73. _ramvec[vba+CPMVEC_PIO_PC7] = inthandler; /* pio - pc7 */
  74. _ramvec[vba+CPMVEC_PIO_PC6] = inthandler; /* pio - pc6 */
  75. _ramvec[vba+CPMVEC_TIMER3] = inthandler; /* timer 3 */
  76. _ramvec[vba+CPMVEC_RISCTIMER] = inthandler; /* reserved */
  77. _ramvec[vba+CPMVEC_PIO_PC5] = inthandler; /* pio - pc5 */
  78. _ramvec[vba+CPMVEC_PIO_PC4] = inthandler; /* pio - pc4 */
  79. _ramvec[vba+CPMVEC_RESERVED2] = inthandler; /* reserved */
  80. _ramvec[vba+CPMVEC_RISCTIMER] = inthandler; /* timer table */
  81. _ramvec[vba+CPMVEC_TIMER2] = inthandler; /* timer 2 */
  82. _ramvec[vba+CPMVEC_RESERVED3] = inthandler; /* reserved */
  83. _ramvec[vba+CPMVEC_IDMA2] = inthandler; /* idma 2 */
  84. _ramvec[vba+CPMVEC_IDMA1] = inthandler; /* idma 1 */
  85. _ramvec[vba+CPMVEC_SDMA_CB_ERR] = inthandler; /* sdma channel bus error */
  86. _ramvec[vba+CPMVEC_PIO_PC3] = inthandler; /* pio - pc3 */
  87. _ramvec[vba+CPMVEC_PIO_PC2] = inthandler; /* pio - pc2 */
  88. /* _ramvec[vba+CPMVEC_TIMER1] = cpm_isr_timer1; */ /* timer 1 */
  89. _ramvec[vba+CPMVEC_TIMER1] = inthandler; /* timer 1 */
  90. _ramvec[vba+CPMVEC_PIO_PC1] = inthandler; /* pio - pc1 */
  91. _ramvec[vba+CPMVEC_SCC4] = inthandler; /* scc 4 */
  92. _ramvec[vba+CPMVEC_SCC3] = inthandler; /* scc 3 */
  93. _ramvec[vba+CPMVEC_SCC2] = inthandler; /* scc 2 */
  94. _ramvec[vba+CPMVEC_SCC1] = inthandler; /* scc 1 */
  95. _ramvec[vba+CPMVEC_PIO_PC0] = inthandler; /* pio - pc0 */
  96. /* turn off all CPM interrupts */
  97. pquicc->intr_cimr = 0x00000000;
  98. }
  99. void enable_vector(unsigned int irq)
  100. {
  101. pquicc->intr_cimr |= (1 << irq);
  102. }
  103. void disable_vector(unsigned int irq)
  104. {
  105. pquicc->intr_cimr &= ~(1 << irq);
  106. }
  107. void ack_vector(unsigned int irq)
  108. {
  109. pquicc->intr_cisr = (1 << irq);
  110. }