nosy-dump.h 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. #ifndef __nosy_dump_h__
  2. #define __nosy_dump_h__
  3. #define array_length(array) (sizeof(array) / sizeof(array[0]))
  4. #define ACK_NO_ACK 0x0
  5. #define ACK_DONE(a) ((a >> 2) == 0)
  6. #define ACK_BUSY(a) ((a >> 2) == 1)
  7. #define ACK_ERROR(a) ((a >> 2) == 3)
  8. #include <stdint.h>
  9. struct phy_packet {
  10. uint32_t timestamp;
  11. union {
  12. struct {
  13. uint32_t zero:24;
  14. uint32_t phy_id:6;
  15. uint32_t identifier:2;
  16. } common, link_on;
  17. struct {
  18. uint32_t zero:16;
  19. uint32_t gap_count:6;
  20. uint32_t set_gap_count:1;
  21. uint32_t set_root:1;
  22. uint32_t root_id:6;
  23. uint32_t identifier:2;
  24. } phy_config;
  25. struct {
  26. uint32_t more_packets:1;
  27. uint32_t initiated_reset:1;
  28. uint32_t port2:2;
  29. uint32_t port1:2;
  30. uint32_t port0:2;
  31. uint32_t power_class:3;
  32. uint32_t contender:1;
  33. uint32_t phy_delay:2;
  34. uint32_t phy_speed:2;
  35. uint32_t gap_count:6;
  36. uint32_t link_active:1;
  37. uint32_t extended:1;
  38. uint32_t phy_id:6;
  39. uint32_t identifier:2;
  40. } self_id;
  41. struct {
  42. uint32_t more_packets:1;
  43. uint32_t reserved1:1;
  44. uint32_t porth:2;
  45. uint32_t portg:2;
  46. uint32_t portf:2;
  47. uint32_t porte:2;
  48. uint32_t portd:2;
  49. uint32_t portc:2;
  50. uint32_t portb:2;
  51. uint32_t porta:2;
  52. uint32_t reserved0:2;
  53. uint32_t sequence:3;
  54. uint32_t extended:1;
  55. uint32_t phy_id:6;
  56. uint32_t identifier:2;
  57. } ext_self_id;
  58. };
  59. uint32_t inverted;
  60. uint32_t ack;
  61. };
  62. #define TCODE_PHY_PACKET 0x10
  63. #define PHY_PACKET_CONFIGURATION 0x00
  64. #define PHY_PACKET_LINK_ON 0x01
  65. #define PHY_PACKET_SELF_ID 0x02
  66. struct link_packet {
  67. uint32_t timestamp;
  68. union {
  69. struct {
  70. uint32_t priority:4;
  71. uint32_t tcode:4;
  72. uint32_t rt:2;
  73. uint32_t tlabel:6;
  74. uint32_t destination:16;
  75. uint32_t offset_high:16;
  76. uint32_t source:16;
  77. uint32_t offset_low;
  78. } common;
  79. struct {
  80. uint32_t common[3];
  81. uint32_t crc;
  82. } read_quadlet;
  83. struct {
  84. uint32_t common[3];
  85. uint32_t data;
  86. uint32_t crc;
  87. } read_quadlet_response;
  88. struct {
  89. uint32_t common[3];
  90. uint32_t extended_tcode:16;
  91. uint32_t data_length:16;
  92. uint32_t crc;
  93. } read_block;
  94. struct {
  95. uint32_t common[3];
  96. uint32_t extended_tcode:16;
  97. uint32_t data_length:16;
  98. uint32_t crc;
  99. uint32_t data[0];
  100. /* crc and ack follows. */
  101. } read_block_response;
  102. struct {
  103. uint32_t common[3];
  104. uint32_t data;
  105. uint32_t crc;
  106. } write_quadlet;
  107. struct {
  108. uint32_t common[3];
  109. uint32_t extended_tcode:16;
  110. uint32_t data_length:16;
  111. uint32_t crc;
  112. uint32_t data[0];
  113. /* crc and ack follows. */
  114. } write_block;
  115. struct {
  116. uint32_t common[3];
  117. uint32_t crc;
  118. } write_response;
  119. struct {
  120. uint32_t common[3];
  121. uint32_t data;
  122. uint32_t crc;
  123. } cycle_start;
  124. struct {
  125. uint32_t sy:4;
  126. uint32_t tcode:4;
  127. uint32_t channel:6;
  128. uint32_t tag:2;
  129. uint32_t data_length:16;
  130. uint32_t crc;
  131. } iso_data;
  132. };
  133. };
  134. struct subaction {
  135. uint32_t ack;
  136. size_t length;
  137. struct list link;
  138. struct link_packet packet;
  139. };
  140. struct link_transaction {
  141. int request_node, response_node, tlabel;
  142. struct subaction *request, *response;
  143. struct list request_list, response_list;
  144. struct list link;
  145. };
  146. int decode_fcp(struct link_transaction *t);
  147. #endif /* __nosy_dump_h__ */