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