setup.c 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. /* $Id: setup.c,v 1.1.2.4 2002/03/02 21:57:07 lethal Exp $
  2. *
  3. * linux/arch/sh/boards/se/770x/setup.c
  4. *
  5. * Copyright (C) 2000 Kazumoto Kojima
  6. *
  7. * Hitachi SolutionEngine Support.
  8. *
  9. */
  10. #include <linux/init.h>
  11. #include <asm/machvec.h>
  12. #include <asm/se.h>
  13. #include <asm/io.h>
  14. #include <asm/smc37c93x.h>
  15. void heartbeat_se(void);
  16. void init_se_IRQ(void);
  17. /*
  18. * Configure the Super I/O chip
  19. */
  20. static void __init smsc_config(int index, int data)
  21. {
  22. outb_p(index, INDEX_PORT);
  23. outb_p(data, DATA_PORT);
  24. }
  25. /* XXX: Another candidate for a more generic cchip machine vector */
  26. static void __init smsc_setup(char **cmdline_p)
  27. {
  28. outb_p(CONFIG_ENTER, CONFIG_PORT);
  29. outb_p(CONFIG_ENTER, CONFIG_PORT);
  30. /* FDC */
  31. smsc_config(CURRENT_LDN_INDEX, LDN_FDC);
  32. smsc_config(ACTIVATE_INDEX, 0x01);
  33. smsc_config(IRQ_SELECT_INDEX, 6); /* IRQ6 */
  34. /* IDE1 */
  35. smsc_config(CURRENT_LDN_INDEX, LDN_IDE1);
  36. smsc_config(ACTIVATE_INDEX, 0x01);
  37. smsc_config(IRQ_SELECT_INDEX, 14); /* IRQ14 */
  38. /* AUXIO (GPIO): to use IDE1 */
  39. smsc_config(CURRENT_LDN_INDEX, LDN_AUXIO);
  40. smsc_config(GPIO46_INDEX, 0x00); /* nIOROP */
  41. smsc_config(GPIO47_INDEX, 0x00); /* nIOWOP */
  42. /* COM1 */
  43. smsc_config(CURRENT_LDN_INDEX, LDN_COM1);
  44. smsc_config(ACTIVATE_INDEX, 0x01);
  45. smsc_config(IO_BASE_HI_INDEX, 0x03);
  46. smsc_config(IO_BASE_LO_INDEX, 0xf8);
  47. smsc_config(IRQ_SELECT_INDEX, 4); /* IRQ4 */
  48. /* COM2 */
  49. smsc_config(CURRENT_LDN_INDEX, LDN_COM2);
  50. smsc_config(ACTIVATE_INDEX, 0x01);
  51. smsc_config(IO_BASE_HI_INDEX, 0x02);
  52. smsc_config(IO_BASE_LO_INDEX, 0xf8);
  53. smsc_config(IRQ_SELECT_INDEX, 3); /* IRQ3 */
  54. /* RTC */
  55. smsc_config(CURRENT_LDN_INDEX, LDN_RTC);
  56. smsc_config(ACTIVATE_INDEX, 0x01);
  57. smsc_config(IRQ_SELECT_INDEX, 8); /* IRQ8 */
  58. /* XXX: PARPORT, KBD, and MOUSE will come here... */
  59. outb_p(CONFIG_EXIT, CONFIG_PORT);
  60. }
  61. /*
  62. * The Machine Vector
  63. */
  64. struct sh_machine_vector mv_se __initmv = {
  65. .mv_name = "SolutionEngine",
  66. .mv_setup = smsc_setup,
  67. #if defined(CONFIG_CPU_SH4)
  68. .mv_nr_irqs = 48,
  69. #elif defined(CONFIG_CPU_SUBTYPE_SH7708)
  70. .mv_nr_irqs = 32,
  71. #elif defined(CONFIG_CPU_SUBTYPE_SH7709)
  72. .mv_nr_irqs = 61,
  73. #elif defined(CONFIG_CPU_SUBTYPE_SH7705)
  74. .mv_nr_irqs = 86,
  75. #endif
  76. .mv_inb = se_inb,
  77. .mv_inw = se_inw,
  78. .mv_inl = se_inl,
  79. .mv_outb = se_outb,
  80. .mv_outw = se_outw,
  81. .mv_outl = se_outl,
  82. .mv_inb_p = se_inb_p,
  83. .mv_inw_p = se_inw,
  84. .mv_inl_p = se_inl,
  85. .mv_outb_p = se_outb_p,
  86. .mv_outw_p = se_outw,
  87. .mv_outl_p = se_outl,
  88. .mv_insb = se_insb,
  89. .mv_insw = se_insw,
  90. .mv_insl = se_insl,
  91. .mv_outsb = se_outsb,
  92. .mv_outsw = se_outsw,
  93. .mv_outsl = se_outsl,
  94. .mv_init_irq = init_se_IRQ,
  95. #ifdef CONFIG_HEARTBEAT
  96. .mv_heartbeat = heartbeat_se,
  97. #endif
  98. };
  99. ALIAS_MV(se)