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