coreboot
coreboot is an Open Source project aimed at replacing the proprietary BIOS found in most computers.
tcss.h
Go to the documentation of this file.
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 
3 #ifndef _TCSS_H_
4 #define _TCSS_H_
5 
6 #include <intelblocks/gpio.h>
7 #include <device/usbc_mux.h>
8 
9 /* PMC IPC related offsets and commands */
10 #define PMC_IPC_USBC_CMD_ID 0xA7
11 #define PMC_IPC_USBC_SUBCMD_ID 0x0
12 #define PMC_IPC_CMD 0x0
13 #define PMC_IPC_TCSS_CONN_REQ_RES 0x0
14 #define PMC_IPC_TCSS_DISC_REQ_RES 0x1
15 #define PMC_IPC_TCSS_SAFE_MODE_REQ_RES 0x2
16 #define PMC_IPC_TCSS_ALTMODE_REQ_RES 0x3
17 #define PMC_IPC_TCSS_HPD_REQ_RES 0x4
18 #define PMC_IPC_CONN_REQ_SIZE 2
19 #define PMC_IPC_DISC_REQ_SIZE 2
20 #define PMC_IPC_ALT_REQ_SIZE 8
21 #define PMC_IPC_SAFE_REQ_SIZE 1
22 #define PMC_IPC_HPD_REQ_SIZE 2
23 #define PMC_IPC_DP_MODE 1
24 
25 #define TCSS_CD_USAGE_SHIFT 0
26 #define TCSS_CD_USAGE_MASK 0x0f
27 #define TCSS_CD_USB3_SHIFT 4
28 #define TCSS_CD_USB3_MASK 0x0f
29 #define TCSS_CD_USB2_SHIFT 8
30 #define TCSS_CD_USB2_MASK 0x0f
31 #define TCSS_CD_UFP_SHIFT 12
32 #define TCSS_CD_UFP_MASK 0x01
33 #define TCSS_CD_HSL_SHIFT 13
34 #define TCSS_CD_HSL_MASK 0x01
35 #define TCSS_CD_SBU_SHIFT 14
36 #define TCSS_CD_SBU_MASK 0x01
37 #define TCSS_CD_ACC_SHIFT 15
38 #define TCSS_CD_ACC_MASK 0x01
39 #define TCSS_CD_FAILED_SHIFT 16
40 #define TCSS_CD_FAILED_MASK 0x01
41 #define TCSS_CD_FATAL_SHIFT 17
42 #define TCSS_CD_FATAL_MASK 0x01
43 
44 #define TCSS_ALT_USAGE_SHIFT 0
45 #define TCSS_ALT_USAGE_MASK 0x0f
46 #define TCSS_ALT_USB3_SHIFT 4
47 #define TCSS_ALT_USB3_MASK 0x0f
48 #define TCSS_ALT_MODE_SHIFT 12
49 #define TCSS_ALT_MODE_MASK 0x0f
50 #define TCSS_ALT_POLARITY_SHIFT 1
51 #define TCSS_ALT_POLARITY_MASK 0x01
52 #define TCSS_ALT_CABLE_SHIFT 2
53 #define TCSS_ALT_CABLE_MASK 0x01
54 #define TCSS_ALT_UFP_SHIFT 3
55 #define TCSS_ALT_UFP_MASK 0x01
56 #define TCSS_ALT_DP_MODE_SHIFT 8
57 #define TCSS_ALT_DP_MODE_MASK 0x0f
58 #define TCSS_ALT_FAILED_SHIFT 8
59 #define TCSS_ALT_FAILED_MASK 0x01
60 #define TCSS_ALT_FATAL_SHIFT 9
61 #define TCSS_ALT_FATAL_MASK 0x01
62 
63 #define TCSS_HPD_USAGE_SHIFT 0
64 #define TCSS_HPD_USAGE_MASK 0x0f
65 #define TCSS_HPD_USB3_SHIFT 4
66 #define TCSS_HPD_USB3_MASK 0x0f
67 #define TCSS_HPD_LVL_SHIFT 12
68 #define TCSS_HPD_LVL_MASK 0x01
69 #define TCSS_HPD_IRQ_SHIFT 13
70 #define TCSS_HPD_IRQ_MASK 0x01
71 
78 };
79 
80 #define TCSS_CD_FIELD(name, val) \
81  (((val) & TCSS_CD_##name##_MASK) << TCSS_CD_##name##_SHIFT)
82 
83 #define GET_TCSS_CD_FIELD(name, val) \
84  (((val) >> TCSS_CD_##name##_SHIFT) & TCSS_CD_##name##_MASK)
85 
86 
87 #define TCSS_ALT_FIELD(name, val) \
88  (((val) & TCSS_ALT_##name##_MASK) << TCSS_ALT_##name##_SHIFT)
89 
90 #define TCSS_HPD_FIELD(name, val) \
91  (((val) & TCSS_HPD_##name##_MASK) << TCSS_HPD_##name##_SHIFT)
92 
93 #define GET_TCSS_ALT_FIELD(name, val) \
94  (((val) >> TCSS_ALT_##name##_SHIFT) & TCSS_ALT_##name##_MASK)
95 
96 #define TCSS_CONN_STATUS_HAS_FAILED(s) GET_TCSS_CD_FIELD(FAILED, s)
97 #define TCSS_STATUS_HAS_FAILED(s) GET_TCSS_ALT_FIELD(FAILED, s)
98 /* !fatal means retry */
99 #define TCSS_CONN_STATUS_IS_FATAL(s) GET_TCSS_CD_FIELD(FATAL, s)
100 #define TCSS_STATUS_IS_FATAL(s) GET_TCSS_ALT_FIELD(FATAL, s)
101 
102 #define USB_2_PORT_MASK 0x0f
103 #define USB_3_PORT_MASK 0xf0
104 
105 /* TCSS connection modes for PMC */
113 };
114 
120 };
121 
122 /* DP Mode pin definitions */
123 #define MODE_DP_PIN_A BIT(0)
124 #define MODE_DP_PIN_B BIT(1)
125 #define MODE_DP_PIN_C BIT(2)
126 #define MODE_DP_PIN_D BIT(3)
127 #define MODE_DP_PIN_E BIT(4)
128 #define MODE_DP_PIN_F BIT(5)
129 
131  uint8_t usb2_port; /* USB2 Port Number */
132  uint8_t usb3_port; /* USB3 Port Number */
133 };
134 
138 };
139 
140 struct soc_tcss_ops {
143 };
144 
145 extern const struct soc_tcss_ops tcss_ops;
146 
147 /* Method to configure pads */
150 
151 /*
152  * 1) Initialize TCSS muxes to disconnected state
153  * 2) Configure GPIO pads to provide DC Bias on AUX signals
154  * 3) Detect DP-over-Type-C alternate mode
155  */
156 void tcss_configure(const struct typec_aux_bias_pads aux_bias_pads[MAX_TYPE_C_PORTS]);
157 
158 /*
159  * Method to get only the port information to initialize the muxes to
160  * disconnect mode during boot.
161  * Returns tcss_port_map of all ports on system
162  */
163 const struct tcss_port_map *tcss_get_port_info(size_t *num_ports);
164 
165 /* Method to validate the Thunderbolt authentication */
166 bool tcss_valid_tbt_auth(void);
167 bool ioe_tcss_valid_tbt_auth(void);
168 
169 #endif /* _TCSS_H_ */
pmc_ipc_conn_mode
Definition: tcss.h:106
@ PMC_IPC_TCSS_USB_MODE
Definition: tcss.h:108
@ PMC_IPC_TCSS_SAFE_MODE
Definition: tcss.h:110
@ PMC_IPC_TCSS_HPD_MODE
Definition: tcss.h:111
@ PMC_IPC_TCSS_TOTAL_MODES
Definition: tcss.h:112
@ PMC_IPC_TCSS_ALTERNATE_MODE
Definition: tcss.h:109
@ PMC_IPC_TCSS_DISCONNECT_MODE
Definition: tcss.h:107
typec_port_index
Definition: tcss.h:72
@ TYPE_C_PORT_3
Definition: tcss.h:76
@ TYPE_C_PORT_2
Definition: tcss.h:75
@ TYPE_C_PORT_1
Definition: tcss.h:74
@ MAX_TYPE_C_PORTS
Definition: tcss.h:77
@ TYPE_C_PORT_0
Definition: tcss.h:73
void tcss_configure(const struct typec_aux_bias_pads aux_bias_pads[MAX_TYPE_C_PORTS])
Definition: tcss.c:415
const struct tcss_port_map * tcss_get_port_info(size_t *num_ports)
Definition: tcss.c:384
bool ioe_tcss_valid_tbt_auth(void)
Definition: tcss.c:441
const struct soc_tcss_ops tcss_ops
Definition: tcss.c:5
pmc_ipc_command_type
Definition: tcss.h:115
@ CONNECT_REQ
Definition: tcss.h:116
@ SAFE_REQ
Definition: tcss.h:117
@ DP_REQ
Definition: tcss.h:118
@ HPD_REQ
Definition: tcss.h:119
void ioe_tcss_configure_aux_bias_pads_sbi(const struct typec_aux_bias_pads *pads)
Definition: tcss.c:371
void tcss_configure_aux_bias_pads_regbar(const struct typec_aux_bias_pads *pads)
Definition: tcss.c:358
bool tcss_valid_tbt_auth(void)
Definition: tcss.c:436
_Bool bool
Definition: stdbool.h:6
unsigned char uint8_t
Definition: stdint.h:8
bool(* valid_tbt_auth)(void)
Definition: tcss.h:142
void(* configure_aux_bias_pads)(const struct typec_aux_bias_pads *pads)
Definition: tcss.h:141
uint8_t usb2_port
Definition: tcss.h:131
uint8_t usb3_port
Definition: tcss.h:132
gpio_t pad_auxn_dc
Definition: tcss.h:136
gpio_t pad_auxp_dc
Definition: tcss.h:137
typedef void(X86APIP X86EMU_intrFuncs)(int num)