setup.c 2.7 KB

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