ide.h
上传用户:lgb322
上传日期:2013-02-24
资源大小:30529k
文件大小:3k
源码类别:

嵌入式Linux

开发平台:

Unix_Linux

  1. /*
  2.  *  linux/include/asm-sh/ide.h
  3.  *
  4.  *  Copyright (C) 1994-1996  Linus Torvalds & authors
  5.  */
  6. /*
  7.  *  This file contains the i386 architecture specific IDE code.
  8.  *  In future, SuperH code.
  9.  */
  10. #ifndef __ASM_SH_IDE_H
  11. #define __ASM_SH_IDE_H
  12. #ifdef __KERNEL__
  13. #include <linux/config.h>
  14. #include <asm/machvec.h>
  15. #ifndef MAX_HWIFS
  16. /* Should never have less than 2, ide-pci.c(ide_match_hwif) requires it */
  17. #define MAX_HWIFS 2
  18. #endif
  19. #define ide__sti() __sti()
  20. static __inline__ int ide_default_irq_hp600(ide_ioreg_t base)
  21. {
  22. switch (base) {
  23. case 0x01f0: return 93;
  24. case 0x0170: return 94;
  25. default:
  26. return 0;
  27. }
  28. }
  29. static __inline__ int ide_default_irq(ide_ioreg_t base)
  30. {
  31. if (MACH_HP600) {
  32. return ide_default_irq_hp600(base);
  33. }
  34. switch (base) {
  35. case 0x01f0: return 14;
  36. case 0x0170: return 15;
  37. default:
  38. return 0;
  39. }
  40. }
  41. static __inline__ ide_ioreg_t ide_default_io_base_hp600(int index)
  42. {
  43. switch (index) {
  44. case 0:
  45. return 0x01f0;
  46. case 1:
  47. return 0x0170;
  48. default:
  49. return 0;
  50. }
  51. }
  52. static __inline__ ide_ioreg_t ide_default_io_base(int index)
  53. {
  54. if (MACH_HP600) {
  55. return ide_default_io_base_hp600(index);
  56. }
  57. switch (index) {
  58. case 0:
  59. return 0x1f0;
  60. case 1:
  61. return 0x170;
  62. default:
  63. return 0;
  64. }
  65. }
  66. static __inline__ void ide_init_hwif_ports(hw_regs_t *hw, ide_ioreg_t data_port, ide_ioreg_t ctrl_port, int *irq)
  67. {
  68. ide_ioreg_t reg = data_port;
  69. int i;
  70. for (i = IDE_DATA_OFFSET; i <= IDE_STATUS_OFFSET; i++) {
  71. hw->io_ports[i] = reg;
  72. reg += 1;
  73. }
  74. if (ctrl_port) {
  75. hw->io_ports[IDE_CONTROL_OFFSET] = ctrl_port;
  76. } else {
  77. hw->io_ports[IDE_CONTROL_OFFSET] = hw->io_ports[IDE_DATA_OFFSET] + 0x206;
  78. }
  79. if (irq != NULL)
  80. *irq = 0;
  81. hw->io_ports[IDE_IRQ_OFFSET] = 0;
  82. }
  83. static __inline__ void ide_init_default_hwifs(void)
  84. {
  85. #ifndef CONFIG_BLK_DEV_IDEPCI
  86. hw_regs_t hw;
  87. int index;
  88. for(index = 0; index < MAX_HWIFS; index++) {
  89. ide_init_hwif_ports(&hw, ide_default_io_base(index), 0, NULL);
  90. hw.irq = ide_default_irq(ide_default_io_base(index));
  91. ide_register_hw(&hw, NULL);
  92. }
  93. #endif /* CONFIG_BLK_DEV_IDEPCI */
  94. }
  95. typedef union {
  96. unsigned all : 8; /* all of the bits together */
  97. struct {
  98. unsigned head : 4; /* always zeros here */
  99. unsigned unit : 1; /* drive select number, 0 or 1 */
  100. unsigned bit5 : 1; /* always 1 */
  101. unsigned lba : 1; /* using LBA instead of CHS */
  102. unsigned bit7 : 1; /* always 1 */
  103. } b;
  104. } select_t;
  105. #define ide_request_irq(irq,hand,flg,dev,id) request_irq((irq),(hand),(flg),(dev),(id))
  106. #define ide_free_irq(irq,dev_id) free_irq((irq), (dev_id))
  107. #define ide_check_region(from,extent) check_region((from), (extent))
  108. #define ide_request_region(from,extent,name) request_region((from), (extent), (name))
  109. #define ide_release_region(from,extent) release_region((from), (extent))
  110. /*
  111.  * The following are not needed for the non-m68k ports
  112.  */
  113. #define ide_ack_intr(hwif) (1)
  114. #define ide_fix_driveid(id) do {} while (0)
  115. #define ide_release_lock(lock) do {} while (0)
  116. #define ide_get_lock(lock, hdlr, data) do {} while (0)
  117. #endif /* __KERNEL__ */
  118. #endif /* __ASM_SH_IDE_H */