hisilicon-sas.txt 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. * HiSilicon SAS controller
  2. The HiSilicon SAS controller supports SAS/SATA.
  3. Main node required properties:
  4. - compatible : value should be as follows:
  5. (a) "hisilicon,hip05-sas-v1" for v1 hw in hip05 chipset
  6. (b) "hisilicon,hip06-sas-v2" for v2 hw in hip06 chipset
  7. - sas-addr : array of 8 bytes for host SAS address
  8. - reg : Address and length of the SAS register
  9. - hisilicon,sas-syscon: phandle of syscon used for sas control
  10. - ctrl-reset-reg : offset to controller reset register in ctrl reg
  11. - ctrl-reset-sts-reg : offset to controller reset status register in ctrl reg
  12. - ctrl-clock-ena-reg : offset to controller clock enable register in ctrl reg
  13. - queue-count : number of delivery and completion queues in the controller
  14. - phy-count : number of phys accessible by the controller
  15. - interrupts : For v1 hw: Interrupts for phys, completion queues, and fatal
  16. sources; the interrupts are ordered in 3 groups, as follows:
  17. - Phy interrupts
  18. - Completion queue interrupts
  19. - Fatal interrupts
  20. Phy interrupts : Each phy has 3 interrupt sources:
  21. - broadcast
  22. - phyup
  23. - abnormal
  24. The phy interrupts are ordered into groups of 3 per phy
  25. (broadcast, phyup, and abnormal) in increasing order.
  26. Completion queue interrupts : each completion queue has 1
  27. interrupt source.
  28. The interrupts are ordered in increasing order.
  29. Fatal interrupts : the fatal interrupts are ordered as follows:
  30. - ECC
  31. - AXI bus
  32. For v2 hw: Interrupts for phys, Sata, and completion queues;
  33. the interrupts are ordered in 3 groups, as follows:
  34. - Phy interrupts
  35. - Sata interrupts
  36. - Completion queue interrupts
  37. Phy interrupts : Each controller has 2 phy interrupts:
  38. - phy up/down
  39. - channel interrupt
  40. Sata interrupts : Each phy on the controller has 1 Sata
  41. interrupt. The interrupts are ordered in increasing
  42. order.
  43. Completion queue interrupts : each completion queue has 1
  44. interrupt source. The interrupts are ordered in
  45. increasing order.
  46. Optional main node properties:
  47. - hip06-sas-v2-quirk-amt : when set, indicates that the v2 controller has the
  48. "am-max-transmissions" limitation.
  49. Example:
  50. sas0: sas@c1000000 {
  51. compatible = "hisilicon,hip05-sas-v1";
  52. sas-addr = [50 01 88 20 16 00 00 0a];
  53. reg = <0x0 0xc1000000 0x0 0x10000>;
  54. hisilicon,sas-syscon = <&pcie_sas>;
  55. ctrl-reset-reg = <0xa60>;
  56. ctrl-reset-sts-reg = <0x5a30>;
  57. ctrl-clock-ena-reg = <0x338>;
  58. queue-count = <32>;
  59. phy-count = <8>;
  60. dma-coherent;
  61. interrupt-parent = <&mbigen_dsa>;
  62. interrupts = <259 4>,<263 4>,<264 4>,/* phy0 */
  63. <269 4>,<273 4>,<274 4>,/* phy1 */
  64. <279 4>,<283 4>,<284 4>,/* phy2 */
  65. <289 4>,<293 4>,<294 4>,/* phy3 */
  66. <299 4>,<303 4>,<304 4>,/* phy4 */
  67. <309 4>,<313 4>,<314 4>,/* phy5 */
  68. <319 4>,<323 4>,<324 4>,/* phy6 */
  69. <329 4>,<333 4>,<334 4>,/* phy7 */
  70. <336 1>,<337 1>,<338 1>,/* cq0-2 */
  71. <339 1>,<340 1>,<341 1>,/* cq3-5 */
  72. <342 1>,<343 1>,<344 1>,/* cq6-8 */
  73. <345 1>,<346 1>,<347 1>,/* cq9-11 */
  74. <348 1>,<349 1>,<350 1>,/* cq12-14 */
  75. <351 1>,<352 1>,<353 1>,/* cq15-17 */
  76. <354 1>,<355 1>,<356 1>,/* cq18-20 */
  77. <357 1>,<358 1>,<359 1>,/* cq21-23 */
  78. <360 1>,<361 1>,<362 1>,/* cq24-26 */
  79. <363 1>,<364 1>,<365 1>,/* cq27-29 */
  80. <366 1>,<367 1>/* cq30-31 */
  81. <376 4>,/* fatal ecc */
  82. <381 4>;/* fatal axi */
  83. status = "disabled";
  84. };