irq.c 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * arch/sh/boards/mach-landisk/irq.c
  4. *
  5. * I-O DATA Device, Inc. LANDISK Support
  6. *
  7. * Copyright (C) 2005-2007 kogiidena
  8. * Copyright (C) 2011 Nobuhiro Iwamatsu
  9. *
  10. * Copyright (C) 2001 Ian da Silva, Jeremy Siegel
  11. * Based largely on io_se.c.
  12. */
  13. #include <linux/init.h>
  14. #include <linux/irq.h>
  15. #include <linux/interrupt.h>
  16. #include <linux/io.h>
  17. #include <mach-landisk/mach/iodata_landisk.h>
  18. enum {
  19. UNUSED = 0,
  20. PCI_INTA, /* PCI int A */
  21. PCI_INTB, /* PCI int B */
  22. PCI_INTC, /* PCI int C */
  23. PCI_INTD, /* PCI int D */
  24. ATA, /* ATA */
  25. FATA, /* CF */
  26. POWER, /* Power switch */
  27. BUTTON, /* Button switch */
  28. };
  29. /* Vectors for LANDISK */
  30. static struct intc_vect vectors_landisk[] __initdata = {
  31. INTC_IRQ(PCI_INTA, IRQ_PCIINTA),
  32. INTC_IRQ(PCI_INTB, IRQ_PCIINTB),
  33. INTC_IRQ(PCI_INTC, IRQ_PCIINTC),
  34. INTC_IRQ(PCI_INTD, IRQ_PCIINTD),
  35. INTC_IRQ(ATA, IRQ_ATA),
  36. INTC_IRQ(FATA, IRQ_FATA),
  37. INTC_IRQ(POWER, IRQ_POWER),
  38. INTC_IRQ(BUTTON, IRQ_BUTTON),
  39. };
  40. /* IRLMSK mask register layout for LANDISK */
  41. static struct intc_mask_reg mask_registers_landisk[] __initdata = {
  42. { PA_IMASK, 0, 8, /* IRLMSK */
  43. { BUTTON, POWER, FATA, ATA,
  44. PCI_INTD, PCI_INTC, PCI_INTB, PCI_INTA,
  45. }
  46. },
  47. };
  48. static DECLARE_INTC_DESC(intc_desc_landisk, "landisk", vectors_landisk, NULL,
  49. mask_registers_landisk, NULL, NULL);
  50. /*
  51. * Initialize IRQ setting
  52. */
  53. void __init init_landisk_IRQ(void)
  54. {
  55. register_intc_controller(&intc_desc_landisk);
  56. __raw_writeb(0x00, PA_PWRINT_CLR);
  57. }