ide.h
上传用户:jlfgdled
上传日期:2013-04-10
资源大小:33168k
文件大小:3k
源码类别:

Linux/Unix编程

开发平台:

Unix_Linux

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