irq-r7785rp.c 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. /*
  2. * Renesas Solutions Highlander R7785RP Support.
  3. *
  4. * Copyright (C) 2002 Atom Create Engineering Co., Ltd.
  5. * Copyright (C) 2006 Paul Mundt
  6. * Copyright (C) 2007 Magnus Damm
  7. *
  8. * This file is subject to the terms and conditions of the GNU General Public
  9. * License. See the file "COPYING" in the main directory of this archive
  10. * for more details.
  11. */
  12. #include <linux/init.h>
  13. #include <linux/irq.h>
  14. #include <linux/io.h>
  15. #include <asm/r7780rp.h>
  16. enum {
  17. UNUSED = 0,
  18. /* board specific interrupt sources */
  19. AX88796, /* Ethernet controller */
  20. CF, /* Compact Flash */
  21. };
  22. static struct intc_vect vectors[] __initdata = {
  23. INTC_IRQ(CF, IRQ_CF),
  24. INTC_IRQ(AX88796, IRQ_AX88796),
  25. };
  26. static struct intc_mask_reg mask_registers[] __initdata = {
  27. { 0xa4000010, 0, 16, /* IRLMCR1 */
  28. { 0, 0, 0, 0, CF, AX88796, 0, 0,
  29. 0, 0, 0, 0, 0, 0, 0, 0 } },
  30. };
  31. static unsigned char irl2irq[HL_NR_IRL] __initdata = {
  32. 0, IRQ_CF, 0, 0,
  33. 0, 0, 0, 0,
  34. 0, 0, IRQ_AX88796, 0,
  35. 0, 0, 0,
  36. };
  37. static DECLARE_INTC_DESC(intc_desc, "r7785rp", vectors,
  38. NULL, NULL, mask_registers, NULL, NULL);
  39. unsigned char * __init highlander_init_irq_r7785rp(void)
  40. {
  41. if ((ctrl_inw(0xa4000158) & 0xf000) != 0x1000)
  42. return NULL;
  43. printk(KERN_INFO "Using r7785rp interrupt controller.\n");
  44. ctrl_outw(0x0000, PA_IRLSSR1); /* FPGA IRLSSR1(CF_CD clear) */
  45. /* Setup the FPGA IRL */
  46. ctrl_outw(0x0000, PA_IRLPRA); /* FPGA IRLA */
  47. ctrl_outw(0xe598, PA_IRLPRB); /* FPGA IRLB */
  48. ctrl_outw(0x7060, PA_IRLPRC); /* FPGA IRLC */
  49. ctrl_outw(0x0000, PA_IRLPRD); /* FPGA IRLD */
  50. ctrl_outw(0x4321, PA_IRLPRE); /* FPGA IRLE */
  51. ctrl_outw(0x0000, PA_IRLPRF); /* FPGA IRLF */
  52. register_intc_controller(&intc_desc);
  53. return irl2irq;
  54. }