10eb6048fSFabio Estevam /* SPDX-License-Identifier: GPL-2.0 */ 217467f23STimur Tabi /* 37a8fceb7SNicolin Chen * fsl_ssi.h - ALSA SSI interface for the Freescale MPC8610 and i.MX SoC 417467f23STimur Tabi * 517467f23STimur Tabi * Author: Timur Tabi <timur@freescale.com> 617467f23STimur Tabi * 70eb6048fSFabio Estevam * Copyright 2007-2008 Freescale Semiconductor, Inc. 817467f23STimur Tabi */ 917467f23STimur Tabi 1017467f23STimur Tabi #ifndef _MPC8610_I2S_H 1117467f23STimur Tabi #define _MPC8610_I2S_H 1217467f23STimur Tabi 137a8fceb7SNicolin Chen /* -- SSI Register Map -- */ 147a8fceb7SNicolin Chen 157a8fceb7SNicolin Chen /* SSI Transmit Data Register 0 */ 16a818aa5fSNicolin Chen #define REG_SSI_STX0 0x00 177a8fceb7SNicolin Chen /* SSI Transmit Data Register 1 */ 18a818aa5fSNicolin Chen #define REG_SSI_STX1 0x04 197a8fceb7SNicolin Chen /* SSI Receive Data Register 0 */ 20a818aa5fSNicolin Chen #define REG_SSI_SRX0 0x08 217a8fceb7SNicolin Chen /* SSI Receive Data Register 1 */ 22a818aa5fSNicolin Chen #define REG_SSI_SRX1 0x0c 237a8fceb7SNicolin Chen /* SSI Control Register */ 24a818aa5fSNicolin Chen #define REG_SSI_SCR 0x10 257a8fceb7SNicolin Chen /* SSI Interrupt Status Register */ 26a818aa5fSNicolin Chen #define REG_SSI_SISR 0x14 277a8fceb7SNicolin Chen /* SSI Interrupt Enable Register */ 28a818aa5fSNicolin Chen #define REG_SSI_SIER 0x18 297a8fceb7SNicolin Chen /* SSI Transmit Configuration Register */ 30a818aa5fSNicolin Chen #define REG_SSI_STCR 0x1c 317a8fceb7SNicolin Chen /* SSI Receive Configuration Register */ 32a818aa5fSNicolin Chen #define REG_SSI_SRCR 0x20 3352eee84eSNicolin Chen #define REG_SSI_SxCR(tx) ((tx) ? REG_SSI_STCR : REG_SSI_SRCR) 347a8fceb7SNicolin Chen /* SSI Transmit Clock Control Register */ 35a818aa5fSNicolin Chen #define REG_SSI_STCCR 0x24 367a8fceb7SNicolin Chen /* SSI Receive Clock Control Register */ 37a818aa5fSNicolin Chen #define REG_SSI_SRCCR 0x28 3852eee84eSNicolin Chen #define REG_SSI_SxCCR(tx) ((tx) ? REG_SSI_STCCR : REG_SSI_SRCCR) 397a8fceb7SNicolin Chen /* SSI FIFO Control/Status Register */ 40a818aa5fSNicolin Chen #define REG_SSI_SFCSR 0x2c 417a8fceb7SNicolin Chen /* 427a8fceb7SNicolin Chen * SSI Test Register (Intended for debugging purposes only) 437a8fceb7SNicolin Chen * 447a8fceb7SNicolin Chen * Note: STR is not documented in recent IMX datasheet, but 457a8fceb7SNicolin Chen * is described in IMX51 reference manual at section 56.3.3.14 467a8fceb7SNicolin Chen */ 47a818aa5fSNicolin Chen #define REG_SSI_STR 0x30 487a8fceb7SNicolin Chen /* 497a8fceb7SNicolin Chen * SSI Option Register (Intended for internal use only) 507a8fceb7SNicolin Chen * 517a8fceb7SNicolin Chen * Note: SOR is not documented in recent IMX datasheet, but 527a8fceb7SNicolin Chen * is described in IMX51 reference manual at section 56.3.3.15 537a8fceb7SNicolin Chen */ 54a818aa5fSNicolin Chen #define REG_SSI_SOR 0x34 557a8fceb7SNicolin Chen /* SSI AC97 Control Register */ 56a818aa5fSNicolin Chen #define REG_SSI_SACNT 0x38 577a8fceb7SNicolin Chen /* SSI AC97 Command Address Register */ 58a818aa5fSNicolin Chen #define REG_SSI_SACADD 0x3c 597a8fceb7SNicolin Chen /* SSI AC97 Command Data Register */ 60a818aa5fSNicolin Chen #define REG_SSI_SACDAT 0x40 617a8fceb7SNicolin Chen /* SSI AC97 Tag Register */ 62a818aa5fSNicolin Chen #define REG_SSI_SATAG 0x44 637a8fceb7SNicolin Chen /* SSI Transmit Time Slot Mask Register */ 64a818aa5fSNicolin Chen #define REG_SSI_STMSK 0x48 657a8fceb7SNicolin Chen /* SSI Receive Time Slot Mask Register */ 66a818aa5fSNicolin Chen #define REG_SSI_SRMSK 0x4c 6752eee84eSNicolin Chen #define REG_SSI_SxMSK(tx) ((tx) ? REG_SSI_STMSK : REG_SSI_SRMSK) 687a8fceb7SNicolin Chen /* 697a8fceb7SNicolin Chen * SSI AC97 Channel Status Register 707a8fceb7SNicolin Chen * 717a8fceb7SNicolin Chen * The status could be changed by: 727a8fceb7SNicolin Chen * 1) Writing a '1' bit at some position in SACCEN sets relevant bit in SACCST 737a8fceb7SNicolin Chen * 2) Writing a '1' bit at some position in SACCDIS unsets the relevant bit 747a8fceb7SNicolin Chen * 3) Receivng a '1' in SLOTREQ bit from external CODEC via AC Link 757a8fceb7SNicolin Chen */ 76a818aa5fSNicolin Chen #define REG_SSI_SACCST 0x50 777a8fceb7SNicolin Chen /* SSI AC97 Channel Enable Register -- Set bits in SACCST */ 78a818aa5fSNicolin Chen #define REG_SSI_SACCEN 0x54 797a8fceb7SNicolin Chen /* SSI AC97 Channel Disable Register -- Clear bits in SACCST */ 80a818aa5fSNicolin Chen #define REG_SSI_SACCDIS 0x58 8117467f23STimur Tabi 827a8fceb7SNicolin Chen /* -- SSI Register Field Maps -- */ 837a8fceb7SNicolin Chen 84a818aa5fSNicolin Chen /* SSI Control Register -- REG_SSI_SCR 0x10 */ 85a818aa5fSNicolin Chen #define SSI_SCR_SYNC_TX_FS 0x00001000 86a818aa5fSNicolin Chen #define SSI_SCR_RFR_CLK_DIS 0x00000800 87a818aa5fSNicolin Chen #define SSI_SCR_TFR_CLK_DIS 0x00000400 88a818aa5fSNicolin Chen #define SSI_SCR_TCH_EN 0x00000100 89a818aa5fSNicolin Chen #define SSI_SCR_SYS_CLK_EN 0x00000080 90a818aa5fSNicolin Chen #define SSI_SCR_I2S_MODE_MASK 0x00000060 91a818aa5fSNicolin Chen #define SSI_SCR_I2S_MODE_NORMAL 0x00000000 92a818aa5fSNicolin Chen #define SSI_SCR_I2S_MODE_MASTER 0x00000020 93a818aa5fSNicolin Chen #define SSI_SCR_I2S_MODE_SLAVE 0x00000040 94a818aa5fSNicolin Chen #define SSI_SCR_SYN 0x00000010 95a818aa5fSNicolin Chen #define SSI_SCR_NET 0x00000008 968bc84a33SNicolin Chen #define SSI_SCR_I2S_NET_MASK (SSI_SCR_NET | SSI_SCR_I2S_MODE_MASK) 97a818aa5fSNicolin Chen #define SSI_SCR_RE 0x00000004 98a818aa5fSNicolin Chen #define SSI_SCR_TE 0x00000002 99a818aa5fSNicolin Chen #define SSI_SCR_SSIEN 0x00000001 10017467f23STimur Tabi 101a818aa5fSNicolin Chen /* SSI Interrupt Status Register -- REG_SSI_SISR 0x14 */ 102a818aa5fSNicolin Chen #define SSI_SISR_RFRC 0x01000000 103a818aa5fSNicolin Chen #define SSI_SISR_TFRC 0x00800000 104a818aa5fSNicolin Chen #define SSI_SISR_CMDAU 0x00040000 105a818aa5fSNicolin Chen #define SSI_SISR_CMDDU 0x00020000 106a818aa5fSNicolin Chen #define SSI_SISR_RXT 0x00010000 107a818aa5fSNicolin Chen #define SSI_SISR_RDR1 0x00008000 108a818aa5fSNicolin Chen #define SSI_SISR_RDR0 0x00004000 109a818aa5fSNicolin Chen #define SSI_SISR_TDE1 0x00002000 110a818aa5fSNicolin Chen #define SSI_SISR_TDE0 0x00001000 111a818aa5fSNicolin Chen #define SSI_SISR_ROE1 0x00000800 112a818aa5fSNicolin Chen #define SSI_SISR_ROE0 0x00000400 113a818aa5fSNicolin Chen #define SSI_SISR_TUE1 0x00000200 114a818aa5fSNicolin Chen #define SSI_SISR_TUE0 0x00000100 115a818aa5fSNicolin Chen #define SSI_SISR_TFS 0x00000080 116a818aa5fSNicolin Chen #define SSI_SISR_RFS 0x00000040 117a818aa5fSNicolin Chen #define SSI_SISR_TLS 0x00000020 118a818aa5fSNicolin Chen #define SSI_SISR_RLS 0x00000010 119a818aa5fSNicolin Chen #define SSI_SISR_RFF1 0x00000008 120a818aa5fSNicolin Chen #define SSI_SISR_RFF0 0x00000004 121a818aa5fSNicolin Chen #define SSI_SISR_TFE1 0x00000002 122a818aa5fSNicolin Chen #define SSI_SISR_TFE0 0x00000001 12317467f23STimur Tabi 124a818aa5fSNicolin Chen /* SSI Interrupt Enable Register -- REG_SSI_SIER 0x18 */ 125a818aa5fSNicolin Chen #define SSI_SIER_RFRC_EN 0x01000000 126a818aa5fSNicolin Chen #define SSI_SIER_TFRC_EN 0x00800000 127a818aa5fSNicolin Chen #define SSI_SIER_RDMAE 0x00400000 128a818aa5fSNicolin Chen #define SSI_SIER_RIE 0x00200000 129a818aa5fSNicolin Chen #define SSI_SIER_TDMAE 0x00100000 130a818aa5fSNicolin Chen #define SSI_SIER_TIE 0x00080000 131a818aa5fSNicolin Chen #define SSI_SIER_CMDAU_EN 0x00040000 132a818aa5fSNicolin Chen #define SSI_SIER_CMDDU_EN 0x00020000 133a818aa5fSNicolin Chen #define SSI_SIER_RXT_EN 0x00010000 134a818aa5fSNicolin Chen #define SSI_SIER_RDR1_EN 0x00008000 135a818aa5fSNicolin Chen #define SSI_SIER_RDR0_EN 0x00004000 136a818aa5fSNicolin Chen #define SSI_SIER_TDE1_EN 0x00002000 137a818aa5fSNicolin Chen #define SSI_SIER_TDE0_EN 0x00001000 138a818aa5fSNicolin Chen #define SSI_SIER_ROE1_EN 0x00000800 139a818aa5fSNicolin Chen #define SSI_SIER_ROE0_EN 0x00000400 140a818aa5fSNicolin Chen #define SSI_SIER_TUE1_EN 0x00000200 141a818aa5fSNicolin Chen #define SSI_SIER_TUE0_EN 0x00000100 142a818aa5fSNicolin Chen #define SSI_SIER_TFS_EN 0x00000080 143a818aa5fSNicolin Chen #define SSI_SIER_RFS_EN 0x00000040 144a818aa5fSNicolin Chen #define SSI_SIER_TLS_EN 0x00000020 145a818aa5fSNicolin Chen #define SSI_SIER_RLS_EN 0x00000010 146a818aa5fSNicolin Chen #define SSI_SIER_RFF1_EN 0x00000008 147a818aa5fSNicolin Chen #define SSI_SIER_RFF0_EN 0x00000004 148a818aa5fSNicolin Chen #define SSI_SIER_TFE1_EN 0x00000002 149a818aa5fSNicolin Chen #define SSI_SIER_TFE0_EN 0x00000001 15017467f23STimur Tabi 151a818aa5fSNicolin Chen /* SSI Transmit Configuration Register -- REG_SSI_STCR 0x1C */ 152a818aa5fSNicolin Chen #define SSI_STCR_TXBIT0 0x00000200 153a818aa5fSNicolin Chen #define SSI_STCR_TFEN1 0x00000100 154a818aa5fSNicolin Chen #define SSI_STCR_TFEN0 0x00000080 155a818aa5fSNicolin Chen #define SSI_STCR_TFDIR 0x00000040 156a818aa5fSNicolin Chen #define SSI_STCR_TXDIR 0x00000020 157a818aa5fSNicolin Chen #define SSI_STCR_TSHFD 0x00000010 158a818aa5fSNicolin Chen #define SSI_STCR_TSCKP 0x00000008 159a818aa5fSNicolin Chen #define SSI_STCR_TFSI 0x00000004 160a818aa5fSNicolin Chen #define SSI_STCR_TFSL 0x00000002 161a818aa5fSNicolin Chen #define SSI_STCR_TEFS 0x00000001 16217467f23STimur Tabi 163a818aa5fSNicolin Chen /* SSI Receive Configuration Register -- REG_SSI_SRCR 0x20 */ 164a818aa5fSNicolin Chen #define SSI_SRCR_RXEXT 0x00000400 165a818aa5fSNicolin Chen #define SSI_SRCR_RXBIT0 0x00000200 166a818aa5fSNicolin Chen #define SSI_SRCR_RFEN1 0x00000100 167a818aa5fSNicolin Chen #define SSI_SRCR_RFEN0 0x00000080 168a818aa5fSNicolin Chen #define SSI_SRCR_RFDIR 0x00000040 169a818aa5fSNicolin Chen #define SSI_SRCR_RXDIR 0x00000020 170a818aa5fSNicolin Chen #define SSI_SRCR_RSHFD 0x00000010 171a818aa5fSNicolin Chen #define SSI_SRCR_RSCKP 0x00000008 172a818aa5fSNicolin Chen #define SSI_SRCR_RFSI 0x00000004 173a818aa5fSNicolin Chen #define SSI_SRCR_RFSL 0x00000002 174a818aa5fSNicolin Chen #define SSI_SRCR_REFS 0x00000001 17517467f23STimur Tabi 1767a8fceb7SNicolin Chen /* 177a818aa5fSNicolin Chen * SSI Transmit Clock Control Register -- REG_SSI_STCCR 0x24 178a818aa5fSNicolin Chen * SSI Receive Clock Control Register -- REG_SSI_SRCCR 0x28 1797a8fceb7SNicolin Chen */ 180a818aa5fSNicolin Chen #define SSI_SxCCR_DIV2_SHIFT 18 181a818aa5fSNicolin Chen #define SSI_SxCCR_DIV2 0x00040000 182a818aa5fSNicolin Chen #define SSI_SxCCR_PSR_SHIFT 17 183a818aa5fSNicolin Chen #define SSI_SxCCR_PSR 0x00020000 184a818aa5fSNicolin Chen #define SSI_SxCCR_WL_SHIFT 13 185a818aa5fSNicolin Chen #define SSI_SxCCR_WL_MASK 0x0001E000 186a818aa5fSNicolin Chen #define SSI_SxCCR_WL(x) \ 187a818aa5fSNicolin Chen (((((x) / 2) - 1) << SSI_SxCCR_WL_SHIFT) & SSI_SxCCR_WL_MASK) 188a818aa5fSNicolin Chen #define SSI_SxCCR_DC_SHIFT 8 189a818aa5fSNicolin Chen #define SSI_SxCCR_DC_MASK 0x00001F00 190a818aa5fSNicolin Chen #define SSI_SxCCR_DC(x) \ 191a818aa5fSNicolin Chen ((((x) - 1) << SSI_SxCCR_DC_SHIFT) & SSI_SxCCR_DC_MASK) 192a818aa5fSNicolin Chen #define SSI_SxCCR_PM_SHIFT 0 193a818aa5fSNicolin Chen #define SSI_SxCCR_PM_MASK 0x000000FF 194a818aa5fSNicolin Chen #define SSI_SxCCR_PM(x) \ 195a818aa5fSNicolin Chen ((((x) - 1) << SSI_SxCCR_PM_SHIFT) & SSI_SxCCR_PM_MASK) 19617467f23STimur Tabi 19717467f23STimur Tabi /* 198a818aa5fSNicolin Chen * SSI FIFO Control/Status Register -- REG_SSI_SFCSR 0x2c 1997a8fceb7SNicolin Chen * 200a818aa5fSNicolin Chen * Tx or Rx FIFO Counter -- SSI_SFCSR_xFCNTy Read-Only 201a818aa5fSNicolin Chen * Tx or Rx FIFO Watermarks -- SSI_SFCSR_xFWMy Read/Write 20217467f23STimur Tabi */ 203a818aa5fSNicolin Chen #define SSI_SFCSR_RFCNT1_SHIFT 28 204a818aa5fSNicolin Chen #define SSI_SFCSR_RFCNT1_MASK 0xF0000000 205a818aa5fSNicolin Chen #define SSI_SFCSR_RFCNT1(x) \ 206a818aa5fSNicolin Chen (((x) & SSI_SFCSR_RFCNT1_MASK) >> SSI_SFCSR_RFCNT1_SHIFT) 207a818aa5fSNicolin Chen #define SSI_SFCSR_TFCNT1_SHIFT 24 208a818aa5fSNicolin Chen #define SSI_SFCSR_TFCNT1_MASK 0x0F000000 209a818aa5fSNicolin Chen #define SSI_SFCSR_TFCNT1(x) \ 210a818aa5fSNicolin Chen (((x) & SSI_SFCSR_TFCNT1_MASK) >> SSI_SFCSR_TFCNT1_SHIFT) 211a818aa5fSNicolin Chen #define SSI_SFCSR_RFWM1_SHIFT 20 212a818aa5fSNicolin Chen #define SSI_SFCSR_RFWM1_MASK 0x00F00000 213a818aa5fSNicolin Chen #define SSI_SFCSR_RFWM1(x) \ 214a818aa5fSNicolin Chen (((x) << SSI_SFCSR_RFWM1_SHIFT) & SSI_SFCSR_RFWM1_MASK) 215a818aa5fSNicolin Chen #define SSI_SFCSR_TFWM1_SHIFT 16 216a818aa5fSNicolin Chen #define SSI_SFCSR_TFWM1_MASK 0x000F0000 217a818aa5fSNicolin Chen #define SSI_SFCSR_TFWM1(x) \ 218a818aa5fSNicolin Chen (((x) << SSI_SFCSR_TFWM1_SHIFT) & SSI_SFCSR_TFWM1_MASK) 219a818aa5fSNicolin Chen #define SSI_SFCSR_RFCNT0_SHIFT 12 220a818aa5fSNicolin Chen #define SSI_SFCSR_RFCNT0_MASK 0x0000F000 221a818aa5fSNicolin Chen #define SSI_SFCSR_RFCNT0(x) \ 222a818aa5fSNicolin Chen (((x) & SSI_SFCSR_RFCNT0_MASK) >> SSI_SFCSR_RFCNT0_SHIFT) 223a818aa5fSNicolin Chen #define SSI_SFCSR_TFCNT0_SHIFT 8 224a818aa5fSNicolin Chen #define SSI_SFCSR_TFCNT0_MASK 0x00000F00 225a818aa5fSNicolin Chen #define SSI_SFCSR_TFCNT0(x) \ 226a818aa5fSNicolin Chen (((x) & SSI_SFCSR_TFCNT0_MASK) >> SSI_SFCSR_TFCNT0_SHIFT) 227a818aa5fSNicolin Chen #define SSI_SFCSR_RFWM0_SHIFT 4 228a818aa5fSNicolin Chen #define SSI_SFCSR_RFWM0_MASK 0x000000F0 229a818aa5fSNicolin Chen #define SSI_SFCSR_RFWM0(x) \ 230a818aa5fSNicolin Chen (((x) << SSI_SFCSR_RFWM0_SHIFT) & SSI_SFCSR_RFWM0_MASK) 231a818aa5fSNicolin Chen #define SSI_SFCSR_TFWM0_SHIFT 0 232a818aa5fSNicolin Chen #define SSI_SFCSR_TFWM0_MASK 0x0000000F 233a818aa5fSNicolin Chen #define SSI_SFCSR_TFWM0(x) \ 234a818aa5fSNicolin Chen (((x) << SSI_SFCSR_TFWM0_SHIFT) & SSI_SFCSR_TFWM0_MASK) 23517467f23STimur Tabi 236a818aa5fSNicolin Chen /* SSI Test Register -- REG_SSI_STR 0x30 */ 237a818aa5fSNicolin Chen #define SSI_STR_TEST 0x00008000 238a818aa5fSNicolin Chen #define SSI_STR_RCK2TCK 0x00004000 239a818aa5fSNicolin Chen #define SSI_STR_RFS2TFS 0x00002000 240a818aa5fSNicolin Chen #define SSI_STR_RXSTATE(x) (((x) >> 8) & 0x1F) 241a818aa5fSNicolin Chen #define SSI_STR_TXD2RXD 0x00000080 242a818aa5fSNicolin Chen #define SSI_STR_TCK2RCK 0x00000040 243a818aa5fSNicolin Chen #define SSI_STR_TFS2RFS 0x00000020 244a818aa5fSNicolin Chen #define SSI_STR_TXSTATE(x) ((x) & 0x1F) 24517467f23STimur Tabi 246a818aa5fSNicolin Chen /* SSI Option Register -- REG_SSI_SOR 0x34 */ 247a818aa5fSNicolin Chen #define SSI_SOR_CLKOFF 0x00000040 248a818aa5fSNicolin Chen #define SSI_SOR_RX_CLR 0x00000020 249a818aa5fSNicolin Chen #define SSI_SOR_TX_CLR 0x00000010 25052eee84eSNicolin Chen #define SSI_SOR_xX_CLR(tx) ((tx) ? SSI_SOR_TX_CLR : SSI_SOR_RX_CLR) 251a818aa5fSNicolin Chen #define SSI_SOR_INIT 0x00000008 252a818aa5fSNicolin Chen #define SSI_SOR_WAIT_SHIFT 1 253a818aa5fSNicolin Chen #define SSI_SOR_WAIT_MASK 0x00000006 254a818aa5fSNicolin Chen #define SSI_SOR_WAIT(x) (((x) & 3) << SSI_SOR_WAIT_SHIFT) 255a818aa5fSNicolin Chen #define SSI_SOR_SYNRST 0x00000001 25617467f23STimur Tabi 257a818aa5fSNicolin Chen /* SSI AC97 Control Register -- REG_SSI_SACNT 0x38 */ 258a818aa5fSNicolin Chen #define SSI_SACNT_FRDIV(x) (((x) & 0x3f) << 5) 259a818aa5fSNicolin Chen #define SSI_SACNT_WR 0x00000010 260a818aa5fSNicolin Chen #define SSI_SACNT_RD 0x00000008 261a818aa5fSNicolin Chen #define SSI_SACNT_RDWR_MASK 0x00000018 262a818aa5fSNicolin Chen #define SSI_SACNT_TIF 0x00000004 263a818aa5fSNicolin Chen #define SSI_SACNT_FV 0x00000002 264a818aa5fSNicolin Chen #define SSI_SACNT_AC97EN 0x00000001 265cd3ff762SMarkus Pargmann 26617467f23STimur Tabi 267f138e621SMarkus Pargmann struct device; 268f138e621SMarkus Pargmann 269f138e621SMarkus Pargmann #if IS_ENABLED(CONFIG_DEBUG_FS) 270f138e621SMarkus Pargmann 271f138e621SMarkus Pargmann struct fsl_ssi_dbg { 272f138e621SMarkus Pargmann struct dentry *dbg_dir; 273f138e621SMarkus Pargmann 274f138e621SMarkus Pargmann struct { 275f138e621SMarkus Pargmann unsigned int rfrc; 276f138e621SMarkus Pargmann unsigned int tfrc; 277f138e621SMarkus Pargmann unsigned int cmdau; 278f138e621SMarkus Pargmann unsigned int cmddu; 279f138e621SMarkus Pargmann unsigned int rxt; 280f138e621SMarkus Pargmann unsigned int rdr1; 281f138e621SMarkus Pargmann unsigned int rdr0; 282f138e621SMarkus Pargmann unsigned int tde1; 283f138e621SMarkus Pargmann unsigned int tde0; 284f138e621SMarkus Pargmann unsigned int roe1; 285f138e621SMarkus Pargmann unsigned int roe0; 286f138e621SMarkus Pargmann unsigned int tue1; 287f138e621SMarkus Pargmann unsigned int tue0; 288f138e621SMarkus Pargmann unsigned int tfs; 289f138e621SMarkus Pargmann unsigned int rfs; 290f138e621SMarkus Pargmann unsigned int tls; 291f138e621SMarkus Pargmann unsigned int rls; 292f138e621SMarkus Pargmann unsigned int rff1; 293f138e621SMarkus Pargmann unsigned int rff0; 294f138e621SMarkus Pargmann unsigned int tfe1; 295f138e621SMarkus Pargmann unsigned int tfe0; 296f138e621SMarkus Pargmann } stats; 297f138e621SMarkus Pargmann }; 298f138e621SMarkus Pargmann 299f138e621SMarkus Pargmann void fsl_ssi_dbg_isr(struct fsl_ssi_dbg *ssi_dbg, u32 sisr); 300f138e621SMarkus Pargmann 301*227ab8baSGreg Kroah-Hartman void fsl_ssi_debugfs_create(struct fsl_ssi_dbg *ssi_dbg, struct device *dev); 302f138e621SMarkus Pargmann 303f138e621SMarkus Pargmann void fsl_ssi_debugfs_remove(struct fsl_ssi_dbg *ssi_dbg); 304f138e621SMarkus Pargmann 305f138e621SMarkus Pargmann #else 306f138e621SMarkus Pargmann 307f138e621SMarkus Pargmann struct fsl_ssi_dbg { 308f138e621SMarkus Pargmann }; 309f138e621SMarkus Pargmann fsl_ssi_dbg_isr(struct fsl_ssi_dbg * stats,u32 sisr)310f138e621SMarkus Pargmannstatic inline void fsl_ssi_dbg_isr(struct fsl_ssi_dbg *stats, u32 sisr) 311f138e621SMarkus Pargmann { 312f138e621SMarkus Pargmann } 313f138e621SMarkus Pargmann fsl_ssi_debugfs_create(struct fsl_ssi_dbg * ssi_dbg,struct device * dev)314*227ab8baSGreg Kroah-Hartmanstatic inline void fsl_ssi_debugfs_create(struct fsl_ssi_dbg *ssi_dbg, 315f138e621SMarkus Pargmann struct device *dev) 316f138e621SMarkus Pargmann { 317f138e621SMarkus Pargmann } 318f138e621SMarkus Pargmann fsl_ssi_debugfs_remove(struct fsl_ssi_dbg * ssi_dbg)319f138e621SMarkus Pargmannstatic inline void fsl_ssi_debugfs_remove(struct fsl_ssi_dbg *ssi_dbg) 320f138e621SMarkus Pargmann { 321f138e621SMarkus Pargmann } 322f138e621SMarkus Pargmann #endif /* ! IS_ENABLED(CONFIG_DEBUG_FS) */ 323f138e621SMarkus Pargmann 324f138e621SMarkus Pargmann #endif 325