xref: /freebsd/sys/contrib/device-tree/Bindings/scsi/hisilicon-sas.txt (revision c66ec88fed842fbaad62c30d510644ceb7bd2d71)
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