mesh.h 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. /*
  2. * mesh.h: definitions for the driver for the MESH SCSI bus adaptor
  3. * (Macintosh Enhanced SCSI Hardware) found on Power Macintosh computers.
  4. *
  5. * Copyright (C) 1996 Paul Mackerras.
  6. */
  7. #ifndef _MESH_H
  8. #define _MESH_H
  9. /*
  10. * Registers in the MESH controller.
  11. */
  12. struct mesh_regs {
  13. unsigned char count_lo;
  14. char pad0[15];
  15. unsigned char count_hi;
  16. char pad1[15];
  17. unsigned char fifo;
  18. char pad2[15];
  19. unsigned char sequence;
  20. char pad3[15];
  21. unsigned char bus_status0;
  22. char pad4[15];
  23. unsigned char bus_status1;
  24. char pad5[15];
  25. unsigned char fifo_count;
  26. char pad6[15];
  27. unsigned char exception;
  28. char pad7[15];
  29. unsigned char error;
  30. char pad8[15];
  31. unsigned char intr_mask;
  32. char pad9[15];
  33. unsigned char interrupt;
  34. char pad10[15];
  35. unsigned char source_id;
  36. char pad11[15];
  37. unsigned char dest_id;
  38. char pad12[15];
  39. unsigned char sync_params;
  40. char pad13[15];
  41. unsigned char mesh_id;
  42. char pad14[15];
  43. unsigned char sel_timeout;
  44. char pad15[15];
  45. };
  46. /* Bits in the sequence register. */
  47. #define SEQ_DMA_MODE 0x80 /* use DMA for data transfer */
  48. #define SEQ_TARGET 0x40 /* put the controller into target mode */
  49. #define SEQ_ATN 0x20 /* assert ATN signal */
  50. #define SEQ_ACTIVE_NEG 0x10 /* use active negation on REQ/ACK */
  51. #define SEQ_CMD 0x0f /* command bits: */
  52. #define SEQ_ARBITRATE 1 /* get the bus */
  53. #define SEQ_SELECT 2 /* select a target */
  54. #define SEQ_COMMAND 3 /* send a command */
  55. #define SEQ_STATUS 4 /* receive status */
  56. #define SEQ_DATAOUT 5 /* send data */
  57. #define SEQ_DATAIN 6 /* receive data */
  58. #define SEQ_MSGOUT 7 /* send a message */
  59. #define SEQ_MSGIN 8 /* receive a message */
  60. #define SEQ_BUSFREE 9 /* look for bus free */
  61. #define SEQ_ENBPARITY 0x0a /* enable parity checking */
  62. #define SEQ_DISPARITY 0x0b /* disable parity checking */
  63. #define SEQ_ENBRESEL 0x0c /* enable reselection */
  64. #define SEQ_DISRESEL 0x0d /* disable reselection */
  65. #define SEQ_RESETMESH 0x0e /* reset the controller */
  66. #define SEQ_FLUSHFIFO 0x0f /* clear out the FIFO */
  67. /* Bits in the bus_status0 and bus_status1 registers:
  68. these correspond directly to the SCSI bus control signals. */
  69. #define BS0_REQ 0x20
  70. #define BS0_ACK 0x10
  71. #define BS0_ATN 0x08
  72. #define BS0_MSG 0x04
  73. #define BS0_CD 0x02
  74. #define BS0_IO 0x01
  75. #define BS1_RST 0x80
  76. #define BS1_BSY 0x40
  77. #define BS1_SEL 0x20
  78. /* Bus phases defined by the bits in bus_status0 */
  79. #define BS0_PHASE (BS0_MSG+BS0_CD+BS0_IO)
  80. #define BP_DATAOUT 0
  81. #define BP_DATAIN BS0_IO
  82. #define BP_COMMAND BS0_CD
  83. #define BP_STATUS (BS0_CD+BS0_IO)
  84. #define BP_MSGOUT (BS0_MSG+BS0_CD)
  85. #define BP_MSGIN (BS0_MSG+BS0_CD+BS0_IO)
  86. /* Bits in the exception register. */
  87. #define EXC_SELWATN 0x20 /* (as target) we were selected with ATN */
  88. #define EXC_SELECTED 0x10 /* (as target) we were selected w/o ATN */
  89. #define EXC_RESELECTED 0x08 /* (as initiator) we were reselected */
  90. #define EXC_ARBLOST 0x04 /* we lost arbitration */
  91. #define EXC_PHASEMM 0x02 /* SCSI phase mismatch */
  92. #define EXC_SELTO 0x01 /* selection timeout */
  93. /* Bits in the error register */
  94. #define ERR_UNEXPDISC 0x40 /* target unexpectedly disconnected */
  95. #define ERR_SCSIRESET 0x20 /* SCSI bus got reset on us */
  96. #define ERR_SEQERR 0x10 /* we did something the chip didn't like */
  97. #define ERR_PARITY 0x01 /* parity error was detected */
  98. /* Bits in the interrupt and intr_mask registers */
  99. #define INT_ERROR 0x04 /* error interrupt */
  100. #define INT_EXCEPTION 0x02 /* exception interrupt */
  101. #define INT_CMDDONE 0x01 /* command done interrupt */
  102. /* Fields in the sync_params register */
  103. #define SYNC_OFF(x) ((x) >> 4) /* offset field */
  104. #define SYNC_PER(x) ((x) & 0xf) /* period field */
  105. #define SYNC_PARAMS(o, p) (((o) << 4) | (p))
  106. #define ASYNC_PARAMS 2 /* sync_params value for async xfers */
  107. /*
  108. * Assuming a clock frequency of 50MHz:
  109. *
  110. * The transfer period with SYNC_PER(sync_params) == x
  111. * is (x + 2) * 40ns, except that x == 0 gives 100ns.
  112. *
  113. * The units of the sel_timeout register are 10ms.
  114. */
  115. #endif /* _MESH_H */