17#include "../tcpm/usb_pd_tcpm.h"
21#define fusb302_DEVID_302A 0x08
22#define fusb302_DEVID_302B 0x09
26#define fusb302_I2C_SLAVE_ADDR 0x22
28#define fusb302_I2C_SLAVE_ADDR_B01 0x23
30#define fusb302_I2C_SLAVE_ADDR_B10 0x24
32#define fusb302_I2C_SLAVE_ADDR_B11 0x25
35#define PD_RETRY_COUNT 3
38#define PD_T_TCPC_TX_TIMEOUT (100 * MSEC_US)
40#define TCPC_REG_DEVICE_ID 0x01
42#define TCPC_REG_SWITCHES0 0x02
43#define TCPC_REG_SWITCHES0_CC2_PU_EN (1 << 7)
44#define TCPC_REG_SWITCHES0_CC1_PU_EN (1 << 6)
45#define TCPC_REG_SWITCHES0_VCONN_CC2 (1 << 5)
46#define TCPC_REG_SWITCHES0_VCONN_CC1 (1 << 4)
47#define TCPC_REG_SWITCHES0_MEAS_CC2 (1 << 3)
48#define TCPC_REG_SWITCHES0_MEAS_CC1 (1 << 2)
49#define TCPC_REG_SWITCHES0_CC2_PD_EN (1 << 1)
50#define TCPC_REG_SWITCHES0_CC1_PD_EN (1 << 0)
52#define TCPC_REG_SWITCHES1 0x03
53#define TCPC_REG_SWITCHES1_POWERROLE (1 << 7)
54#define TCPC_REG_SWITCHES1_SPECREV1 (1 << 6)
55#define TCPC_REG_SWITCHES1_SPECREV0 (1 << 5)
56#define TCPC_REG_SWITCHES1_DATAROLE (1 << 4)
57#define TCPC_REG_SWITCHES1_AUTO_GCRC (1 << 2)
58#define TCPC_REG_SWITCHES1_TXCC2_EN (1 << 1)
59#define TCPC_REG_SWITCHES1_TXCC1_EN (1 << 0)
61#define TCPC_REG_MEASURE 0x04
62#define TCPC_REG_MEASURE_VBUS (1 << 6)
63#define TCPC_REG_MEASURE_MDAC_MASK 0x3f
64#define TCPC_REG_MEASURE_MDAC_MV(mv) (((mv) / 42) & TCPC_REG_MEASURE_MDAC_MASK)
66#define TCPC_REG_CONTROL0 0x06
67#define TCPC_REG_CONTROL0_TX_FLUSH (1 << 6)
68#define TCPC_REG_CONTROL0_INT_MASK (1 << 5)
69#define TCPC_REG_CONTROL0_HOST_CUR_MASK (3 << 2)
70#define TCPC_REG_CONTROL0_HOST_CUR_3A0 (3 << 2)
71#define TCPC_REG_CONTROL0_HOST_CUR_1A5 (2 << 2)
72#define TCPC_REG_CONTROL0_HOST_CUR_USB (1 << 2)
73#define TCPC_REG_CONTROL0_TX_START (1 << 0)
75#define TCPC_REG_CONTROL1 0x07
76#define TCPC_REG_CONTROL1_ENSOP2DB (1 << 6)
77#define TCPC_REG_CONTROL1_ENSOP1DB (1 << 5)
78#define TCPC_REG_CONTROL1_BIST_MODE2 (1 << 4)
79#define TCPC_REG_CONTROL1_RX_FLUSH (1 << 2)
80#define TCPC_REG_CONTROL1_ENSOP2 (1 << 1)
81#define TCPC_REG_CONTROL1_ENSOP1 (1 << 0)
83#define TCPC_REG_CONTROL2 0x08
85#define TCPC_REG_CONTROL2_MODE_MASK (0x3 << TCPC_REG_CONTROL2_MODE_POS)
86#define TCPC_REG_CONTROL2_MODE (1 << 1)
87#define TCPC_REG_CONTROL2_MODE_DFP (0x3)
88#define TCPC_REG_CONTROL2_MODE_UFP (0x2)
89#define TCPC_REG_CONTROL2_MODE_DRP (0x1)
90#define TCPC_REG_CONTROL2_MODE_POS (1)
91#define TCPC_REG_CONTROL2_TOGGLE (1 << 0)
93#define TCPC_REG_CONTROL3 0x09
94#define TCPC_REG_CONTROL3_SEND_HARDRESET (1 << 6)
95#define TCPC_REG_CONTROL3_BIST_TMODE (1 << 5)
96#define TCPC_REG_CONTROL3_AUTO_HARDRESET (1 << 4)
97#define TCPC_REG_CONTROL3_AUTO_SOFTRESET (1 << 3)
99#define TCPC_REG_CONTROL3_N_RETRIES (1 << 1)
100#define TCPC_REG_CONTROL3_N_RETRIES_POS (1)
101#define TCPC_REG_CONTROL3_N_RETRIES_SIZE (2)
102#define TCPC_REG_CONTROL3_AUTO_RETRY (1 << 0)
104#define TCPC_REG_MASK 0x0A
105#define TCPC_REG_MASK_VBUSOK (1 << 7)
106#define TCPC_REG_MASK_ACTIVITY (1 << 6)
107#define TCPC_REG_MASK_COMP_CHNG (1 << 5)
108#define TCPC_REG_MASK_CRC_CHK (1 << 4)
109#define TCPC_REG_MASK_ALERT (1 << 3)
110#define TCPC_REG_MASK_WAKE (1 << 2)
111#define TCPC_REG_MASK_COLLISION (1 << 1)
112#define TCPC_REG_MASK_BC_LVL (1 << 0)
114#define TCPC_REG_POWER 0x0B
115#define TCPC_REG_POWER_PWR (1 << 0)
116#define TCPC_REG_POWER_PWR_LOW 0x1
117#define TCPC_REG_POWER_PWR_MEDIUM 0x3
118#define TCPC_REG_POWER_PWR_HIGH 0x7
119#define TCPC_REG_POWER_PWR_ALL 0xF
121#define TCPC_REG_RESET 0x0C
122#define TCPC_REG_RESET_PD_RESET (1 << 1)
123#define TCPC_REG_RESET_SW_RESET (1 << 0)
125#define TCPC_REG_MASKA 0x0E
126#define TCPC_REG_MASKA_OCP_TEMP (1 << 7)
127#define TCPC_REG_MASKA_TOGDONE (1 << 6)
128#define TCPC_REG_MASKA_SOFTFAIL (1 << 5)
129#define TCPC_REG_MASKA_RETRYFAIL (1 << 4)
130#define TCPC_REG_MASKA_HARDSENT (1 << 3)
131#define TCPC_REG_MASKA_TX_SUCCESS (1 << 2)
132#define TCPC_REG_MASKA_SOFTRESET (1 << 1)
133#define TCPC_REG_MASKA_HARDRESET (1 << 0)
135#define TCPC_REG_MASKB 0x0F
136#define TCPC_REG_MASKB_GCRCSENT (1 << 0)
138#define TCPC_REG_STATUS0A 0x3C
139#define TCPC_REG_STATUS0A_SOFTFAIL (1 << 5)
140#define TCPC_REG_STATUS0A_RETRYFAIL (1 << 4)
141#define TCPC_REG_STATUS0A_POWER (1 << 2)
142#define TCPC_REG_STATUS0A_RX_SOFT_RESET (1 << 1)
143#define TCPC_REG_STATUS0A_RX_HARD_RESET (1 << 0)
145#define TCPC_REG_STATUS1A 0x3D
147#define TCPC_REG_STATUS1A_TOGSS (1 << 3)
148#define TCPC_REG_STATUS1A_TOGSS_RUNNING 0x0
149#define TCPC_REG_STATUS1A_TOGSS_SRC1 0x1
150#define TCPC_REG_STATUS1A_TOGSS_SRC2 0x2
151#define TCPC_REG_STATUS1A_TOGSS_SNK1 0x5
152#define TCPC_REG_STATUS1A_TOGSS_SNK2 0x6
153#define TCPC_REG_STATUS1A_TOGSS_AA 0x7
154#define TCPC_REG_STATUS1A_TOGSS_POS (3)
155#define TCPC_REG_STATUS1A_TOGSS_MASK (0x7)
157#define TCPC_REG_STATUS1A_RXSOP2DB (1 << 2)
158#define TCPC_REG_STATUS1A_RXSOP1DB (1 << 1)
159#define TCPC_REG_STATUS1A_RXSOP (1 << 0)
161#define TCPC_REG_INTERRUPTA 0x3E
162#define TCPC_REG_INTERRUPTA_OCP_TEMP (1 << 7)
163#define TCPC_REG_INTERRUPTA_TOGDONE (1 << 6)
164#define TCPC_REG_INTERRUPTA_SOFTFAIL (1 << 5)
165#define TCPC_REG_INTERRUPTA_RETRYFAIL (1 << 4)
166#define TCPC_REG_INTERRUPTA_HARDSENT (1 << 3)
167#define TCPC_REG_INTERRUPTA_TX_SUCCESS (1 << 2)
168#define TCPC_REG_INTERRUPTA_SOFTRESET (1 << 1)
169#define TCPC_REG_INTERRUPTA_HARDRESET (1 << 0)
171#define TCPC_REG_INTERRUPTB 0x3F
172#define TCPC_REG_INTERRUPTB_GCRCSENT (1 << 0)
174#define TCPC_REG_STATUS0 0x40
175#define TCPC_REG_STATUS0_VBUSOK (1 << 7)
176#define TCPC_REG_STATUS0_ACTIVITY (1 << 6)
177#define TCPC_REG_STATUS0_COMP (1 << 5)
178#define TCPC_REG_STATUS0_CRC_CHK (1 << 4)
179#define TCPC_REG_STATUS0_ALERT (1 << 3)
180#define TCPC_REG_STATUS0_WAKE (1 << 2)
181#define TCPC_REG_STATUS0_BC_LVL1 (1 << 1)
182#define TCPC_REG_STATUS0_BC_LVL0 (1 << 0)
184#define TCPC_REG_STATUS1 0x41
185#define TCPC_REG_STATUS1_RXSOP2 (1 << 7)
186#define TCPC_REG_STATUS1_RXSOP1 (1 << 6)
187#define TCPC_REG_STATUS1_RX_EMPTY (1 << 5)
188#define TCPC_REG_STATUS1_RX_FULL (1 << 4)
189#define TCPC_REG_STATUS1_TX_EMPTY (1 << 3)
190#define TCPC_REG_STATUS1_TX_FULL (1 << 2)
192#define TCPC_REG_INTERRUPT 0x42
193#define TCPC_REG_INTERRUPT_VBUSOK (1 << 7)
194#define TCPC_REG_INTERRUPT_ACTIVITY (1 << 6)
195#define TCPC_REG_INTERRUPT_COMP_CHNG (1 << 5)
196#define TCPC_REG_INTERRUPT_CRC_CHK (1 << 4)
197#define TCPC_REG_INTERRUPT_ALERT (1 << 3)
198#define TCPC_REG_INTERRUPT_WAKE (1 << 2)
199#define TCPC_REG_INTERRUPT_COLLISION (1 << 1)
200#define TCPC_REG_INTERRUPT_BC_LVL (1 << 0)
202#define TCPC_REG_FIFOS 0x43
205 enum fusb302_txfifo_tokens
207 fusb302_TKN_TXON = 0xA1,
208 fusb302_TKN_SYNC1 = 0x12,
209 fusb302_TKN_SYNC2 = 0x13,
210 fusb302_TKN_SYNC3 = 0x1B,
211 fusb302_TKN_RST1 = 0x15,
212 fusb302_TKN_RST2 = 0x16,
213 fusb302_TKN_PACKSYM = 0x80,
214 fusb302_TKN_JAMCRC = 0xFF,
215 fusb302_TKN_EOP = 0x14,
216 fusb302_TKN_TXOFF = 0xFE,
219 extern const struct tcpm_drv fusb302_tcpm_drv;
Definition: usb_pd_tcpm.h:268