1*c66ec88fSEmmanuel Vadot /* SPDX-License-Identifier: GPL-2.0 */ 2*c66ec88fSEmmanuel Vadot /* 3*c66ec88fSEmmanuel Vadot * Copyright (C) 2017 Gateworks Corporation 4*c66ec88fSEmmanuel Vadot */ 5*c66ec88fSEmmanuel Vadot #ifndef _DT_BINDINGS_MEDIA_TDA1997X_H 6*c66ec88fSEmmanuel Vadot #define _DT_BINDINGS_MEDIA_TDA1997X_H 7*c66ec88fSEmmanuel Vadot 8*c66ec88fSEmmanuel Vadot /* TDA19973 36bit Video Port control registers */ 9*c66ec88fSEmmanuel Vadot #define TDA1997X_VP36_35_32 0 10*c66ec88fSEmmanuel Vadot #define TDA1997X_VP36_31_28 1 11*c66ec88fSEmmanuel Vadot #define TDA1997X_VP36_27_24 2 12*c66ec88fSEmmanuel Vadot #define TDA1997X_VP36_23_20 3 13*c66ec88fSEmmanuel Vadot #define TDA1997X_VP36_19_16 4 14*c66ec88fSEmmanuel Vadot #define TDA1997X_VP36_15_12 5 15*c66ec88fSEmmanuel Vadot #define TDA1997X_VP36_11_08 6 16*c66ec88fSEmmanuel Vadot #define TDA1997X_VP36_07_04 7 17*c66ec88fSEmmanuel Vadot #define TDA1997X_VP36_03_00 8 18*c66ec88fSEmmanuel Vadot 19*c66ec88fSEmmanuel Vadot /* TDA19971 24bit Video Port control registers */ 20*c66ec88fSEmmanuel Vadot #define TDA1997X_VP24_V23_20 0 21*c66ec88fSEmmanuel Vadot #define TDA1997X_VP24_V19_16 1 22*c66ec88fSEmmanuel Vadot #define TDA1997X_VP24_V15_12 3 23*c66ec88fSEmmanuel Vadot #define TDA1997X_VP24_V11_08 4 24*c66ec88fSEmmanuel Vadot #define TDA1997X_VP24_V07_04 6 25*c66ec88fSEmmanuel Vadot #define TDA1997X_VP24_V03_00 7 26*c66ec88fSEmmanuel Vadot 27*c66ec88fSEmmanuel Vadot /* Pin groups */ 28*c66ec88fSEmmanuel Vadot #define TDA1997X_VP_OUT_EN 0x80 /* enable output group */ 29*c66ec88fSEmmanuel Vadot #define TDA1997X_VP_HIZ 0x40 /* hi-Z output group when not used */ 30*c66ec88fSEmmanuel Vadot #define TDA1997X_VP_SWP 0x10 /* pin-swap output group */ 31*c66ec88fSEmmanuel Vadot #define TDA1997X_R_CR_CBCR_3_0 (0 | TDA1997X_VP_OUT_EN | TDA1997X_VP_HIZ) 32*c66ec88fSEmmanuel Vadot #define TDA1997X_R_CR_CBCR_7_4 (1 | TDA1997X_VP_OUT_EN | TDA1997X_VP_HIZ) 33*c66ec88fSEmmanuel Vadot #define TDA1997X_R_CR_CBCR_11_8 (2 | TDA1997X_VP_OUT_EN | TDA1997X_VP_HIZ) 34*c66ec88fSEmmanuel Vadot #define TDA1997X_B_CB_3_0 (3 | TDA1997X_VP_OUT_EN | TDA1997X_VP_HIZ) 35*c66ec88fSEmmanuel Vadot #define TDA1997X_B_CB_7_4 (4 | TDA1997X_VP_OUT_EN | TDA1997X_VP_HIZ) 36*c66ec88fSEmmanuel Vadot #define TDA1997X_B_CB_11_8 (5 | TDA1997X_VP_OUT_EN | TDA1997X_VP_HIZ) 37*c66ec88fSEmmanuel Vadot #define TDA1997X_G_Y_3_0 (6 | TDA1997X_VP_OUT_EN | TDA1997X_VP_HIZ) 38*c66ec88fSEmmanuel Vadot #define TDA1997X_G_Y_7_4 (7 | TDA1997X_VP_OUT_EN | TDA1997X_VP_HIZ) 39*c66ec88fSEmmanuel Vadot #define TDA1997X_G_Y_11_8 (8 | TDA1997X_VP_OUT_EN | TDA1997X_VP_HIZ) 40*c66ec88fSEmmanuel Vadot /* pinswapped groups */ 41*c66ec88fSEmmanuel Vadot #define TDA1997X_R_CR_CBCR_3_0_S (TDA1997X_R_CR_CBCR_3_0 | TDA1997X_VP_SWAP) 42*c66ec88fSEmmanuel Vadot #define TDA1997X_R_CR_CBCR_7_4_S (TDA1997X_R_CR_CBCR_7_4 | TDA1997X_VP_SWAP) 43*c66ec88fSEmmanuel Vadot #define TDA1997X_R_CR_CBCR_11_8_S (TDA1997X_R_CR_CBCR_11_8 | TDA1997X_VP_SWAP) 44*c66ec88fSEmmanuel Vadot #define TDA1997X_B_CB_3_0_S (TDA1997X_B_CB_3_0 | TDA1997X_VP_SWAP) 45*c66ec88fSEmmanuel Vadot #define TDA1997X_B_CB_7_4_S (TDA1997X_B_CB_7_4 | TDA1997X_VP_SWAP) 46*c66ec88fSEmmanuel Vadot #define TDA1997X_B_CB_11_8_S (TDA1997X_B_CB_11_8 | TDA1997X_VP_SWAP) 47*c66ec88fSEmmanuel Vadot #define TDA1997X_G_Y_3_0_S (TDA1997X_G_Y_3_0 | TDA1997X_VP_SWAP) 48*c66ec88fSEmmanuel Vadot #define TDA1997X_G_Y_7_4_S (TDA1997X_G_Y_7_4 | TDA1997X_VP_SWAP) 49*c66ec88fSEmmanuel Vadot #define TDA1997X_G_Y_11_8_S (TDA1997X_G_Y_11_8 | TDA1997X_VP_SWAP) 50*c66ec88fSEmmanuel Vadot 51*c66ec88fSEmmanuel Vadot /* Audio bus DAI format */ 52*c66ec88fSEmmanuel Vadot #define TDA1997X_I2S16 1 /* I2S 16bit */ 53*c66ec88fSEmmanuel Vadot #define TDA1997X_I2S32 2 /* I2S 32bit */ 54*c66ec88fSEmmanuel Vadot #define TDA1997X_SPDIF 3 /* SPDIF */ 55*c66ec88fSEmmanuel Vadot #define TDA1997X_OBA 4 /* One Bit Audio */ 56*c66ec88fSEmmanuel Vadot #define TDA1997X_DST 5 /* Direct Stream Transfer */ 57*c66ec88fSEmmanuel Vadot #define TDA1997X_I2S16_HBR 6 /* HBR straight in I2S 16bit mode */ 58*c66ec88fSEmmanuel Vadot #define TDA1997X_I2S16_HBR_DEMUX 7 /* HBR demux in I2S 16bit mode */ 59*c66ec88fSEmmanuel Vadot #define TDA1997X_I2S32_HBR_DEMUX 8 /* HBR demux in I2S 32bit mode */ 60*c66ec88fSEmmanuel Vadot #define TDA1997X_SPDIF_HBR_DEMUX 9 /* HBR demux in SPDIF mode */ 61*c66ec88fSEmmanuel Vadot 62*c66ec88fSEmmanuel Vadot /* Audio bus channel layout */ 63*c66ec88fSEmmanuel Vadot #define TDA1997X_LAYOUT0 0 /* 2-channel */ 64*c66ec88fSEmmanuel Vadot #define TDA1997X_LAYOUT1 1 /* 8-channel */ 65*c66ec88fSEmmanuel Vadot 66*c66ec88fSEmmanuel Vadot /* Audio bus clock */ 67*c66ec88fSEmmanuel Vadot #define TDA1997X_ACLK_16FS 0 68*c66ec88fSEmmanuel Vadot #define TDA1997X_ACLK_32FS 1 69*c66ec88fSEmmanuel Vadot #define TDA1997X_ACLK_64FS 2 70*c66ec88fSEmmanuel Vadot #define TDA1997X_ACLK_128FS 3 71*c66ec88fSEmmanuel Vadot #define TDA1997X_ACLK_256FS 4 72*c66ec88fSEmmanuel Vadot #define TDA1997X_ACLK_512FS 5 73*c66ec88fSEmmanuel Vadot 74*c66ec88fSEmmanuel Vadot #endif /* _DT_BINDINGS_MEDIA_TDA1997X_H */ 75