xref: /openbmc/u-boot/drivers/sound/broadwell_i2s.h (revision 0c41e59a37fbd5b10d4837ae30c288a084997465)
1*cbdfe599SSimon Glass /* SPDX-License-Identifier: GPL-2.0+ */
2*cbdfe599SSimon Glass /*
3*cbdfe599SSimon Glass  * Intel Broadwell I2S driver
4*cbdfe599SSimon Glass  *
5*cbdfe599SSimon Glass  * Copyright 2019 Google LLC
6*cbdfe599SSimon Glass  *
7*cbdfe599SSimon Glass  * Modified from dc i2s/broadwell/broadwell.h
8*cbdfe599SSimon Glass  */
9*cbdfe599SSimon Glass 
10*cbdfe599SSimon Glass #ifndef __BROADWELL_I2S_H__
11*cbdfe599SSimon Glass #define __BROADWELL_I2S_H__
12*cbdfe599SSimon Glass 
13*cbdfe599SSimon Glass enum {
14*cbdfe599SSimon Glass 	SSP_FIFO_SIZE = 7,
15*cbdfe599SSimon Glass };
16*cbdfe599SSimon Glass 
17*cbdfe599SSimon Glass enum frame_sync_rel_timing_t {
18*cbdfe599SSimon Glass 	NEXT_FRMS_AFTER_END_OF_T4 =  0,
19*cbdfe599SSimon Glass 	NEXT_FRMS_WITH_LSB_PREVIOUS_FRM,
20*cbdfe599SSimon Glass };
21*cbdfe599SSimon Glass 
22*cbdfe599SSimon Glass enum frame_sync_pol_t {
23*cbdfe599SSimon Glass 	SSP_FRMS_ACTIVE_LOW = 0,
24*cbdfe599SSimon Glass 	SSP_FRMS_ACTIVE_HIGH,
25*cbdfe599SSimon Glass };
26*cbdfe599SSimon Glass 
27*cbdfe599SSimon Glass enum end_transfer_state_t {
28*cbdfe599SSimon Glass 	SSP_END_TRANSFER_STATE_LOW = 0,
29*cbdfe599SSimon Glass 	SSP_END_TRANSFER_STATE_PEVIOUS_BIT,
30*cbdfe599SSimon Glass };
31*cbdfe599SSimon Glass 
32*cbdfe599SSimon Glass enum clock_mode_t {
33*cbdfe599SSimon Glass 	/* Data driven (falling), data sampled (rising), idle state (low) */
34*cbdfe599SSimon Glass 	SCLK_MODE_DDF_DSR_ISL,
35*cbdfe599SSimon Glass 	/* Data driven (rising), data sampled (falling), idle state (low) */
36*cbdfe599SSimon Glass 	SCLK_MODE_DDR_DSF_ISL,
37*cbdfe599SSimon Glass 	/* Data driven (rising), data sampled (falling), idle state (high) */
38*cbdfe599SSimon Glass 	SCLK_MODE_DDR_DSF_ISH,
39*cbdfe599SSimon Glass 	/* Data driven (falling), data sampled (rising), idle state (high) */
40*cbdfe599SSimon Glass 	SCLK_MODE_DDF_DSR_ISH,
41*cbdfe599SSimon Glass };
42*cbdfe599SSimon Glass 
43*cbdfe599SSimon Glass struct i2s_shim_regs {
44*cbdfe599SSimon Glass 	u32 csr;		/* 0x00 */
45*cbdfe599SSimon Glass 	u32 reserved0[29];	/* 0x14 - 0x77 */
46*cbdfe599SSimon Glass 	u32 clkctl;		/* 0x78 */
47*cbdfe599SSimon Glass 	u32 reserved1;		/* 0x7c */
48*cbdfe599SSimon Glass 	u32 cs2;		/* 0x80 */
49*cbdfe599SSimon Glass };
50*cbdfe599SSimon Glass 
51*cbdfe599SSimon Glass struct broadwell_i2s_regs {
52*cbdfe599SSimon Glass 	u32 sscr0;		/* 0x00 */
53*cbdfe599SSimon Glass 	u32 sscr1;		/* 0x04 */
54*cbdfe599SSimon Glass 	u32 sssr;		/* 0x08 */
55*cbdfe599SSimon Glass 	u32 ssitr;		/* 0x0c */
56*cbdfe599SSimon Glass 	u32 ssdr;		/* 0x10 */
57*cbdfe599SSimon Glass 	u32 reserved0[5];	/* 0x14 - 0x27 */
58*cbdfe599SSimon Glass 	u32 ssto;		/* 0x28 */
59*cbdfe599SSimon Glass 	u32 sspsp;		/* 0x2c */
60*cbdfe599SSimon Glass 	u32 sstsa;		/* 0x30 */
61*cbdfe599SSimon Glass 	u32 ssrsa;		/* 0x34 */
62*cbdfe599SSimon Glass 	u32 sstss;		/* 0x38 */
63*cbdfe599SSimon Glass 	u32 sscr2;		/* 0x40 */
64*cbdfe599SSimon Glass 	u32 sspsp2;		/* 0x44 */
65*cbdfe599SSimon Glass };
66*cbdfe599SSimon Glass 
67*cbdfe599SSimon Glass /* SHIM Configuration & Status */
68*cbdfe599SSimon Glass enum {
69*cbdfe599SSimon Glass 	/* Low Power Clock Select */
70*cbdfe599SSimon Glass 	SHIM_CS_LPCS = 1 << 31,
71*cbdfe599SSimon Glass 	/* SSP Force Clock Running */
72*cbdfe599SSimon Glass 	SHIM_CS_SFCR_SSP1 = 1 << 28,
73*cbdfe599SSimon Glass 	SHIM_CS_SFCR_SSP0 = 1 << 27,
74*cbdfe599SSimon Glass 	/* SSP1 IO Clock Select */
75*cbdfe599SSimon Glass 	SHIM_CS_S1IOCS = 1 << 23,
76*cbdfe599SSimon Glass 	/* SSP0 IO Clock Select */
77*cbdfe599SSimon Glass 	SHIM_CS_S0IOCS = 1 << 21,
78*cbdfe599SSimon Glass 	/* Parity Check Enable */
79*cbdfe599SSimon Glass 	SHIM_CS_PCE = 1 << 15,
80*cbdfe599SSimon Glass 	/* SSP DMA or PIO Mode */
81*cbdfe599SSimon Glass 	SHIM_CS_SDPM_PIO_SSP1 = 1 << 12,
82*cbdfe599SSimon Glass 	SHIM_CS_SDPM_DMA_SSP1 = 0 << 12,
83*cbdfe599SSimon Glass 	SHIM_CS_SDPM_PIO_SSP0 = 1 << 11,
84*cbdfe599SSimon Glass 	SHIM_CS_SDPM_DMA_SSP0 = 0 << 11,
85*cbdfe599SSimon Glass 	/* Run / Stall */
86*cbdfe599SSimon Glass 	SHIM_CS_STALL = 1 << 10,
87*cbdfe599SSimon Glass 	/* DSP Clock Select */
88*cbdfe599SSimon Glass 	SHIM_CS_DCS_DSP320_AF80 = 0 << 4,
89*cbdfe599SSimon Glass 	SHIM_CS_DCS_DSP160_AF80 = 1 << 4,
90*cbdfe599SSimon Glass 	SHIM_CS_DCS_DSP80_AF80 = 2 << 4,
91*cbdfe599SSimon Glass 	SHIM_CS_DCS_DSP320_AF160 = 4 << 4,
92*cbdfe599SSimon Glass 	SHIM_CS_DCS_DSP160_AF160 = 5 << 4,
93*cbdfe599SSimon Glass 	SHIM_CS_DCS_DSP32_AF32 = 6 << 4,
94*cbdfe599SSimon Glass 	SHIM_CS_DCS_MASK =  7 << 4,
95*cbdfe599SSimon Glass 	/* SSP Base Clock Select */
96*cbdfe599SSimon Glass 	SHIM_CS_SBCS_SSP0_24MHZ = 1 << 3,
97*cbdfe599SSimon Glass 	SHIM_CS_SBCS_SSP0_32MHZ = 0 << 3,
98*cbdfe599SSimon Glass 	SHIM_CS_SBCS_SSP1_24MHZ = 1 << 2,
99*cbdfe599SSimon Glass 	SHIM_CS_SBCS_SSP1_32MHZ = 0 << 2,
100*cbdfe599SSimon Glass 	/* DSP Core Reset */
101*cbdfe599SSimon Glass 	SHIM_CS_RST = 1 << 1,
102*cbdfe599SSimon Glass };
103*cbdfe599SSimon Glass 
104*cbdfe599SSimon Glass /* SHIM Clock Control */
105*cbdfe599SSimon Glass enum {
106*cbdfe599SSimon Glass 	/* Clock Frequency Change In Progress */
107*cbdfe599SSimon Glass 	SHIM_CLKCTL_CFCIP = 1 << 31,
108*cbdfe599SSimon Glass 	/* SSP MCLK Output Select */
109*cbdfe599SSimon Glass 	SHIM_CLKCTL_MCLK_MASK = 0x3,
110*cbdfe599SSimon Glass 	SHIM_CLKCTL_MCLK_SHIFT = 24,
111*cbdfe599SSimon Glass 	SHIM_CLKCTL_MCLK_DISABLED = 0 << 24,
112*cbdfe599SSimon Glass 	SHIM_CLKCTL_MCLK_6MHZ = 1 << 24,
113*cbdfe599SSimon Glass 	SHIM_CLKCTL_MCLK_12MHZ = 2 << 24,
114*cbdfe599SSimon Glass 	SHIM_CLKCTL_MCLK_24MHZ = 3 << 24,
115*cbdfe599SSimon Glass 	/* DSP Core Prevent Local Clock Gating */
116*cbdfe599SSimon Glass 	SHIM_CLKCTL_DCPLCG = 1 << 18,
117*cbdfe599SSimon Glass 	/* SSP Clock Output Enable */
118*cbdfe599SSimon Glass 	SHIM_CLKCTL_SCOE_SSP1 = 1 << 17,
119*cbdfe599SSimon Glass 	SHIM_CLKCTL_SCOE_SSP0 = 1 << 16,
120*cbdfe599SSimon Glass 	/* DMA Engine Force Local Clock Gating */
121*cbdfe599SSimon Glass 	SHIM_CLKCTL_DEFLCGB_DMA1_CGE = 0 << 6,
122*cbdfe599SSimon Glass 	SHIM_CLKCTL_DEFLCGB_DMA1_CGD = 1 << 6,
123*cbdfe599SSimon Glass 	SHIM_CLKCTL_DEFLCGB_DMA0_CGE = 0 << 5,
124*cbdfe599SSimon Glass 	SHIM_CLKCTL_DEFLCGB_DMA0_CGD = 1 << 5,
125*cbdfe599SSimon Glass 	/* SSP Force Local Clock Gating */
126*cbdfe599SSimon Glass 	SHIM_CLKCTL_SFLCGB_SSP1_CGE = 0 << 1,
127*cbdfe599SSimon Glass 	SHIM_CLKCTL_SFLCGB_SSP1_CGD = 1 << 1,
128*cbdfe599SSimon Glass 	SHIM_CLKCTL_SFLCGB_SSP0_CGE = 0 << 0,
129*cbdfe599SSimon Glass 	SHIM_CLKCTL_SFLCGB_SSP0_CGD = 1 << 0,
130*cbdfe599SSimon Glass 
131*cbdfe599SSimon Glass 	/* Reserved bits: 30:26, 23:19, 15:7, 4:2 */
132*cbdfe599SSimon Glass 	SHIM_CLKCTL_RESERVED = 0x1f << 26 | 0x1f << 19 | 0x1ff << 7 | 0x7 << 2,
133*cbdfe599SSimon Glass };
134*cbdfe599SSimon Glass 
135*cbdfe599SSimon Glass /* SSP Status */
136*cbdfe599SSimon Glass enum {
137*cbdfe599SSimon Glass 	/* Bit Count Error */
138*cbdfe599SSimon Glass 	SSP_SSS_BCE = 1 << 23,
139*cbdfe599SSimon Glass 	/* Clock Sync Statu s*/
140*cbdfe599SSimon Glass 	SSP_SSS_CSS = 1 << 22,
141*cbdfe599SSimon Glass 	/* Transmit FIFO Underrun */
142*cbdfe599SSimon Glass 	SSP_SSS_TUR = 1 << 21,
143*cbdfe599SSimon Glass 	/* End Of Chain */
144*cbdfe599SSimon Glass 	SSP_SSS_EOC = 1 << 20,
145*cbdfe599SSimon Glass 	/* Receiver Time-out Interrupt */
146*cbdfe599SSimon Glass 	SSP_SSS_TINT = 1 << 19,
147*cbdfe599SSimon Glass 	/* Peripheral Trailing Byte Interrupt */
148*cbdfe599SSimon Glass 	SSP_SSS_PINT = 1 << 18,
149*cbdfe599SSimon Glass 	/* Received FIFO Level */
150*cbdfe599SSimon Glass 	SSP_RFL_MASK = 0xf,
151*cbdfe599SSimon Glass 	SSP_RFL_SHIFT = 12,
152*cbdfe599SSimon Glass 	/* Transmit FIFO Level */
153*cbdfe599SSimon Glass 	SSP_TFL_MASK = 0xf,
154*cbdfe599SSimon Glass 	SSP_TFL_SHIFT = 8,
155*cbdfe599SSimon Glass 	/* Receive FIFO Overrun */
156*cbdfe599SSimon Glass 	SSP_SSS_ROR = 1 << 7,
157*cbdfe599SSimon Glass 	/* Receive FIFO Service Request */
158*cbdfe599SSimon Glass 	SSP_SSS_RFS = 1 << 6,
159*cbdfe599SSimon Glass 	/* Transmit FIFO Service Request */
160*cbdfe599SSimon Glass 	SSP_SSS_TFS = 1 << 5,
161*cbdfe599SSimon Glass 	/* SSP Busy */
162*cbdfe599SSimon Glass 	SSP_SSS_BSY = 1 << 4,
163*cbdfe599SSimon Glass 	/* Receive FIFO Not Empty */
164*cbdfe599SSimon Glass 	SSP_SSS_RNE = 1 << 3,
165*cbdfe599SSimon Glass 	/* Transmit FIFO Not Full */
166*cbdfe599SSimon Glass 	SSP_SSS_TNF = 1 << 2,
167*cbdfe599SSimon Glass };
168*cbdfe599SSimon Glass 
169*cbdfe599SSimon Glass /* SSP Control 0 */
170*cbdfe599SSimon Glass enum {
171*cbdfe599SSimon Glass 	/* Mode */
172*cbdfe599SSimon Glass 	SSP_SSC0_MODE_NORMAL = 0 << 31,
173*cbdfe599SSimon Glass 	SSP_SSC0_MODE_NETWORK = 1 << 31,
174*cbdfe599SSimon Glass 	/* Audio Clock Select */
175*cbdfe599SSimon Glass 	SSP_SSC0_ACS_PCH = 0 << 30,
176*cbdfe599SSimon Glass 	/* Frame Rate Divider Control (0-7) */
177*cbdfe599SSimon Glass 	SSP_SSC0_FRDC_MASK = 0x7,
178*cbdfe599SSimon Glass 	SSP_SSC0_FRDC_SHIFT = 24,
179*cbdfe599SSimon Glass 	SSP_SSC0_FRDC_STEREO = 1 << 24,
180*cbdfe599SSimon Glass 	/* Transmit FIFO Underrun Interrupt Mask */
181*cbdfe599SSimon Glass 	SSP_SSC0_TIM = 1 << 23,
182*cbdfe599SSimon Glass 	/* Receive FIFO Underrun Interrupt Mask */
183*cbdfe599SSimon Glass 	SSP_SSC0_RIM = 1 << 22,
184*cbdfe599SSimon Glass 	/* Network Clock Select */
185*cbdfe599SSimon Glass 	SSP_SSC0_NCS_PCH = 0 << 21,
186*cbdfe599SSimon Glass 	/* Extended Data Size Select */
187*cbdfe599SSimon Glass 	SSP_SSC0_EDSS = 1 << 20,
188*cbdfe599SSimon Glass 	/* Serial Clock Rate (0-4095) */
189*cbdfe599SSimon Glass 	SSP_SSC0_SCR_SHIFT = 8,
190*cbdfe599SSimon Glass 	SSP_SSC0_SCR_MASK = 0xfff << SSP_SSC0_SCR_SHIFT,
191*cbdfe599SSimon Glass 	/* Synchronous Serial Port Enable */
192*cbdfe599SSimon Glass 	SSP_SSC0_SSE = 1 << 7,
193*cbdfe599SSimon Glass 	/* External Clock Select */
194*cbdfe599SSimon Glass 	SSP_SSC0_ECS_PCH = 0 << 6,
195*cbdfe599SSimon Glass 	/* Frame Format */
196*cbdfe599SSimon Glass 	SSP_SSC0_FRF_MOTOROLA_SPI = 0 << 4,
197*cbdfe599SSimon Glass 	SSP_SSC0_FRF_TI_SSP = 1 << 4,
198*cbdfe599SSimon Glass 	SSP_SSC0_FRF_NS_MICROWIRE = 2 << 4,
199*cbdfe599SSimon Glass 	SSP_SSC0_FRF_PSP = 3 << 4,
200*cbdfe599SSimon Glass 	/* Data Size Select */
201*cbdfe599SSimon Glass 	SSP_SSC0_DSS_SHIFT = 0,
202*cbdfe599SSimon Glass 	SSP_SSC0_DSS_MASK = 0xf << SSP_SSC0_DSS_SHIFT,
203*cbdfe599SSimon Glass };
204*cbdfe599SSimon Glass 
205*cbdfe599SSimon Glass /* SSP Control 1 */
206*cbdfe599SSimon Glass enum {
207*cbdfe599SSimon Glass 	/* TXD Tristate Enable on Last Phase */
208*cbdfe599SSimon Glass 	SSP_SSC1_TTELP = 1 << 31,
209*cbdfe599SSimon Glass 	/* TXD Tristate Enable */
210*cbdfe599SSimon Glass 	SSP_SSC1_TTE = 1 << 30,
211*cbdfe599SSimon Glass 	/* Enable Bit Count Error Interrupt */
212*cbdfe599SSimon Glass 	SSP_SSC1_EBCEI = 1 << 29,
213*cbdfe599SSimon Glass 	/* Slave Clock Running */
214*cbdfe599SSimon Glass 	SSP_SSC1_SCFR = 1 << 28,
215*cbdfe599SSimon Glass 	/* Enable Clock Request A */
216*cbdfe599SSimon Glass 	SSP_SSC1_ECRA = 1 << 27,
217*cbdfe599SSimon Glass 	/* Enable Clock Request B */
218*cbdfe599SSimon Glass 	SSP_SSC1_ECRB = 1 << 26,
219*cbdfe599SSimon Glass 	/* SSPCLK Direction */
220*cbdfe599SSimon Glass 	SSP_SSC1_SCLKDIR_SLAVE = 1 << 25,
221*cbdfe599SSimon Glass 	SSP_SSC1_SCLKDIR_MASTER = 0 << 25,
222*cbdfe599SSimon Glass 	/* SSPFRM Direction */
223*cbdfe599SSimon Glass 	SSP_SSC1_SFRMDIR_SLAVE = 1 << 24,
224*cbdfe599SSimon Glass 	SSP_SSC1_SFRMDIR_MASTER = 0 << 24,
225*cbdfe599SSimon Glass 	/* Receive without Transmit */
226*cbdfe599SSimon Glass 	SSP_SSC1_RWOT = 1 << 23,
227*cbdfe599SSimon Glass 	/* Trailing Byte */
228*cbdfe599SSimon Glass 	SSP_SSC1_TRAIL = 1 << 22,
229*cbdfe599SSimon Glass 	/* DMA Tx Service Request Enable */
230*cbdfe599SSimon Glass 	SSP_SSC1_TSRE = 1 << 21,
231*cbdfe599SSimon Glass 	/* DMA Rx Service Request Enable */
232*cbdfe599SSimon Glass 	SSP_SSC1_RSRE = 1 << 20,
233*cbdfe599SSimon Glass 	/* Receiver Timeout Interrupt Enable */
234*cbdfe599SSimon Glass 	SSP_SSC1_TINTE = 1 << 19,
235*cbdfe599SSimon Glass 	/* Periph. Trailing Byte Int. Enable */
236*cbdfe599SSimon Glass 	SSP_SSC1_PINTE = 1 << 18,
237*cbdfe599SSimon Glass 	/* Invert Frame Signal */
238*cbdfe599SSimon Glass 	SSP_SSC1_IFS = 1 << 16,
239*cbdfe599SSimon Glass 	/* Select FIFO for EFWR: test mode */
240*cbdfe599SSimon Glass 	SSP_SSC1_STRF = 1 << 15,
241*cbdfe599SSimon Glass 	/* Enable FIFO Write/Read: test mode */
242*cbdfe599SSimon Glass 	SSP_SSC1_EFWR = 1 << 14,
243*cbdfe599SSimon Glass 	/* Receive FIFO Trigger Threshold */
244*cbdfe599SSimon Glass 	SSP_SSC1_RFT_SHIFT = 10,
245*cbdfe599SSimon Glass 	SSP_SSC1_RFT_MASK = 0xf << SSP_SSC1_RFT_SHIFT,
246*cbdfe599SSimon Glass 	/* Transmit FIFO Trigger Threshold */
247*cbdfe599SSimon Glass 	SSP_SSC1_TFT_SHIFT = 6,
248*cbdfe599SSimon Glass 	SSP_SSC1_TFT_MASK = 0xf << SSP_SSC1_TFT_SHIFT,
249*cbdfe599SSimon Glass 	/* Microwire Transmit Data Size */
250*cbdfe599SSimon Glass 	SSP_SSC1_MWDS = 1 << 5,
251*cbdfe599SSimon Glass 	/* Motorola SPI SSPSCLK Phase Setting*/
252*cbdfe599SSimon Glass 	SSP_SSC1_SPH = 1 << 4,
253*cbdfe599SSimon Glass 	/* Motorola SPI SSPSCLK Polarity */
254*cbdfe599SSimon Glass 	SSP_SSC1_SPO = 1 << 3,
255*cbdfe599SSimon Glass 	/* Loopback mode: test mode */
256*cbdfe599SSimon Glass 	SSP_SSC1_LBM = 1 << 2,
257*cbdfe599SSimon Glass 	/* Transmit FIFO Interrupt Enable */
258*cbdfe599SSimon Glass 	SSP_SSC1_TIE = 1 << 1,
259*cbdfe599SSimon Glass 	/* Receive FIFO Interrupt Enable */
260*cbdfe599SSimon Glass 	SSP_SSC1_RIE = 1 << 0,
261*cbdfe599SSimon Glass 
262*cbdfe599SSimon Glass 	SSP_SSC1_RESERVED = 17 << 1,
263*cbdfe599SSimon Glass };
264*cbdfe599SSimon Glass 
265*cbdfe599SSimon Glass /* SSP Programmable Serial Protocol */
266*cbdfe599SSimon Glass enum {
267*cbdfe599SSimon Glass 	/* Extended Dummy Stop (0-31) */
268*cbdfe599SSimon Glass 	SSP_PSP_EDYMSTOP_SHIFT = 26,
269*cbdfe599SSimon Glass 	SSP_PSP_EDMYSTOP_MASK = 0x7 << SSP_PSP_EDYMSTOP_SHIFT,
270*cbdfe599SSimon Glass 	/* Frame Sync Relative Timing */
271*cbdfe599SSimon Glass 	SSP_PSP_FSRT = 1 << 25,
272*cbdfe599SSimon Glass 	/* Dummy Stop low bits */
273*cbdfe599SSimon Glass 	SSP_PSP_DMYSTOP_SHIFT = 23,
274*cbdfe599SSimon Glass 	SSP_PSP_DMYSTOP_MASK = 0x3 << SSP_PSP_DMYSTOP_SHIFT,
275*cbdfe599SSimon Glass 	/* Serial Frame Width */
276*cbdfe599SSimon Glass 	SSP_PSP_SFRMWDTH_SHIFT = 16,
277*cbdfe599SSimon Glass 	SSP_PSP_SFRMWDTH_MASK = 0x3f << SSP_PSP_SFRMWDTH_SHIFT,
278*cbdfe599SSimon Glass 	/* Serial Frame Delay */
279*cbdfe599SSimon Glass 	SSP_PSP_SFRMDLY_MASK = 0x7f,
280*cbdfe599SSimon Glass 	SSP_PSP_SFRMDLY_SHIFT = 9,
281*cbdfe599SSimon Glass 	/* Start Delay */
282*cbdfe599SSimon Glass 	SSP_PSP_STRTDLY_MASK = 0x7,
283*cbdfe599SSimon Glass 	SSP_PSP_STRTDLY_SHIFT = 4,
284*cbdfe599SSimon Glass 	/* End of Transfer Data State */
285*cbdfe599SSimon Glass 	SSP_PSP_ETDS = 1 << 3,
286*cbdfe599SSimon Glass 	/* Serial Frame Polarity */
287*cbdfe599SSimon Glass 	SSP_PSP_SFRMP = 1 << 2,
288*cbdfe599SSimon Glass 	/* Serial Clock Mode */
289*cbdfe599SSimon Glass 	SSP_PSP_SCMODE_SHIFT = 0,
290*cbdfe599SSimon Glass 	SSP_PSP_SCMODE_MASK = 0x3 << SSP_PSP_SCMODE_SHIFT,
291*cbdfe599SSimon Glass 
292*cbdfe599SSimon Glass 	SSP_PSP_RESERVED = 1 << 22,
293*cbdfe599SSimon Glass };
294*cbdfe599SSimon Glass 
295*cbdfe599SSimon Glass /* SSP TX Time Slot Active */
296*cbdfe599SSimon Glass enum {
297*cbdfe599SSimon Glass 	SSP_SSTSA_EN = 1 << 8,
298*cbdfe599SSimon Glass 	SSP_SSTSA_MASK = 0xff,
299*cbdfe599SSimon Glass };
300*cbdfe599SSimon Glass 
301*cbdfe599SSimon Glass #endif /* __BROADWELL_I2S_H__ */
302