tb_regs.h 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /*
  3. * Thunderbolt driver - Port/Switch config area registers
  4. *
  5. * Every thunderbolt device consists (logically) of a switch with multiple
  6. * ports. Every port contains up to four config regions (HOPS, PORT, SWITCH,
  7. * COUNTERS) which are used to configure the device.
  8. *
  9. * Copyright (c) 2014 Andreas Noever <andreas.noever@gmail.com>
  10. * Copyright (C) 2018, Intel Corporation
  11. */
  12. #ifndef _TB_REGS
  13. #define _TB_REGS
  14. #include <linux/types.h>
  15. #define TB_ROUTE_SHIFT 8 /* number of bits in a port entry of a route */
  16. /*
  17. * TODO: should be 63? But we do not know how to receive frames larger than 256
  18. * bytes at the frame level. (header + checksum = 16, 60*4 = 240)
  19. */
  20. #define TB_MAX_CONFIG_RW_LENGTH 60
  21. enum tb_switch_cap {
  22. TB_SWITCH_CAP_TMU = 0x03,
  23. TB_SWITCH_CAP_VSE = 0x05,
  24. };
  25. enum tb_switch_vse_cap {
  26. TB_VSE_CAP_PLUG_EVENTS = 0x01, /* also EEPROM */
  27. TB_VSE_CAP_TIME2 = 0x03,
  28. TB_VSE_CAP_CP_LP = 0x04,
  29. TB_VSE_CAP_LINK_CONTROLLER = 0x06, /* also IECS */
  30. };
  31. enum tb_port_cap {
  32. TB_PORT_CAP_PHY = 0x01,
  33. TB_PORT_CAP_POWER = 0x02,
  34. TB_PORT_CAP_TIME1 = 0x03,
  35. TB_PORT_CAP_ADAP = 0x04,
  36. TB_PORT_CAP_VSE = 0x05,
  37. TB_PORT_CAP_USB4 = 0x06,
  38. };
  39. enum tb_port_state {
  40. TB_PORT_DISABLED = 0, /* tb_cap_phy.disable == 1 */
  41. TB_PORT_CONNECTING = 1, /* retry */
  42. TB_PORT_UP = 2,
  43. TB_PORT_TX_CL0S = 3,
  44. TB_PORT_RX_CL0S = 4,
  45. TB_PORT_CL1 = 5,
  46. TB_PORT_CL2 = 6,
  47. TB_PORT_UNPLUGGED = 7,
  48. };
  49. /* capability headers */
  50. struct tb_cap_basic {
  51. u8 next;
  52. /* enum tb_cap cap:8; prevent "narrower than values of its type" */
  53. u8 cap; /* if cap == 0x05 then we have a extended capability */
  54. } __packed;
  55. /**
  56. * struct tb_cap_extended_short - Switch extended short capability
  57. * @next: Pointer to the next capability. If @next and @length are zero
  58. * then we have a long cap.
  59. * @cap: Base capability ID (see &enum tb_switch_cap)
  60. * @vsec_id: Vendor specific capability ID (see &enum switch_vse_cap)
  61. * @length: Length of this capability
  62. */
  63. struct tb_cap_extended_short {
  64. u8 next;
  65. u8 cap;
  66. u8 vsec_id;
  67. u8 length;
  68. } __packed;
  69. /**
  70. * struct tb_cap_extended_long - Switch extended long capability
  71. * @zero1: This field should be zero
  72. * @cap: Base capability ID (see &enum tb_switch_cap)
  73. * @vsec_id: Vendor specific capability ID (see &enum switch_vse_cap)
  74. * @zero2: This field should be zero
  75. * @next: Pointer to the next capability
  76. * @length: Length of this capability
  77. */
  78. struct tb_cap_extended_long {
  79. u8 zero1;
  80. u8 cap;
  81. u8 vsec_id;
  82. u8 zero2;
  83. u16 next;
  84. u16 length;
  85. } __packed;
  86. /**
  87. * struct tb_cap_any - Structure capable of hold every capability
  88. * @basic: Basic capability
  89. * @extended_short: Vendor specific capability
  90. * @extended_long: Vendor specific extended capability
  91. */
  92. struct tb_cap_any {
  93. union {
  94. struct tb_cap_basic basic;
  95. struct tb_cap_extended_short extended_short;
  96. struct tb_cap_extended_long extended_long;
  97. };
  98. } __packed;
  99. /* capabilities */
  100. struct tb_cap_link_controller {
  101. struct tb_cap_extended_long cap_header;
  102. u32 count:4; /* number of link controllers */
  103. u32 unknown1:4;
  104. u32 base_offset:8; /*
  105. * offset (into this capability) of the configuration
  106. * area of the first link controller
  107. */
  108. u32 length:12; /* link controller configuration area length */
  109. u32 unknown2:4; /* TODO check that length is correct */
  110. } __packed;
  111. struct tb_cap_phy {
  112. struct tb_cap_basic cap_header;
  113. u32 unknown1:16;
  114. u32 unknown2:14;
  115. bool disable:1;
  116. u32 unknown3:11;
  117. enum tb_port_state state:4;
  118. u32 unknown4:2;
  119. } __packed;
  120. struct tb_eeprom_ctl {
  121. bool fl_sk:1; /* send pulse to transfer one bit */
  122. bool fl_cs:1; /* set to 0 before access */
  123. bool fl_di:1; /* to eeprom */
  124. bool fl_do:1; /* from eeprom */
  125. bool bit_banging_enable:1; /* set to 1 before access */
  126. bool not_present:1; /* should be 0 */
  127. bool unknown1:1;
  128. bool present:1; /* should be 1 */
  129. u32 unknown2:24;
  130. } __packed;
  131. struct tb_cap_plug_events {
  132. struct tb_cap_extended_short cap_header;
  133. u32 __unknown1:2; /* VSC_CS_1 */
  134. u32 plug_events:5; /* VSC_CS_1 */
  135. u32 __unknown2:25; /* VSC_CS_1 */
  136. u32 vsc_cs_2;
  137. u32 vsc_cs_3;
  138. struct tb_eeprom_ctl eeprom_ctl;
  139. u32 __unknown5[7]; /* VSC_CS_5 -> VSC_CS_11 */
  140. u32 drom_offset; /* VSC_CS_12: 32 bit register, but eeprom addresses are 16 bit */
  141. } __packed;
  142. /* device headers */
  143. /* Present on port 0 in TB_CFG_SWITCH at address zero. */
  144. struct tb_regs_switch_header {
  145. /* DWORD 0 */
  146. u16 vendor_id;
  147. u16 device_id;
  148. /* DWORD 1 */
  149. u32 first_cap_offset:8;
  150. u32 upstream_port_number:6;
  151. u32 max_port_number:6;
  152. u32 depth:3;
  153. u32 __unknown1:1;
  154. u32 revision:8;
  155. /* DWORD 2 */
  156. u32 route_lo;
  157. /* DWORD 3 */
  158. u32 route_hi:31;
  159. bool enabled:1;
  160. /* DWORD 4 */
  161. u32 plug_events_delay:8; /*
  162. * RW, pause between plug events in
  163. * milliseconds. Writing 0x00 is interpreted
  164. * as 255ms.
  165. */
  166. u32 cmuv:8;
  167. u32 __unknown4:8;
  168. u32 thunderbolt_version:8;
  169. } __packed;
  170. /* Used with the router thunderbolt_version */
  171. #define USB4_VERSION_MAJOR_MASK GENMASK(7, 5)
  172. #define ROUTER_CS_1 0x01
  173. #define ROUTER_CS_3 0x03
  174. #define ROUTER_CS_3_V BIT(31)
  175. #define ROUTER_CS_4 0x04
  176. /* Used with the router cmuv field */
  177. #define ROUTER_CS_4_CMUV_V1 0x10
  178. #define ROUTER_CS_4_CMUV_V2 0x20
  179. #define ROUTER_CS_5 0x05
  180. #define ROUTER_CS_5_SLP BIT(0)
  181. #define ROUTER_CS_5_WOP BIT(1)
  182. #define ROUTER_CS_5_WOU BIT(2)
  183. #define ROUTER_CS_5_WOD BIT(3)
  184. #define ROUTER_CS_5_CNS BIT(23)
  185. #define ROUTER_CS_5_PTO BIT(24)
  186. #define ROUTER_CS_5_UTO BIT(25)
  187. #define ROUTER_CS_5_HCO BIT(26)
  188. #define ROUTER_CS_5_CV BIT(31)
  189. #define ROUTER_CS_6 0x06
  190. #define ROUTER_CS_6_SLPR BIT(0)
  191. #define ROUTER_CS_6_TNS BIT(1)
  192. #define ROUTER_CS_6_WOPS BIT(2)
  193. #define ROUTER_CS_6_WOUS BIT(3)
  194. #define ROUTER_CS_6_HCI BIT(18)
  195. #define ROUTER_CS_6_CR BIT(25)
  196. #define ROUTER_CS_7 0x07
  197. #define ROUTER_CS_9 0x09
  198. #define ROUTER_CS_25 0x19
  199. #define ROUTER_CS_26 0x1a
  200. #define ROUTER_CS_26_OPCODE_MASK GENMASK(15, 0)
  201. #define ROUTER_CS_26_STATUS_MASK GENMASK(29, 24)
  202. #define ROUTER_CS_26_STATUS_SHIFT 24
  203. #define ROUTER_CS_26_ONS BIT(30)
  204. #define ROUTER_CS_26_OV BIT(31)
  205. /* USB4 router operations opcodes */
  206. enum usb4_switch_op {
  207. USB4_SWITCH_OP_QUERY_DP_RESOURCE = 0x10,
  208. USB4_SWITCH_OP_ALLOC_DP_RESOURCE = 0x11,
  209. USB4_SWITCH_OP_DEALLOC_DP_RESOURCE = 0x12,
  210. USB4_SWITCH_OP_NVM_WRITE = 0x20,
  211. USB4_SWITCH_OP_NVM_AUTH = 0x21,
  212. USB4_SWITCH_OP_NVM_READ = 0x22,
  213. USB4_SWITCH_OP_NVM_SET_OFFSET = 0x23,
  214. USB4_SWITCH_OP_DROM_READ = 0x24,
  215. USB4_SWITCH_OP_NVM_SECTOR_SIZE = 0x25,
  216. USB4_SWITCH_OP_BUFFER_ALLOC = 0x33,
  217. };
  218. /* Router TMU configuration */
  219. #define TMU_RTR_CS_0 0x00
  220. #define TMU_RTR_CS_0_FREQ_WIND_MASK GENMASK(26, 16)
  221. #define TMU_RTR_CS_0_TD BIT(27)
  222. #define TMU_RTR_CS_0_UCAP BIT(30)
  223. #define TMU_RTR_CS_1 0x01
  224. #define TMU_RTR_CS_1_LOCAL_TIME_NS_MASK GENMASK(31, 16)
  225. #define TMU_RTR_CS_1_LOCAL_TIME_NS_SHIFT 16
  226. #define TMU_RTR_CS_2 0x02
  227. #define TMU_RTR_CS_3 0x03
  228. #define TMU_RTR_CS_3_LOCAL_TIME_NS_MASK GENMASK(15, 0)
  229. #define TMU_RTR_CS_3_TS_PACKET_INTERVAL_MASK GENMASK(31, 16)
  230. #define TMU_RTR_CS_3_TS_PACKET_INTERVAL_SHIFT 16
  231. #define TMU_RTR_CS_15 0x0f
  232. #define TMU_RTR_CS_15_FREQ_AVG_MASK GENMASK(5, 0)
  233. #define TMU_RTR_CS_15_DELAY_AVG_MASK GENMASK(11, 6)
  234. #define TMU_RTR_CS_15_OFFSET_AVG_MASK GENMASK(17, 12)
  235. #define TMU_RTR_CS_15_ERROR_AVG_MASK GENMASK(23, 18)
  236. #define TMU_RTR_CS_18 0x12
  237. #define TMU_RTR_CS_18_DELTA_AVG_CONST_MASK GENMASK(23, 16)
  238. #define TMU_RTR_CS_22 0x16
  239. #define TMU_RTR_CS_24 0x18
  240. #define TMU_RTR_CS_25 0x19
  241. enum tb_port_type {
  242. TB_TYPE_INACTIVE = 0x000000,
  243. TB_TYPE_PORT = 0x000001,
  244. TB_TYPE_NHI = 0x000002,
  245. /* TB_TYPE_ETHERNET = 0x020000, lower order bits are not known */
  246. /* TB_TYPE_SATA = 0x080000, lower order bits are not known */
  247. TB_TYPE_DP_HDMI_IN = 0x0e0101,
  248. TB_TYPE_DP_HDMI_OUT = 0x0e0102,
  249. TB_TYPE_PCIE_DOWN = 0x100101,
  250. TB_TYPE_PCIE_UP = 0x100102,
  251. TB_TYPE_USB3_DOWN = 0x200101,
  252. TB_TYPE_USB3_UP = 0x200102,
  253. };
  254. /* Present on every port in TB_CF_PORT at address zero. */
  255. struct tb_regs_port_header {
  256. /* DWORD 0 */
  257. u16 vendor_id;
  258. u16 device_id;
  259. /* DWORD 1 */
  260. u32 first_cap_offset:8;
  261. u32 max_counters:11;
  262. u32 counters_support:1;
  263. u32 __unknown1:4;
  264. u32 revision:8;
  265. /* DWORD 2 */
  266. enum tb_port_type type:24;
  267. u32 thunderbolt_version:8;
  268. /* DWORD 3 */
  269. u32 __unknown2:20;
  270. u32 port_number:6;
  271. u32 __unknown3:6;
  272. /* DWORD 4 */
  273. u32 nfc_credits;
  274. /* DWORD 5 */
  275. u32 max_in_hop_id:11;
  276. u32 max_out_hop_id:11;
  277. u32 __unknown4:10;
  278. /* DWORD 6 */
  279. u32 __unknown5;
  280. /* DWORD 7 */
  281. u32 __unknown6;
  282. } __packed;
  283. /* Basic adapter configuration registers */
  284. #define ADP_CS_4 0x04
  285. #define ADP_CS_4_NFC_BUFFERS_MASK GENMASK(9, 0)
  286. #define ADP_CS_4_TOTAL_BUFFERS_MASK GENMASK(29, 20)
  287. #define ADP_CS_4_TOTAL_BUFFERS_SHIFT 20
  288. #define ADP_CS_4_LCK BIT(31)
  289. #define ADP_CS_5 0x05
  290. #define ADP_CS_5_LCA_MASK GENMASK(28, 22)
  291. #define ADP_CS_5_LCA_SHIFT 22
  292. #define ADP_CS_5_DHP BIT(31)
  293. /* TMU adapter registers */
  294. #define TMU_ADP_CS_3 0x03
  295. #define TMU_ADP_CS_3_UDM BIT(29)
  296. #define TMU_ADP_CS_6 0x06
  297. #define TMU_ADP_CS_6_DTS BIT(1)
  298. #define TMU_ADP_CS_8 0x08
  299. #define TMU_ADP_CS_8_REPL_TIMEOUT_MASK GENMASK(14, 0)
  300. #define TMU_ADP_CS_8_EUDM BIT(15)
  301. #define TMU_ADP_CS_8_REPL_THRESHOLD_MASK GENMASK(25, 16)
  302. #define TMU_ADP_CS_9 0x09
  303. #define TMU_ADP_CS_9_REPL_N_MASK GENMASK(7, 0)
  304. #define TMU_ADP_CS_9_DIRSWITCH_N_MASK GENMASK(15, 8)
  305. #define TMU_ADP_CS_9_ADP_TS_INTERVAL_MASK GENMASK(31, 16)
  306. /* Lane adapter registers */
  307. #define LANE_ADP_CS_0 0x00
  308. #define LANE_ADP_CS_0_SUPPORTED_SPEED_MASK GENMASK(19, 16)
  309. #define LANE_ADP_CS_0_SUPPORTED_SPEED_SHIFT 16
  310. #define LANE_ADP_CS_0_SUPPORTED_WIDTH_MASK GENMASK(25, 20)
  311. #define LANE_ADP_CS_0_SUPPORTED_WIDTH_SHIFT 20
  312. #define LANE_ADP_CS_0_SUPPORTED_WIDTH_DUAL 0x2
  313. #define LANE_ADP_CS_0_CL0S_SUPPORT BIT(26)
  314. #define LANE_ADP_CS_0_CL1_SUPPORT BIT(27)
  315. #define LANE_ADP_CS_0_CL2_SUPPORT BIT(28)
  316. #define LANE_ADP_CS_1 0x01
  317. #define LANE_ADP_CS_1_TARGET_SPEED_MASK GENMASK(3, 0)
  318. #define LANE_ADP_CS_1_TARGET_SPEED_GEN3 0xc
  319. #define LANE_ADP_CS_1_TARGET_WIDTH_MASK GENMASK(5, 4)
  320. #define LANE_ADP_CS_1_TARGET_WIDTH_SHIFT 4
  321. #define LANE_ADP_CS_1_TARGET_WIDTH_SINGLE 0x1
  322. #define LANE_ADP_CS_1_TARGET_WIDTH_DUAL 0x3
  323. #define LANE_ADP_CS_1_TARGET_WIDTH_ASYM_MASK GENMASK(7, 6)
  324. #define LANE_ADP_CS_1_TARGET_WIDTH_ASYM_TX 0x1
  325. #define LANE_ADP_CS_1_TARGET_WIDTH_ASYM_RX 0x2
  326. #define LANE_ADP_CS_1_TARGET_WIDTH_ASYM_DUAL 0x0
  327. #define LANE_ADP_CS_1_CL0S_ENABLE BIT(10)
  328. #define LANE_ADP_CS_1_CL1_ENABLE BIT(11)
  329. #define LANE_ADP_CS_1_CL2_ENABLE BIT(12)
  330. #define LANE_ADP_CS_1_LD BIT(14)
  331. #define LANE_ADP_CS_1_LB BIT(15)
  332. #define LANE_ADP_CS_1_CURRENT_SPEED_MASK GENMASK(19, 16)
  333. #define LANE_ADP_CS_1_CURRENT_SPEED_SHIFT 16
  334. #define LANE_ADP_CS_1_CURRENT_SPEED_GEN2 0x8
  335. #define LANE_ADP_CS_1_CURRENT_SPEED_GEN3 0x4
  336. #define LANE_ADP_CS_1_CURRENT_SPEED_GEN4 0x2
  337. #define LANE_ADP_CS_1_CURRENT_WIDTH_MASK GENMASK(25, 20)
  338. #define LANE_ADP_CS_1_CURRENT_WIDTH_SHIFT 20
  339. #define LANE_ADP_CS_1_PMS BIT(30)
  340. /* USB4 port registers */
  341. #define PORT_CS_1 0x01
  342. #define PORT_CS_1_LENGTH_SHIFT 8
  343. #define PORT_CS_1_TARGET_MASK GENMASK(18, 16)
  344. #define PORT_CS_1_TARGET_SHIFT 16
  345. #define PORT_CS_1_RETIMER_INDEX_SHIFT 20
  346. #define PORT_CS_1_WNR_WRITE BIT(24)
  347. #define PORT_CS_1_NR BIT(25)
  348. #define PORT_CS_1_RC BIT(26)
  349. #define PORT_CS_1_PND BIT(31)
  350. #define PORT_CS_2 0x02
  351. #define PORT_CS_18 0x12
  352. #define PORT_CS_18_BE BIT(8)
  353. #define PORT_CS_18_TCM BIT(9)
  354. #define PORT_CS_18_CPS BIT(10)
  355. #define PORT_CS_18_WOCS BIT(16)
  356. #define PORT_CS_18_WODS BIT(17)
  357. #define PORT_CS_18_WOU4S BIT(18)
  358. #define PORT_CS_18_CSA BIT(22)
  359. #define PORT_CS_18_TIP BIT(24)
  360. #define PORT_CS_19 0x13
  361. #define PORT_CS_19_DPR BIT(0)
  362. #define PORT_CS_19_PC BIT(3)
  363. #define PORT_CS_19_PID BIT(4)
  364. #define PORT_CS_19_WOC BIT(16)
  365. #define PORT_CS_19_WOD BIT(17)
  366. #define PORT_CS_19_WOU4 BIT(18)
  367. #define PORT_CS_19_START_ASYM BIT(24)
  368. /* Display Port adapter registers */
  369. #define ADP_DP_CS_0 0x00
  370. #define ADP_DP_CS_0_VIDEO_HOPID_MASK GENMASK(26, 16)
  371. #define ADP_DP_CS_0_VIDEO_HOPID_SHIFT 16
  372. #define ADP_DP_CS_0_AE BIT(30)
  373. #define ADP_DP_CS_0_VE BIT(31)
  374. #define ADP_DP_CS_1_AUX_TX_HOPID_MASK GENMASK(10, 0)
  375. #define ADP_DP_CS_1_AUX_RX_HOPID_MASK GENMASK(21, 11)
  376. #define ADP_DP_CS_1_AUX_RX_HOPID_SHIFT 11
  377. #define ADP_DP_CS_2 0x02
  378. #define ADP_DP_CS_2_NRD_MLC_MASK GENMASK(2, 0)
  379. #define ADP_DP_CS_2_HPD BIT(6)
  380. #define ADP_DP_CS_2_NRD_MLR_MASK GENMASK(9, 7)
  381. #define ADP_DP_CS_2_NRD_MLR_SHIFT 7
  382. #define ADP_DP_CS_2_CA BIT(10)
  383. #define ADP_DP_CS_2_GR_MASK GENMASK(12, 11)
  384. #define ADP_DP_CS_2_GR_SHIFT 11
  385. #define ADP_DP_CS_2_GR_0_25G 0x0
  386. #define ADP_DP_CS_2_GR_0_5G 0x1
  387. #define ADP_DP_CS_2_GR_1G 0x2
  388. #define ADP_DP_CS_2_GROUP_ID_MASK GENMASK(15, 13)
  389. #define ADP_DP_CS_2_GROUP_ID_SHIFT 13
  390. #define ADP_DP_CS_2_CM_ID_MASK GENMASK(19, 16)
  391. #define ADP_DP_CS_2_CM_ID_SHIFT 16
  392. #define ADP_DP_CS_2_CMMS BIT(20)
  393. #define ADP_DP_CS_2_ESTIMATED_BW_MASK GENMASK(31, 24)
  394. #define ADP_DP_CS_2_ESTIMATED_BW_SHIFT 24
  395. #define ADP_DP_CS_3 0x03
  396. #define ADP_DP_CS_3_HPDC BIT(9)
  397. #define DP_LOCAL_CAP 0x04
  398. #define DP_REMOTE_CAP 0x05
  399. /* For DP IN adapter */
  400. #define DP_STATUS 0x06
  401. #define DP_STATUS_ALLOCATED_BW_MASK GENMASK(31, 24)
  402. #define DP_STATUS_ALLOCATED_BW_SHIFT 24
  403. /* For DP OUT adapter */
  404. #define DP_STATUS_CTRL 0x06
  405. #define DP_STATUS_CTRL_CMHS BIT(25)
  406. #define DP_STATUS_CTRL_UF BIT(26)
  407. #define DP_COMMON_CAP 0x07
  408. /* Only if DP IN supports BW allocation mode */
  409. #define ADP_DP_CS_8 0x08
  410. #define ADP_DP_CS_8_REQUESTED_BW_MASK GENMASK(7, 0)
  411. #define ADP_DP_CS_8_DPME BIT(30)
  412. #define ADP_DP_CS_8_DR BIT(31)
  413. /*
  414. * DP_COMMON_CAP offsets work also for DP_LOCAL_CAP and DP_REMOTE_CAP
  415. * with exception of DPRX done.
  416. */
  417. #define DP_COMMON_CAP_RATE_MASK GENMASK(11, 8)
  418. #define DP_COMMON_CAP_RATE_SHIFT 8
  419. #define DP_COMMON_CAP_RATE_RBR 0x0
  420. #define DP_COMMON_CAP_RATE_HBR 0x1
  421. #define DP_COMMON_CAP_RATE_HBR2 0x2
  422. #define DP_COMMON_CAP_RATE_HBR3 0x3
  423. #define DP_COMMON_CAP_LANES_MASK GENMASK(14, 12)
  424. #define DP_COMMON_CAP_LANES_SHIFT 12
  425. #define DP_COMMON_CAP_1_LANE 0x0
  426. #define DP_COMMON_CAP_2_LANES 0x1
  427. #define DP_COMMON_CAP_4_LANES 0x2
  428. #define DP_COMMON_CAP_UHBR10 BIT(17)
  429. #define DP_COMMON_CAP_UHBR20 BIT(18)
  430. #define DP_COMMON_CAP_UHBR13_5 BIT(19)
  431. #define DP_COMMON_CAP_LTTPR_NS BIT(27)
  432. #define DP_COMMON_CAP_BW_MODE BIT(28)
  433. #define DP_COMMON_CAP_DPRX_DONE BIT(31)
  434. /* Only present if DP IN supports BW allocation mode */
  435. #define ADP_DP_CS_8 0x08
  436. #define ADP_DP_CS_8_DPME BIT(30)
  437. #define ADP_DP_CS_8_DR BIT(31)
  438. /* PCIe adapter registers */
  439. #define ADP_PCIE_CS_0 0x00
  440. #define ADP_PCIE_CS_0_PE BIT(31)
  441. #define ADP_PCIE_CS_1 0x01
  442. #define ADP_PCIE_CS_1_EE BIT(0)
  443. /* USB adapter registers */
  444. #define ADP_USB3_CS_0 0x00
  445. #define ADP_USB3_CS_0_V BIT(30)
  446. #define ADP_USB3_CS_0_PE BIT(31)
  447. #define ADP_USB3_CS_1 0x01
  448. #define ADP_USB3_CS_1_CUBW_MASK GENMASK(11, 0)
  449. #define ADP_USB3_CS_1_CDBW_MASK GENMASK(23, 12)
  450. #define ADP_USB3_CS_1_CDBW_SHIFT 12
  451. #define ADP_USB3_CS_1_HCA BIT(31)
  452. #define ADP_USB3_CS_2 0x02
  453. #define ADP_USB3_CS_2_AUBW_MASK GENMASK(11, 0)
  454. #define ADP_USB3_CS_2_ADBW_MASK GENMASK(23, 12)
  455. #define ADP_USB3_CS_2_ADBW_SHIFT 12
  456. #define ADP_USB3_CS_2_CMR BIT(31)
  457. #define ADP_USB3_CS_3 0x03
  458. #define ADP_USB3_CS_3_SCALE_MASK GENMASK(5, 0)
  459. #define ADP_USB3_CS_4 0x04
  460. #define ADP_USB3_CS_4_MSLR_MASK GENMASK(18, 12)
  461. #define ADP_USB3_CS_4_MSLR_SHIFT 12
  462. #define ADP_USB3_CS_4_MSLR_20G 0x1
  463. /* Hop register from TB_CFG_HOPS. 8 byte per entry. */
  464. struct tb_regs_hop {
  465. /* DWORD 0 */
  466. u32 next_hop:11; /*
  467. * hop to take after sending the packet through
  468. * out_port (on the incoming port of the next switch)
  469. */
  470. u32 out_port:6; /* next port of the path (on the same switch) */
  471. u32 initial_credits:7;
  472. u32 pmps:1;
  473. u32 unknown1:6; /* set to zero */
  474. bool enable:1;
  475. /* DWORD 1 */
  476. u32 weight:4;
  477. u32 unknown2:4; /* set to zero */
  478. u32 priority:3;
  479. bool drop_packages:1;
  480. u32 counter:11; /* index into TB_CFG_COUNTERS on this port */
  481. bool counter_enable:1;
  482. bool ingress_fc:1;
  483. bool egress_fc:1;
  484. bool ingress_shared_buffer:1;
  485. bool egress_shared_buffer:1;
  486. bool pending:1;
  487. u32 unknown3:3; /* set to zero */
  488. } __packed;
  489. /* TMU Thunderbolt 3 registers */
  490. #define TB_TIME_VSEC_3_CS_9 0x9
  491. #define TB_TIME_VSEC_3_CS_9_TMU_OBJ_MASK GENMASK(17, 16)
  492. #define TB_TIME_VSEC_3_CS_26 0x1a
  493. #define TB_TIME_VSEC_3_CS_26_TD BIT(22)
  494. /*
  495. * Used for Titan Ridge only. Bits are part of the same register: TMU_ADP_CS_6
  496. * (see above) as in USB4 spec, but these specific bits used for Titan Ridge
  497. * only and reserved in USB4 spec.
  498. */
  499. #define TMU_ADP_CS_6_DISABLE_TMU_OBJ_MASK GENMASK(3, 2)
  500. #define TMU_ADP_CS_6_DISABLE_TMU_OBJ_CL1 BIT(2)
  501. #define TMU_ADP_CS_6_DISABLE_TMU_OBJ_CL2 BIT(3)
  502. /* Plug Events registers */
  503. #define TB_PLUG_EVENTS_USB_DISABLE BIT(2)
  504. #define TB_PLUG_EVENTS_CS_1_LANE_DISABLE BIT(3)
  505. #define TB_PLUG_EVENTS_CS_1_DPOUT_DISABLE BIT(4)
  506. #define TB_PLUG_EVENTS_CS_1_LOW_DPIN_DISABLE BIT(5)
  507. #define TB_PLUG_EVENTS_CS_1_HIGH_DPIN_DISABLE BIT(6)
  508. #define TB_PLUG_EVENTS_PCIE_WR_DATA 0x1b
  509. #define TB_PLUG_EVENTS_PCIE_CMD 0x1c
  510. #define TB_PLUG_EVENTS_PCIE_CMD_DW_OFFSET_MASK GENMASK(9, 0)
  511. #define TB_PLUG_EVENTS_PCIE_CMD_BR_SHIFT 10
  512. #define TB_PLUG_EVENTS_PCIE_CMD_BR_MASK GENMASK(17, 10)
  513. #define TB_PLUG_EVENTS_PCIE_CMD_RD_WR_MASK BIT(21)
  514. #define TB_PLUG_EVENTS_PCIE_CMD_WR 0x1
  515. #define TB_PLUG_EVENTS_PCIE_CMD_COMMAND_SHIFT 22
  516. #define TB_PLUG_EVENTS_PCIE_CMD_COMMAND_MASK GENMASK(24, 22)
  517. #define TB_PLUG_EVENTS_PCIE_CMD_COMMAND_VAL 0x2
  518. #define TB_PLUG_EVENTS_PCIE_CMD_REQ_ACK_MASK BIT(30)
  519. #define TB_PLUG_EVENTS_PCIE_CMD_TIMEOUT_MASK BIT(31)
  520. #define TB_PLUG_EVENTS_PCIE_CMD_RD_DATA 0x1d
  521. /* CP Low Power registers */
  522. #define TB_LOW_PWR_C1_CL1 0x1
  523. #define TB_LOW_PWR_C1_CL1_OBJ_MASK GENMASK(4, 1)
  524. #define TB_LOW_PWR_C1_CL2_OBJ_MASK GENMASK(4, 1)
  525. #define TB_LOW_PWR_C1_PORT_A_MASK GENMASK(2, 1)
  526. #define TB_LOW_PWR_C0_PORT_B_MASK GENMASK(4, 3)
  527. #define TB_LOW_PWR_C3_CL1 0x3
  528. /* Common link controller registers */
  529. #define TB_LC_DESC 0x02
  530. #define TB_LC_DESC_NLC_MASK GENMASK(3, 0)
  531. #define TB_LC_DESC_SIZE_SHIFT 8
  532. #define TB_LC_DESC_SIZE_MASK GENMASK(15, 8)
  533. #define TB_LC_DESC_PORT_SIZE_SHIFT 16
  534. #define TB_LC_DESC_PORT_SIZE_MASK GENMASK(27, 16)
  535. #define TB_LC_FUSE 0x03
  536. #define TB_LC_SNK_ALLOCATION 0x10
  537. #define TB_LC_SNK_ALLOCATION_SNK0_MASK GENMASK(3, 0)
  538. #define TB_LC_SNK_ALLOCATION_SNK0_CM 0x1
  539. #define TB_LC_SNK_ALLOCATION_SNK1_SHIFT 4
  540. #define TB_LC_SNK_ALLOCATION_SNK1_MASK GENMASK(7, 4)
  541. #define TB_LC_SNK_ALLOCATION_SNK1_CM 0x1
  542. #define TB_LC_POWER 0x740
  543. /* Link controller registers */
  544. #define TB_LC_PORT_MODE 0x26
  545. #define TB_LC_PORT_MODE_DPR BIT(0)
  546. #define TB_LC_CS_42 0x2a
  547. #define TB_LC_CS_42_USB_PLUGGED BIT(31)
  548. #define TB_LC_PORT_ATTR 0x8d
  549. #define TB_LC_PORT_ATTR_BE BIT(12)
  550. #define TB_LC_SX_CTRL 0x96
  551. #define TB_LC_SX_CTRL_WOC BIT(1)
  552. #define TB_LC_SX_CTRL_WOD BIT(2)
  553. #define TB_LC_SX_CTRL_WODPC BIT(3)
  554. #define TB_LC_SX_CTRL_WODPD BIT(4)
  555. #define TB_LC_SX_CTRL_WOU4 BIT(5)
  556. #define TB_LC_SX_CTRL_WOP BIT(6)
  557. #define TB_LC_SX_CTRL_L1C BIT(16)
  558. #define TB_LC_SX_CTRL_L1D BIT(17)
  559. #define TB_LC_SX_CTRL_L2C BIT(20)
  560. #define TB_LC_SX_CTRL_L2D BIT(21)
  561. #define TB_LC_SX_CTRL_SLI BIT(29)
  562. #define TB_LC_SX_CTRL_UPSTREAM BIT(30)
  563. #define TB_LC_SX_CTRL_SLP BIT(31)
  564. #define TB_LC_LINK_ATTR 0x97
  565. #define TB_LC_LINK_ATTR_CPS BIT(18)
  566. #define TB_LC_LINK_REQ 0xad
  567. #define TB_LC_LINK_REQ_XHCI_CONNECT BIT(31)
  568. #endif