interrupts.c 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. /*
  2. * (C) Copyright 2006
  3. * Stefan Roese, DENX Software Engineering, sr@denx.de.
  4. *
  5. * (C) Copyright 2002
  6. * Sysgo Real-Time Solutions, GmbH <www.elinos.com>
  7. * Marius Groeger <mgroeger@sysgo.de>
  8. *
  9. * (C) Copyright 2002
  10. * Sysgo Real-Time Solutions, GmbH <www.elinos.com>
  11. * Alex Zuepke <azu@sysgo.de>
  12. *
  13. * SPDX-License-Identifier: GPL-2.0+
  14. */
  15. #include <common.h>
  16. #include <asm/arch/ixp425.h>
  17. #include <asm/proc-armv/ptrace.h>
  18. struct _irq_handler {
  19. void *m_data;
  20. void (*m_func)( void *data);
  21. };
  22. static struct _irq_handler IRQ_HANDLER[N_IRQS];
  23. static void default_isr(void *data)
  24. {
  25. printf("default_isr(): called for IRQ %d, Interrupt Status=%x PR=%x\n",
  26. (int)data, *IXP425_ICIP, *IXP425_ICIH);
  27. }
  28. static int next_irq(void)
  29. {
  30. return (((*IXP425_ICIH & 0x000000fc) >> 2) - 1);
  31. }
  32. void do_irq (struct pt_regs *pt_regs)
  33. {
  34. int irq = next_irq();
  35. IRQ_HANDLER[irq].m_func(IRQ_HANDLER[irq].m_data);
  36. }
  37. void irq_install_handler (int irq, interrupt_handler_t handle_irq, void *data)
  38. {
  39. if (irq >= N_IRQS || !handle_irq)
  40. return;
  41. IRQ_HANDLER[irq].m_data = data;
  42. IRQ_HANDLER[irq].m_func = handle_irq;
  43. }
  44. int arch_interrupt_init (void)
  45. {
  46. int i;
  47. /* install default interrupt handlers */
  48. for (i = 0; i < N_IRQS; i++)
  49. irq_install_handler(i, default_isr, (void *)i);
  50. /* configure interrupts for IRQ mode */
  51. *IXP425_ICLR = 0x00000000;
  52. return (0);
  53. }