linux_dsm_epyc7002/drivers/gpu/drm/bridge/synopsys/dw-hdmi.h
Yakir Yang 3250cdf938 drm: bridge/dw_hdmi: add audio sample channel status setting
When transmitting IEC60985 linear PCM audio, we configure the
Aduio Sample Channel Status information in the IEC60958 frame.
The status bit is already available in iec.status of hdmi_codec_params.

This fix the issue that audio does not come out on some monitors
(e.g. LG 22CV241)

Note that these registers are only for interfaces:
I2S audio interface, General Purpose Audio (GPA), or AHB audio DMA
(AHBAUDDMA).
For S/PDIF interface this information comes from the stream.

Currently this function dw_hdmi_set_channel_status is only called
from dw-hdmi-i2s-audio in I2S setup.

Signed-off-by: Yakir Yang <ykk@rock-chips.com>
Signed-off-by: Cheng-Yi Chiang <cychiang@chromium.org>
Reviewed-by: Jonas Karlman <jonas@kwiboo.se>
Signed-off-by: Neil Armstrong <narmstrong@baylibre.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20190911082646.134347-1-cychiang@chromium.org
2019-09-13 10:43:51 +02:00

1120 lines
47 KiB
C

/* SPDX-License-Identifier: GPL-2.0-or-later */
/*
* Copyright (C) 2011 Freescale Semiconductor, Inc.
*/
#ifndef __DW_HDMI_H__
#define __DW_HDMI_H__
/* Identification Registers */
#define HDMI_DESIGN_ID 0x0000
#define HDMI_REVISION_ID 0x0001
#define HDMI_PRODUCT_ID0 0x0002
#define HDMI_PRODUCT_ID1 0x0003
#define HDMI_CONFIG0_ID 0x0004
#define HDMI_CONFIG1_ID 0x0005
#define HDMI_CONFIG2_ID 0x0006
#define HDMI_CONFIG3_ID 0x0007
/* Interrupt Registers */
#define HDMI_IH_FC_STAT0 0x0100
#define HDMI_IH_FC_STAT1 0x0101
#define HDMI_IH_FC_STAT2 0x0102
#define HDMI_IH_AS_STAT0 0x0103
#define HDMI_IH_PHY_STAT0 0x0104
#define HDMI_IH_I2CM_STAT0 0x0105
#define HDMI_IH_CEC_STAT0 0x0106
#define HDMI_IH_VP_STAT0 0x0107
#define HDMI_IH_I2CMPHY_STAT0 0x0108
#define HDMI_IH_AHBDMAAUD_STAT0 0x0109
#define HDMI_IH_MUTE_FC_STAT0 0x0180
#define HDMI_IH_MUTE_FC_STAT1 0x0181
#define HDMI_IH_MUTE_FC_STAT2 0x0182
#define HDMI_IH_MUTE_AS_STAT0 0x0183
#define HDMI_IH_MUTE_PHY_STAT0 0x0184
#define HDMI_IH_MUTE_I2CM_STAT0 0x0185
#define HDMI_IH_MUTE_CEC_STAT0 0x0186
#define HDMI_IH_MUTE_VP_STAT0 0x0187
#define HDMI_IH_MUTE_I2CMPHY_STAT0 0x0188
#define HDMI_IH_MUTE_AHBDMAAUD_STAT0 0x0189
#define HDMI_IH_MUTE 0x01FF
/* Video Sample Registers */
#define HDMI_TX_INVID0 0x0200
#define HDMI_TX_INSTUFFING 0x0201
#define HDMI_TX_GYDATA0 0x0202
#define HDMI_TX_GYDATA1 0x0203
#define HDMI_TX_RCRDATA0 0x0204
#define HDMI_TX_RCRDATA1 0x0205
#define HDMI_TX_BCBDATA0 0x0206
#define HDMI_TX_BCBDATA1 0x0207
/* Video Packetizer Registers */
#define HDMI_VP_STATUS 0x0800
#define HDMI_VP_PR_CD 0x0801
#define HDMI_VP_STUFF 0x0802
#define HDMI_VP_REMAP 0x0803
#define HDMI_VP_CONF 0x0804
#define HDMI_VP_STAT 0x0805
#define HDMI_VP_INT 0x0806
#define HDMI_VP_MASK 0x0807
#define HDMI_VP_POL 0x0808
/* Frame Composer Registers */
#define HDMI_FC_INVIDCONF 0x1000
#define HDMI_FC_INHACTV0 0x1001
#define HDMI_FC_INHACTV1 0x1002
#define HDMI_FC_INHBLANK0 0x1003
#define HDMI_FC_INHBLANK1 0x1004
#define HDMI_FC_INVACTV0 0x1005
#define HDMI_FC_INVACTV1 0x1006
#define HDMI_FC_INVBLANK 0x1007
#define HDMI_FC_HSYNCINDELAY0 0x1008
#define HDMI_FC_HSYNCINDELAY1 0x1009
#define HDMI_FC_HSYNCINWIDTH0 0x100A
#define HDMI_FC_HSYNCINWIDTH1 0x100B
#define HDMI_FC_VSYNCINDELAY 0x100C
#define HDMI_FC_VSYNCINWIDTH 0x100D
#define HDMI_FC_INFREQ0 0x100E
#define HDMI_FC_INFREQ1 0x100F
#define HDMI_FC_INFREQ2 0x1010
#define HDMI_FC_CTRLDUR 0x1011
#define HDMI_FC_EXCTRLDUR 0x1012
#define HDMI_FC_EXCTRLSPAC 0x1013
#define HDMI_FC_CH0PREAM 0x1014
#define HDMI_FC_CH1PREAM 0x1015
#define HDMI_FC_CH2PREAM 0x1016
#define HDMI_FC_AVICONF3 0x1017
#define HDMI_FC_GCP 0x1018
#define HDMI_FC_AVICONF0 0x1019
#define HDMI_FC_AVICONF1 0x101A
#define HDMI_FC_AVICONF2 0x101B
#define HDMI_FC_AVIVID 0x101C
#define HDMI_FC_AVIETB0 0x101D
#define HDMI_FC_AVIETB1 0x101E
#define HDMI_FC_AVISBB0 0x101F
#define HDMI_FC_AVISBB1 0x1020
#define HDMI_FC_AVIELB0 0x1021
#define HDMI_FC_AVIELB1 0x1022
#define HDMI_FC_AVISRB0 0x1023
#define HDMI_FC_AVISRB1 0x1024
#define HDMI_FC_AUDICONF0 0x1025
#define HDMI_FC_AUDICONF1 0x1026
#define HDMI_FC_AUDICONF2 0x1027
#define HDMI_FC_AUDICONF3 0x1028
#define HDMI_FC_VSDIEEEID0 0x1029
#define HDMI_FC_VSDSIZE 0x102A
#define HDMI_FC_VSDIEEEID1 0x1030
#define HDMI_FC_VSDIEEEID2 0x1031
#define HDMI_FC_VSDPAYLOAD0 0x1032
#define HDMI_FC_VSDPAYLOAD1 0x1033
#define HDMI_FC_VSDPAYLOAD2 0x1034
#define HDMI_FC_VSDPAYLOAD3 0x1035
#define HDMI_FC_VSDPAYLOAD4 0x1036
#define HDMI_FC_VSDPAYLOAD5 0x1037
#define HDMI_FC_VSDPAYLOAD6 0x1038
#define HDMI_FC_VSDPAYLOAD7 0x1039
#define HDMI_FC_VSDPAYLOAD8 0x103A
#define HDMI_FC_VSDPAYLOAD9 0x103B
#define HDMI_FC_VSDPAYLOAD10 0x103C
#define HDMI_FC_VSDPAYLOAD11 0x103D
#define HDMI_FC_VSDPAYLOAD12 0x103E
#define HDMI_FC_VSDPAYLOAD13 0x103F
#define HDMI_FC_VSDPAYLOAD14 0x1040
#define HDMI_FC_VSDPAYLOAD15 0x1041
#define HDMI_FC_VSDPAYLOAD16 0x1042
#define HDMI_FC_VSDPAYLOAD17 0x1043
#define HDMI_FC_VSDPAYLOAD18 0x1044
#define HDMI_FC_VSDPAYLOAD19 0x1045
#define HDMI_FC_VSDPAYLOAD20 0x1046
#define HDMI_FC_VSDPAYLOAD21 0x1047
#define HDMI_FC_VSDPAYLOAD22 0x1048
#define HDMI_FC_VSDPAYLOAD23 0x1049
#define HDMI_FC_SPDVENDORNAME0 0x104A
#define HDMI_FC_SPDVENDORNAME1 0x104B
#define HDMI_FC_SPDVENDORNAME2 0x104C
#define HDMI_FC_SPDVENDORNAME3 0x104D
#define HDMI_FC_SPDVENDORNAME4 0x104E
#define HDMI_FC_SPDVENDORNAME5 0x104F
#define HDMI_FC_SPDVENDORNAME6 0x1050
#define HDMI_FC_SPDVENDORNAME7 0x1051
#define HDMI_FC_SDPPRODUCTNAME0 0x1052
#define HDMI_FC_SDPPRODUCTNAME1 0x1053
#define HDMI_FC_SDPPRODUCTNAME2 0x1054
#define HDMI_FC_SDPPRODUCTNAME3 0x1055
#define HDMI_FC_SDPPRODUCTNAME4 0x1056
#define HDMI_FC_SDPPRODUCTNAME5 0x1057
#define HDMI_FC_SDPPRODUCTNAME6 0x1058
#define HDMI_FC_SDPPRODUCTNAME7 0x1059
#define HDMI_FC_SDPPRODUCTNAME8 0x105A
#define HDMI_FC_SDPPRODUCTNAME9 0x105B
#define HDMI_FC_SDPPRODUCTNAME10 0x105C
#define HDMI_FC_SDPPRODUCTNAME11 0x105D
#define HDMI_FC_SDPPRODUCTNAME12 0x105E
#define HDMI_FC_SDPPRODUCTNAME13 0x105F
#define HDMI_FC_SDPPRODUCTNAME14 0x1060
#define HDMI_FC_SPDPRODUCTNAME15 0x1061
#define HDMI_FC_SPDDEVICEINF 0x1062
#define HDMI_FC_AUDSCONF 0x1063
#define HDMI_FC_AUDSSTAT 0x1064
#define HDMI_FC_AUDSCHNLS7 0x106e
#define HDMI_FC_AUDSCHNLS8 0x106f
#define HDMI_FC_DATACH0FILL 0x1070
#define HDMI_FC_DATACH1FILL 0x1071
#define HDMI_FC_DATACH2FILL 0x1072
#define HDMI_FC_CTRLQHIGH 0x1073
#define HDMI_FC_CTRLQLOW 0x1074
#define HDMI_FC_ACP0 0x1075
#define HDMI_FC_ACP28 0x1076
#define HDMI_FC_ACP27 0x1077
#define HDMI_FC_ACP26 0x1078
#define HDMI_FC_ACP25 0x1079
#define HDMI_FC_ACP24 0x107A
#define HDMI_FC_ACP23 0x107B
#define HDMI_FC_ACP22 0x107C
#define HDMI_FC_ACP21 0x107D
#define HDMI_FC_ACP20 0x107E
#define HDMI_FC_ACP19 0x107F
#define HDMI_FC_ACP18 0x1080
#define HDMI_FC_ACP17 0x1081
#define HDMI_FC_ACP16 0x1082
#define HDMI_FC_ACP15 0x1083
#define HDMI_FC_ACP14 0x1084
#define HDMI_FC_ACP13 0x1085
#define HDMI_FC_ACP12 0x1086
#define HDMI_FC_ACP11 0x1087
#define HDMI_FC_ACP10 0x1088
#define HDMI_FC_ACP9 0x1089
#define HDMI_FC_ACP8 0x108A
#define HDMI_FC_ACP7 0x108B
#define HDMI_FC_ACP6 0x108C
#define HDMI_FC_ACP5 0x108D
#define HDMI_FC_ACP4 0x108E
#define HDMI_FC_ACP3 0x108F
#define HDMI_FC_ACP2 0x1090
#define HDMI_FC_ACP1 0x1091
#define HDMI_FC_ISCR1_0 0x1092
#define HDMI_FC_ISCR1_16 0x1093
#define HDMI_FC_ISCR1_15 0x1094
#define HDMI_FC_ISCR1_14 0x1095
#define HDMI_FC_ISCR1_13 0x1096
#define HDMI_FC_ISCR1_12 0x1097
#define HDMI_FC_ISCR1_11 0x1098
#define HDMI_FC_ISCR1_10 0x1099
#define HDMI_FC_ISCR1_9 0x109A
#define HDMI_FC_ISCR1_8 0x109B
#define HDMI_FC_ISCR1_7 0x109C
#define HDMI_FC_ISCR1_6 0x109D
#define HDMI_FC_ISCR1_5 0x109E
#define HDMI_FC_ISCR1_4 0x109F
#define HDMI_FC_ISCR1_3 0x10A0
#define HDMI_FC_ISCR1_2 0x10A1
#define HDMI_FC_ISCR1_1 0x10A2
#define HDMI_FC_ISCR2_15 0x10A3
#define HDMI_FC_ISCR2_14 0x10A4
#define HDMI_FC_ISCR2_13 0x10A5
#define HDMI_FC_ISCR2_12 0x10A6
#define HDMI_FC_ISCR2_11 0x10A7
#define HDMI_FC_ISCR2_10 0x10A8
#define HDMI_FC_ISCR2_9 0x10A9
#define HDMI_FC_ISCR2_8 0x10AA
#define HDMI_FC_ISCR2_7 0x10AB
#define HDMI_FC_ISCR2_6 0x10AC
#define HDMI_FC_ISCR2_5 0x10AD
#define HDMI_FC_ISCR2_4 0x10AE
#define HDMI_FC_ISCR2_3 0x10AF
#define HDMI_FC_ISCR2_2 0x10B0
#define HDMI_FC_ISCR2_1 0x10B1
#define HDMI_FC_ISCR2_0 0x10B2
#define HDMI_FC_DATAUTO0 0x10B3
#define HDMI_FC_DATAUTO1 0x10B4
#define HDMI_FC_DATAUTO2 0x10B5
#define HDMI_FC_DATMAN 0x10B6
#define HDMI_FC_DATAUTO3 0x10B7
#define HDMI_FC_RDRB0 0x10B8
#define HDMI_FC_RDRB1 0x10B9
#define HDMI_FC_RDRB2 0x10BA
#define HDMI_FC_RDRB3 0x10BB
#define HDMI_FC_RDRB4 0x10BC
#define HDMI_FC_RDRB5 0x10BD
#define HDMI_FC_RDRB6 0x10BE
#define HDMI_FC_RDRB7 0x10BF
#define HDMI_FC_STAT0 0x10D0
#define HDMI_FC_INT0 0x10D1
#define HDMI_FC_MASK0 0x10D2
#define HDMI_FC_POL0 0x10D3
#define HDMI_FC_STAT1 0x10D4
#define HDMI_FC_INT1 0x10D5
#define HDMI_FC_MASK1 0x10D6
#define HDMI_FC_POL1 0x10D7
#define HDMI_FC_STAT2 0x10D8
#define HDMI_FC_INT2 0x10D9
#define HDMI_FC_MASK2 0x10DA
#define HDMI_FC_POL2 0x10DB
#define HDMI_FC_PRCONF 0x10E0
#define HDMI_FC_SCRAMBLER_CTRL 0x10E1
#define HDMI_FC_GMD_STAT 0x1100
#define HDMI_FC_GMD_EN 0x1101
#define HDMI_FC_GMD_UP 0x1102
#define HDMI_FC_GMD_CONF 0x1103
#define HDMI_FC_GMD_HB 0x1104
#define HDMI_FC_GMD_PB0 0x1105
#define HDMI_FC_GMD_PB1 0x1106
#define HDMI_FC_GMD_PB2 0x1107
#define HDMI_FC_GMD_PB3 0x1108
#define HDMI_FC_GMD_PB4 0x1109
#define HDMI_FC_GMD_PB5 0x110A
#define HDMI_FC_GMD_PB6 0x110B
#define HDMI_FC_GMD_PB7 0x110C
#define HDMI_FC_GMD_PB8 0x110D
#define HDMI_FC_GMD_PB9 0x110E
#define HDMI_FC_GMD_PB10 0x110F
#define HDMI_FC_GMD_PB11 0x1110
#define HDMI_FC_GMD_PB12 0x1111
#define HDMI_FC_GMD_PB13 0x1112
#define HDMI_FC_GMD_PB14 0x1113
#define HDMI_FC_GMD_PB15 0x1114
#define HDMI_FC_GMD_PB16 0x1115
#define HDMI_FC_GMD_PB17 0x1116
#define HDMI_FC_GMD_PB18 0x1117
#define HDMI_FC_GMD_PB19 0x1118
#define HDMI_FC_GMD_PB20 0x1119
#define HDMI_FC_GMD_PB21 0x111A
#define HDMI_FC_GMD_PB22 0x111B
#define HDMI_FC_GMD_PB23 0x111C
#define HDMI_FC_GMD_PB24 0x111D
#define HDMI_FC_GMD_PB25 0x111E
#define HDMI_FC_GMD_PB26 0x111F
#define HDMI_FC_GMD_PB27 0x1120
#define HDMI_FC_DBGFORCE 0x1200
#define HDMI_FC_DBGAUD0CH0 0x1201
#define HDMI_FC_DBGAUD1CH0 0x1202
#define HDMI_FC_DBGAUD2CH0 0x1203
#define HDMI_FC_DBGAUD0CH1 0x1204
#define HDMI_FC_DBGAUD1CH1 0x1205
#define HDMI_FC_DBGAUD2CH1 0x1206
#define HDMI_FC_DBGAUD0CH2 0x1207
#define HDMI_FC_DBGAUD1CH2 0x1208
#define HDMI_FC_DBGAUD2CH2 0x1209
#define HDMI_FC_DBGAUD0CH3 0x120A
#define HDMI_FC_DBGAUD1CH3 0x120B
#define HDMI_FC_DBGAUD2CH3 0x120C
#define HDMI_FC_DBGAUD0CH4 0x120D
#define HDMI_FC_DBGAUD1CH4 0x120E
#define HDMI_FC_DBGAUD2CH4 0x120F
#define HDMI_FC_DBGAUD0CH5 0x1210
#define HDMI_FC_DBGAUD1CH5 0x1211
#define HDMI_FC_DBGAUD2CH5 0x1212
#define HDMI_FC_DBGAUD0CH6 0x1213
#define HDMI_FC_DBGAUD1CH6 0x1214
#define HDMI_FC_DBGAUD2CH6 0x1215
#define HDMI_FC_DBGAUD0CH7 0x1216
#define HDMI_FC_DBGAUD1CH7 0x1217
#define HDMI_FC_DBGAUD2CH7 0x1218
#define HDMI_FC_DBGTMDS0 0x1219
#define HDMI_FC_DBGTMDS1 0x121A
#define HDMI_FC_DBGTMDS2 0x121B
/* HDMI Source PHY Registers */
#define HDMI_PHY_CONF0 0x3000
#define HDMI_PHY_TST0 0x3001
#define HDMI_PHY_TST1 0x3002
#define HDMI_PHY_TST2 0x3003
#define HDMI_PHY_STAT0 0x3004
#define HDMI_PHY_INT0 0x3005
#define HDMI_PHY_MASK0 0x3006
#define HDMI_PHY_POL0 0x3007
/* HDMI Master PHY Registers */
#define HDMI_PHY_I2CM_SLAVE_ADDR 0x3020
#define HDMI_PHY_I2CM_ADDRESS_ADDR 0x3021
#define HDMI_PHY_I2CM_DATAO_1_ADDR 0x3022
#define HDMI_PHY_I2CM_DATAO_0_ADDR 0x3023
#define HDMI_PHY_I2CM_DATAI_1_ADDR 0x3024
#define HDMI_PHY_I2CM_DATAI_0_ADDR 0x3025
#define HDMI_PHY_I2CM_OPERATION_ADDR 0x3026
#define HDMI_PHY_I2CM_INT_ADDR 0x3027
#define HDMI_PHY_I2CM_CTLINT_ADDR 0x3028
#define HDMI_PHY_I2CM_DIV_ADDR 0x3029
#define HDMI_PHY_I2CM_SOFTRSTZ_ADDR 0x302a
#define HDMI_PHY_I2CM_SS_SCL_HCNT_1_ADDR 0x302b
#define HDMI_PHY_I2CM_SS_SCL_HCNT_0_ADDR 0x302c
#define HDMI_PHY_I2CM_SS_SCL_LCNT_1_ADDR 0x302d
#define HDMI_PHY_I2CM_SS_SCL_LCNT_0_ADDR 0x302e
#define HDMI_PHY_I2CM_FS_SCL_HCNT_1_ADDR 0x302f
#define HDMI_PHY_I2CM_FS_SCL_HCNT_0_ADDR 0x3030
#define HDMI_PHY_I2CM_FS_SCL_LCNT_1_ADDR 0x3031
#define HDMI_PHY_I2CM_FS_SCL_LCNT_0_ADDR 0x3032
/* Audio Sampler Registers */
#define HDMI_AUD_CONF0 0x3100
#define HDMI_AUD_CONF1 0x3101
#define HDMI_AUD_INT 0x3102
#define HDMI_AUD_CONF2 0x3103
#define HDMI_AUD_N1 0x3200
#define HDMI_AUD_N2 0x3201
#define HDMI_AUD_N3 0x3202
#define HDMI_AUD_CTS1 0x3203
#define HDMI_AUD_CTS2 0x3204
#define HDMI_AUD_CTS3 0x3205
#define HDMI_AUD_INPUTCLKFS 0x3206
#define HDMI_AUD_SPDIFINT 0x3302
#define HDMI_AUD_CONF0_HBR 0x3400
#define HDMI_AUD_HBR_STATUS 0x3401
#define HDMI_AUD_HBR_INT 0x3402
#define HDMI_AUD_HBR_POL 0x3403
#define HDMI_AUD_HBR_MASK 0x3404
/*
* Generic Parallel Audio Interface Registers
* Not used as GPAUD interface is not enabled in hw
*/
#define HDMI_GP_CONF0 0x3500
#define HDMI_GP_CONF1 0x3501
#define HDMI_GP_CONF2 0x3502
#define HDMI_GP_STAT 0x3503
#define HDMI_GP_INT 0x3504
#define HDMI_GP_MASK 0x3505
#define HDMI_GP_POL 0x3506
/* Audio DMA Registers */
#define HDMI_AHB_DMA_CONF0 0x3600
#define HDMI_AHB_DMA_START 0x3601
#define HDMI_AHB_DMA_STOP 0x3602
#define HDMI_AHB_DMA_THRSLD 0x3603
#define HDMI_AHB_DMA_STRADDR0 0x3604
#define HDMI_AHB_DMA_STRADDR1 0x3605
#define HDMI_AHB_DMA_STRADDR2 0x3606
#define HDMI_AHB_DMA_STRADDR3 0x3607
#define HDMI_AHB_DMA_STPADDR0 0x3608
#define HDMI_AHB_DMA_STPADDR1 0x3609
#define HDMI_AHB_DMA_STPADDR2 0x360a
#define HDMI_AHB_DMA_STPADDR3 0x360b
#define HDMI_AHB_DMA_BSTADDR0 0x360c
#define HDMI_AHB_DMA_BSTADDR1 0x360d
#define HDMI_AHB_DMA_BSTADDR2 0x360e
#define HDMI_AHB_DMA_BSTADDR3 0x360f
#define HDMI_AHB_DMA_MBLENGTH0 0x3610
#define HDMI_AHB_DMA_MBLENGTH1 0x3611
#define HDMI_AHB_DMA_STAT 0x3612
#define HDMI_AHB_DMA_INT 0x3613
#define HDMI_AHB_DMA_MASK 0x3614
#define HDMI_AHB_DMA_POL 0x3615
#define HDMI_AHB_DMA_CONF1 0x3616
#define HDMI_AHB_DMA_BUFFSTAT 0x3617
#define HDMI_AHB_DMA_BUFFINT 0x3618
#define HDMI_AHB_DMA_BUFFMASK 0x3619
#define HDMI_AHB_DMA_BUFFPOL 0x361a
/* Main Controller Registers */
#define HDMI_MC_SFRDIV 0x4000
#define HDMI_MC_CLKDIS 0x4001
#define HDMI_MC_SWRSTZ 0x4002
#define HDMI_MC_OPCTRL 0x4003
#define HDMI_MC_FLOWCTRL 0x4004
#define HDMI_MC_PHYRSTZ 0x4005
#define HDMI_MC_LOCKONCLOCK 0x4006
#define HDMI_MC_HEACPHY_RST 0x4007
/* Color Space Converter Registers */
#define HDMI_CSC_CFG 0x4100
#define HDMI_CSC_SCALE 0x4101
#define HDMI_CSC_COEF_A1_MSB 0x4102
#define HDMI_CSC_COEF_A1_LSB 0x4103
#define HDMI_CSC_COEF_A2_MSB 0x4104
#define HDMI_CSC_COEF_A2_LSB 0x4105
#define HDMI_CSC_COEF_A3_MSB 0x4106
#define HDMI_CSC_COEF_A3_LSB 0x4107
#define HDMI_CSC_COEF_A4_MSB 0x4108
#define HDMI_CSC_COEF_A4_LSB 0x4109
#define HDMI_CSC_COEF_B1_MSB 0x410A
#define HDMI_CSC_COEF_B1_LSB 0x410B
#define HDMI_CSC_COEF_B2_MSB 0x410C
#define HDMI_CSC_COEF_B2_LSB 0x410D
#define HDMI_CSC_COEF_B3_MSB 0x410E
#define HDMI_CSC_COEF_B3_LSB 0x410F
#define HDMI_CSC_COEF_B4_MSB 0x4110
#define HDMI_CSC_COEF_B4_LSB 0x4111
#define HDMI_CSC_COEF_C1_MSB 0x4112
#define HDMI_CSC_COEF_C1_LSB 0x4113
#define HDMI_CSC_COEF_C2_MSB 0x4114
#define HDMI_CSC_COEF_C2_LSB 0x4115
#define HDMI_CSC_COEF_C3_MSB 0x4116
#define HDMI_CSC_COEF_C3_LSB 0x4117
#define HDMI_CSC_COEF_C4_MSB 0x4118
#define HDMI_CSC_COEF_C4_LSB 0x4119
/* HDCP Encryption Engine Registers */
#define HDMI_A_HDCPCFG0 0x5000
#define HDMI_A_HDCPCFG1 0x5001
#define HDMI_A_HDCPOBS0 0x5002
#define HDMI_A_HDCPOBS1 0x5003
#define HDMI_A_HDCPOBS2 0x5004
#define HDMI_A_HDCPOBS3 0x5005
#define HDMI_A_APIINTCLR 0x5006
#define HDMI_A_APIINTSTAT 0x5007
#define HDMI_A_APIINTMSK 0x5008
#define HDMI_A_VIDPOLCFG 0x5009
#define HDMI_A_OESSWCFG 0x500A
#define HDMI_A_TIMER1SETUP0 0x500B
#define HDMI_A_TIMER1SETUP1 0x500C
#define HDMI_A_TIMER2SETUP0 0x500D
#define HDMI_A_TIMER2SETUP1 0x500E
#define HDMI_A_100MSCFG 0x500F
#define HDMI_A_2SCFG0 0x5010
#define HDMI_A_2SCFG1 0x5011
#define HDMI_A_5SCFG0 0x5012
#define HDMI_A_5SCFG1 0x5013
#define HDMI_A_SRMVERLSB 0x5014
#define HDMI_A_SRMVERMSB 0x5015
#define HDMI_A_SRMCTRL 0x5016
#define HDMI_A_SFRSETUP 0x5017
#define HDMI_A_I2CHSETUP 0x5018
#define HDMI_A_INTSETUP 0x5019
#define HDMI_A_PRESETUP 0x501A
#define HDMI_A_SRM_BASE 0x5020
/* I2C Master Registers (E-DDC) */
#define HDMI_I2CM_SLAVE 0x7E00
#define HDMI_I2CM_ADDRESS 0x7E01
#define HDMI_I2CM_DATAO 0x7E02
#define HDMI_I2CM_DATAI 0x7E03
#define HDMI_I2CM_OPERATION 0x7E04
#define HDMI_I2CM_INT 0x7E05
#define HDMI_I2CM_CTLINT 0x7E06
#define HDMI_I2CM_DIV 0x7E07
#define HDMI_I2CM_SEGADDR 0x7E08
#define HDMI_I2CM_SOFTRSTZ 0x7E09
#define HDMI_I2CM_SEGPTR 0x7E0A
#define HDMI_I2CM_SS_SCL_HCNT_1_ADDR 0x7E0B
#define HDMI_I2CM_SS_SCL_HCNT_0_ADDR 0x7E0C
#define HDMI_I2CM_SS_SCL_LCNT_1_ADDR 0x7E0D
#define HDMI_I2CM_SS_SCL_LCNT_0_ADDR 0x7E0E
#define HDMI_I2CM_FS_SCL_HCNT_1_ADDR 0x7E0F
#define HDMI_I2CM_FS_SCL_HCNT_0_ADDR 0x7E10
#define HDMI_I2CM_FS_SCL_LCNT_1_ADDR 0x7E11
#define HDMI_I2CM_FS_SCL_LCNT_0_ADDR 0x7E12
enum {
/* PRODUCT_ID0 field values */
HDMI_PRODUCT_ID0_HDMI_TX = 0xa0,
/* PRODUCT_ID1 field values */
HDMI_PRODUCT_ID1_HDCP = 0xc0,
HDMI_PRODUCT_ID1_HDMI_RX = 0x02,
HDMI_PRODUCT_ID1_HDMI_TX = 0x01,
/* CONFIG0_ID field values */
HDMI_CONFIG0_I2S = 0x10,
HDMI_CONFIG0_CEC = 0x02,
/* CONFIG1_ID field values */
HDMI_CONFIG1_AHB = 0x01,
/* CONFIG3_ID field values */
HDMI_CONFIG3_AHBAUDDMA = 0x02,
HDMI_CONFIG3_GPAUD = 0x01,
/* IH_FC_INT2 field values */
HDMI_IH_FC_INT2_OVERFLOW_MASK = 0x03,
HDMI_IH_FC_INT2_LOW_PRIORITY_OVERFLOW = 0x02,
HDMI_IH_FC_INT2_HIGH_PRIORITY_OVERFLOW = 0x01,
/* IH_FC_STAT2 field values */
HDMI_IH_FC_STAT2_OVERFLOW_MASK = 0x03,
HDMI_IH_FC_STAT2_LOW_PRIORITY_OVERFLOW = 0x02,
HDMI_IH_FC_STAT2_HIGH_PRIORITY_OVERFLOW = 0x01,
/* IH_PHY_STAT0 field values */
HDMI_IH_PHY_STAT0_RX_SENSE3 = 0x20,
HDMI_IH_PHY_STAT0_RX_SENSE2 = 0x10,
HDMI_IH_PHY_STAT0_RX_SENSE1 = 0x8,
HDMI_IH_PHY_STAT0_RX_SENSE0 = 0x4,
HDMI_IH_PHY_STAT0_TX_PHY_LOCK = 0x2,
HDMI_IH_PHY_STAT0_HPD = 0x1,
/* IH_I2CM_STAT0 and IH_MUTE_I2CM_STAT0 field values */
HDMI_IH_I2CM_STAT0_DONE = 0x2,
HDMI_IH_I2CM_STAT0_ERROR = 0x1,
/* IH_MUTE_I2CMPHY_STAT0 field values */
HDMI_IH_MUTE_I2CMPHY_STAT0_I2CMPHYDONE = 0x2,
HDMI_IH_MUTE_I2CMPHY_STAT0_I2CMPHYERROR = 0x1,
/* IH_AHBDMAAUD_STAT0 field values */
HDMI_IH_AHBDMAAUD_STAT0_ERROR = 0x20,
HDMI_IH_AHBDMAAUD_STAT0_LOST = 0x10,
HDMI_IH_AHBDMAAUD_STAT0_RETRY = 0x08,
HDMI_IH_AHBDMAAUD_STAT0_DONE = 0x04,
HDMI_IH_AHBDMAAUD_STAT0_BUFFFULL = 0x02,
HDMI_IH_AHBDMAAUD_STAT0_BUFFEMPTY = 0x01,
/* IH_MUTE_FC_STAT2 field values */
HDMI_IH_MUTE_FC_STAT2_OVERFLOW_MASK = 0x03,
HDMI_IH_MUTE_FC_STAT2_LOW_PRIORITY_OVERFLOW = 0x02,
HDMI_IH_MUTE_FC_STAT2_HIGH_PRIORITY_OVERFLOW = 0x01,
/* IH_MUTE_AHBDMAAUD_STAT0 field values */
HDMI_IH_MUTE_AHBDMAAUD_STAT0_ERROR = 0x20,
HDMI_IH_MUTE_AHBDMAAUD_STAT0_LOST = 0x10,
HDMI_IH_MUTE_AHBDMAAUD_STAT0_RETRY = 0x08,
HDMI_IH_MUTE_AHBDMAAUD_STAT0_DONE = 0x04,
HDMI_IH_MUTE_AHBDMAAUD_STAT0_BUFFFULL = 0x02,
HDMI_IH_MUTE_AHBDMAAUD_STAT0_BUFFEMPTY = 0x01,
/* IH_MUTE field values */
HDMI_IH_MUTE_MUTE_WAKEUP_INTERRUPT = 0x2,
HDMI_IH_MUTE_MUTE_ALL_INTERRUPT = 0x1,
/* TX_INVID0 field values */
HDMI_TX_INVID0_INTERNAL_DE_GENERATOR_MASK = 0x80,
HDMI_TX_INVID0_INTERNAL_DE_GENERATOR_ENABLE = 0x80,
HDMI_TX_INVID0_INTERNAL_DE_GENERATOR_DISABLE = 0x00,
HDMI_TX_INVID0_VIDEO_MAPPING_MASK = 0x1F,
HDMI_TX_INVID0_VIDEO_MAPPING_OFFSET = 0,
/* TX_INSTUFFING field values */
HDMI_TX_INSTUFFING_BDBDATA_STUFFING_MASK = 0x4,
HDMI_TX_INSTUFFING_BDBDATA_STUFFING_ENABLE = 0x4,
HDMI_TX_INSTUFFING_BDBDATA_STUFFING_DISABLE = 0x0,
HDMI_TX_INSTUFFING_RCRDATA_STUFFING_MASK = 0x2,
HDMI_TX_INSTUFFING_RCRDATA_STUFFING_ENABLE = 0x2,
HDMI_TX_INSTUFFING_RCRDATA_STUFFING_DISABLE = 0x0,
HDMI_TX_INSTUFFING_GYDATA_STUFFING_MASK = 0x1,
HDMI_TX_INSTUFFING_GYDATA_STUFFING_ENABLE = 0x1,
HDMI_TX_INSTUFFING_GYDATA_STUFFING_DISABLE = 0x0,
/* VP_PR_CD field values */
HDMI_VP_PR_CD_COLOR_DEPTH_MASK = 0xF0,
HDMI_VP_PR_CD_COLOR_DEPTH_OFFSET = 4,
HDMI_VP_PR_CD_DESIRED_PR_FACTOR_MASK = 0x0F,
HDMI_VP_PR_CD_DESIRED_PR_FACTOR_OFFSET = 0,
/* VP_STUFF field values */
HDMI_VP_STUFF_IDEFAULT_PHASE_MASK = 0x20,
HDMI_VP_STUFF_IDEFAULT_PHASE_OFFSET = 5,
HDMI_VP_STUFF_IFIX_PP_TO_LAST_MASK = 0x10,
HDMI_VP_STUFF_IFIX_PP_TO_LAST_OFFSET = 4,
HDMI_VP_STUFF_ICX_GOTO_P0_ST_MASK = 0x8,
HDMI_VP_STUFF_ICX_GOTO_P0_ST_OFFSET = 3,
HDMI_VP_STUFF_YCC422_STUFFING_MASK = 0x4,
HDMI_VP_STUFF_YCC422_STUFFING_STUFFING_MODE = 0x4,
HDMI_VP_STUFF_YCC422_STUFFING_DIRECT_MODE = 0x0,
HDMI_VP_STUFF_PP_STUFFING_MASK = 0x2,
HDMI_VP_STUFF_PP_STUFFING_STUFFING_MODE = 0x2,
HDMI_VP_STUFF_PP_STUFFING_DIRECT_MODE = 0x0,
HDMI_VP_STUFF_PR_STUFFING_MASK = 0x1,
HDMI_VP_STUFF_PR_STUFFING_STUFFING_MODE = 0x1,
HDMI_VP_STUFF_PR_STUFFING_DIRECT_MODE = 0x0,
/* VP_CONF field values */
HDMI_VP_CONF_BYPASS_EN_MASK = 0x40,
HDMI_VP_CONF_BYPASS_EN_ENABLE = 0x40,
HDMI_VP_CONF_BYPASS_EN_DISABLE = 0x00,
HDMI_VP_CONF_PP_EN_ENMASK = 0x20,
HDMI_VP_CONF_PP_EN_ENABLE = 0x20,
HDMI_VP_CONF_PP_EN_DISABLE = 0x00,
HDMI_VP_CONF_PR_EN_MASK = 0x10,
HDMI_VP_CONF_PR_EN_ENABLE = 0x10,
HDMI_VP_CONF_PR_EN_DISABLE = 0x00,
HDMI_VP_CONF_YCC422_EN_MASK = 0x8,
HDMI_VP_CONF_YCC422_EN_ENABLE = 0x8,
HDMI_VP_CONF_YCC422_EN_DISABLE = 0x0,
HDMI_VP_CONF_BYPASS_SELECT_MASK = 0x4,
HDMI_VP_CONF_BYPASS_SELECT_VID_PACKETIZER = 0x4,
HDMI_VP_CONF_BYPASS_SELECT_PIX_REPEATER = 0x0,
HDMI_VP_CONF_OUTPUT_SELECTOR_MASK = 0x3,
HDMI_VP_CONF_OUTPUT_SELECTOR_BYPASS = 0x3,
HDMI_VP_CONF_OUTPUT_SELECTOR_YCC422 = 0x1,
HDMI_VP_CONF_OUTPUT_SELECTOR_PP = 0x0,
/* VP_REMAP field values */
HDMI_VP_REMAP_MASK = 0x3,
HDMI_VP_REMAP_YCC422_24bit = 0x2,
HDMI_VP_REMAP_YCC422_20bit = 0x1,
HDMI_VP_REMAP_YCC422_16bit = 0x0,
/* FC_INVIDCONF field values */
HDMI_FC_INVIDCONF_HDCP_KEEPOUT_MASK = 0x80,
HDMI_FC_INVIDCONF_HDCP_KEEPOUT_ACTIVE = 0x80,
HDMI_FC_INVIDCONF_HDCP_KEEPOUT_INACTIVE = 0x00,
HDMI_FC_INVIDCONF_VSYNC_IN_POLARITY_MASK = 0x40,
HDMI_FC_INVIDCONF_VSYNC_IN_POLARITY_ACTIVE_HIGH = 0x40,
HDMI_FC_INVIDCONF_VSYNC_IN_POLARITY_ACTIVE_LOW = 0x00,
HDMI_FC_INVIDCONF_HSYNC_IN_POLARITY_MASK = 0x20,
HDMI_FC_INVIDCONF_HSYNC_IN_POLARITY_ACTIVE_HIGH = 0x20,
HDMI_FC_INVIDCONF_HSYNC_IN_POLARITY_ACTIVE_LOW = 0x00,
HDMI_FC_INVIDCONF_DE_IN_POLARITY_MASK = 0x10,
HDMI_FC_INVIDCONF_DE_IN_POLARITY_ACTIVE_HIGH = 0x10,
HDMI_FC_INVIDCONF_DE_IN_POLARITY_ACTIVE_LOW = 0x00,
HDMI_FC_INVIDCONF_DVI_MODEZ_MASK = 0x8,
HDMI_FC_INVIDCONF_DVI_MODEZ_HDMI_MODE = 0x8,
HDMI_FC_INVIDCONF_DVI_MODEZ_DVI_MODE = 0x0,
HDMI_FC_INVIDCONF_R_V_BLANK_IN_OSC_MASK = 0x2,
HDMI_FC_INVIDCONF_R_V_BLANK_IN_OSC_ACTIVE_HIGH = 0x2,
HDMI_FC_INVIDCONF_R_V_BLANK_IN_OSC_ACTIVE_LOW = 0x0,
HDMI_FC_INVIDCONF_IN_I_P_MASK = 0x1,
HDMI_FC_INVIDCONF_IN_I_P_INTERLACED = 0x1,
HDMI_FC_INVIDCONF_IN_I_P_PROGRESSIVE = 0x0,
/* FC_AUDICONF0 field values */
HDMI_FC_AUDICONF0_CC_OFFSET = 4,
HDMI_FC_AUDICONF0_CC_MASK = 0x70,
HDMI_FC_AUDICONF0_CT_OFFSET = 0,
HDMI_FC_AUDICONF0_CT_MASK = 0xF,
/* FC_AUDICONF1 field values */
HDMI_FC_AUDICONF1_SS_OFFSET = 3,
HDMI_FC_AUDICONF1_SS_MASK = 0x18,
HDMI_FC_AUDICONF1_SF_OFFSET = 0,
HDMI_FC_AUDICONF1_SF_MASK = 0x7,
/* FC_AUDICONF3 field values */
HDMI_FC_AUDICONF3_LFEPBL_OFFSET = 5,
HDMI_FC_AUDICONF3_LFEPBL_MASK = 0x60,
HDMI_FC_AUDICONF3_DM_INH_OFFSET = 4,
HDMI_FC_AUDICONF3_DM_INH_MASK = 0x10,
HDMI_FC_AUDICONF3_LSV_OFFSET = 0,
HDMI_FC_AUDICONF3_LSV_MASK = 0xF,
/* FC_AUDSCHNLS0 field values */
HDMI_FC_AUDSCHNLS0_CGMSA_OFFSET = 4,
HDMI_FC_AUDSCHNLS0_CGMSA_MASK = 0x30,
HDMI_FC_AUDSCHNLS0_COPYRIGHT_OFFSET = 0,
HDMI_FC_AUDSCHNLS0_COPYRIGHT_MASK = 0x01,
/* FC_AUDSCHNLS3-6 field values */
HDMI_FC_AUDSCHNLS3_OIEC_CH0_OFFSET = 0,
HDMI_FC_AUDSCHNLS3_OIEC_CH0_MASK = 0x0f,
HDMI_FC_AUDSCHNLS3_OIEC_CH1_OFFSET = 4,
HDMI_FC_AUDSCHNLS3_OIEC_CH1_MASK = 0xf0,
HDMI_FC_AUDSCHNLS4_OIEC_CH2_OFFSET = 0,
HDMI_FC_AUDSCHNLS4_OIEC_CH2_MASK = 0x0f,
HDMI_FC_AUDSCHNLS4_OIEC_CH3_OFFSET = 4,
HDMI_FC_AUDSCHNLS4_OIEC_CH3_MASK = 0xf0,
HDMI_FC_AUDSCHNLS5_OIEC_CH0_OFFSET = 0,
HDMI_FC_AUDSCHNLS5_OIEC_CH0_MASK = 0x0f,
HDMI_FC_AUDSCHNLS5_OIEC_CH1_OFFSET = 4,
HDMI_FC_AUDSCHNLS5_OIEC_CH1_MASK = 0xf0,
HDMI_FC_AUDSCHNLS6_OIEC_CH2_OFFSET = 0,
HDMI_FC_AUDSCHNLS6_OIEC_CH2_MASK = 0x0f,
HDMI_FC_AUDSCHNLS6_OIEC_CH3_OFFSET = 4,
HDMI_FC_AUDSCHNLS6_OIEC_CH3_MASK = 0xf0,
/* HDMI_FC_AUDSCHNLS7 field values */
HDMI_FC_AUDSCHNLS7_ACCURACY_OFFSET = 4,
HDMI_FC_AUDSCHNLS7_ACCURACY_MASK = 0x30,
/* HDMI_FC_AUDSCHNLS8 field values */
HDMI_FC_AUDSCHNLS8_ORIGSAMPFREQ_MASK = 0xf0,
HDMI_FC_AUDSCHNLS8_ORIGSAMPFREQ_OFFSET = 4,
HDMI_FC_AUDSCHNLS8_WORDLEGNTH_MASK = 0x0f,
HDMI_FC_AUDSCHNLS8_WORDLEGNTH_OFFSET = 0,
/* FC_AUDSCONF field values */
HDMI_FC_AUDSCONF_AUD_PACKET_SAMPFIT_MASK = 0xF0,
HDMI_FC_AUDSCONF_AUD_PACKET_SAMPFIT_OFFSET = 4,
HDMI_FC_AUDSCONF_AUD_PACKET_LAYOUT_MASK = 0x1,
HDMI_FC_AUDSCONF_AUD_PACKET_LAYOUT_OFFSET = 0,
HDMI_FC_AUDSCONF_AUD_PACKET_LAYOUT_LAYOUT1 = 0x1,
HDMI_FC_AUDSCONF_AUD_PACKET_LAYOUT_LAYOUT0 = 0x0,
/* FC_STAT2 field values */
HDMI_FC_STAT2_OVERFLOW_MASK = 0x03,
HDMI_FC_STAT2_LOW_PRIORITY_OVERFLOW = 0x02,
HDMI_FC_STAT2_HIGH_PRIORITY_OVERFLOW = 0x01,
/* FC_INT2 field values */
HDMI_FC_INT2_OVERFLOW_MASK = 0x03,
HDMI_FC_INT2_LOW_PRIORITY_OVERFLOW = 0x02,
HDMI_FC_INT2_HIGH_PRIORITY_OVERFLOW = 0x01,
/* FC_MASK2 field values */
HDMI_FC_MASK2_OVERFLOW_MASK = 0x03,
HDMI_FC_MASK2_LOW_PRIORITY_OVERFLOW = 0x02,
HDMI_FC_MASK2_HIGH_PRIORITY_OVERFLOW = 0x01,
/* FC_PRCONF field values */
HDMI_FC_PRCONF_INCOMING_PR_FACTOR_MASK = 0xF0,
HDMI_FC_PRCONF_INCOMING_PR_FACTOR_OFFSET = 4,
HDMI_FC_PRCONF_OUTPUT_PR_FACTOR_MASK = 0x0F,
HDMI_FC_PRCONF_OUTPUT_PR_FACTOR_OFFSET = 0,
/* FC_AVICONF0-FC_AVICONF3 field values */
HDMI_FC_AVICONF0_PIX_FMT_MASK = 0x03,
HDMI_FC_AVICONF0_PIX_FMT_RGB = 0x00,
HDMI_FC_AVICONF0_PIX_FMT_YCBCR422 = 0x01,
HDMI_FC_AVICONF0_PIX_FMT_YCBCR444 = 0x02,
HDMI_FC_AVICONF0_ACTIVE_FMT_MASK = 0x40,
HDMI_FC_AVICONF0_ACTIVE_FMT_INFO_PRESENT = 0x40,
HDMI_FC_AVICONF0_ACTIVE_FMT_NO_INFO = 0x00,
HDMI_FC_AVICONF0_BAR_DATA_MASK = 0x0C,
HDMI_FC_AVICONF0_BAR_DATA_NO_DATA = 0x00,
HDMI_FC_AVICONF0_BAR_DATA_VERT_BAR = 0x04,
HDMI_FC_AVICONF0_BAR_DATA_HORIZ_BAR = 0x08,
HDMI_FC_AVICONF0_BAR_DATA_VERT_HORIZ_BAR = 0x0C,
HDMI_FC_AVICONF0_SCAN_INFO_MASK = 0x30,
HDMI_FC_AVICONF0_SCAN_INFO_OVERSCAN = 0x10,
HDMI_FC_AVICONF0_SCAN_INFO_UNDERSCAN = 0x20,
HDMI_FC_AVICONF0_SCAN_INFO_NODATA = 0x00,
HDMI_FC_AVICONF1_ACTIVE_ASPECT_RATIO_MASK = 0x0F,
HDMI_FC_AVICONF1_ACTIVE_ASPECT_RATIO_USE_CODED = 0x08,
HDMI_FC_AVICONF1_ACTIVE_ASPECT_RATIO_4_3 = 0x09,
HDMI_FC_AVICONF1_ACTIVE_ASPECT_RATIO_16_9 = 0x0A,
HDMI_FC_AVICONF1_ACTIVE_ASPECT_RATIO_14_9 = 0x0B,
HDMI_FC_AVICONF1_CODED_ASPECT_RATIO_MASK = 0x30,
HDMI_FC_AVICONF1_CODED_ASPECT_RATIO_NO_DATA = 0x00,
HDMI_FC_AVICONF1_CODED_ASPECT_RATIO_4_3 = 0x10,
HDMI_FC_AVICONF1_CODED_ASPECT_RATIO_16_9 = 0x20,
HDMI_FC_AVICONF1_COLORIMETRY_MASK = 0xC0,
HDMI_FC_AVICONF1_COLORIMETRY_NO_DATA = 0x00,
HDMI_FC_AVICONF1_COLORIMETRY_SMPTE = 0x40,
HDMI_FC_AVICONF1_COLORIMETRY_ITUR = 0x80,
HDMI_FC_AVICONF1_COLORIMETRY_EXTENDED_INFO = 0xC0,
HDMI_FC_AVICONF2_SCALING_MASK = 0x03,
HDMI_FC_AVICONF2_SCALING_NONE = 0x00,
HDMI_FC_AVICONF2_SCALING_HORIZ = 0x01,
HDMI_FC_AVICONF2_SCALING_VERT = 0x02,
HDMI_FC_AVICONF2_SCALING_HORIZ_VERT = 0x03,
HDMI_FC_AVICONF2_RGB_QUANT_MASK = 0x0C,
HDMI_FC_AVICONF2_RGB_QUANT_DEFAULT = 0x00,
HDMI_FC_AVICONF2_RGB_QUANT_LIMITED_RANGE = 0x04,
HDMI_FC_AVICONF2_RGB_QUANT_FULL_RANGE = 0x08,
HDMI_FC_AVICONF2_EXT_COLORIMETRY_MASK = 0x70,
HDMI_FC_AVICONF2_EXT_COLORIMETRY_XVYCC601 = 0x00,
HDMI_FC_AVICONF2_EXT_COLORIMETRY_XVYCC709 = 0x10,
HDMI_FC_AVICONF2_EXT_COLORIMETRY_SYCC601 = 0x20,
HDMI_FC_AVICONF2_EXT_COLORIMETRY_ADOBE_YCC601 = 0x30,
HDMI_FC_AVICONF2_EXT_COLORIMETRY_ADOBE_RGB = 0x40,
HDMI_FC_AVICONF2_IT_CONTENT_MASK = 0x80,
HDMI_FC_AVICONF2_IT_CONTENT_NO_DATA = 0x00,
HDMI_FC_AVICONF2_IT_CONTENT_VALID = 0x80,
HDMI_FC_AVICONF3_IT_CONTENT_TYPE_MASK = 0x03,
HDMI_FC_AVICONF3_IT_CONTENT_TYPE_GRAPHICS = 0x00,
HDMI_FC_AVICONF3_IT_CONTENT_TYPE_PHOTO = 0x01,
HDMI_FC_AVICONF3_IT_CONTENT_TYPE_CINEMA = 0x02,
HDMI_FC_AVICONF3_IT_CONTENT_TYPE_GAME = 0x03,
HDMI_FC_AVICONF3_QUANT_RANGE_MASK = 0x0C,
HDMI_FC_AVICONF3_QUANT_RANGE_LIMITED = 0x00,
HDMI_FC_AVICONF3_QUANT_RANGE_FULL = 0x04,
/* FC_DBGFORCE field values */
HDMI_FC_DBGFORCE_FORCEAUDIO = 0x10,
HDMI_FC_DBGFORCE_FORCEVIDEO = 0x1,
/* FC_DATAUTO0 field values */
HDMI_FC_DATAUTO0_VSD_MASK = 0x08,
HDMI_FC_DATAUTO0_VSD_OFFSET = 3,
/* PHY_CONF0 field values */
HDMI_PHY_CONF0_PDZ_MASK = 0x80,
HDMI_PHY_CONF0_PDZ_OFFSET = 7,
HDMI_PHY_CONF0_ENTMDS_MASK = 0x40,
HDMI_PHY_CONF0_ENTMDS_OFFSET = 6,
HDMI_PHY_CONF0_SVSRET_MASK = 0x20,
HDMI_PHY_CONF0_SVSRET_OFFSET = 5,
HDMI_PHY_CONF0_GEN2_PDDQ_MASK = 0x10,
HDMI_PHY_CONF0_GEN2_PDDQ_OFFSET = 4,
HDMI_PHY_CONF0_GEN2_TXPWRON_MASK = 0x8,
HDMI_PHY_CONF0_GEN2_TXPWRON_OFFSET = 3,
HDMI_PHY_CONF0_GEN2_ENHPDRXSENSE_MASK = 0x4,
HDMI_PHY_CONF0_GEN2_ENHPDRXSENSE_OFFSET = 2,
HDMI_PHY_CONF0_SELDATAENPOL_MASK = 0x2,
HDMI_PHY_CONF0_SELDATAENPOL_OFFSET = 1,
HDMI_PHY_CONF0_SELDIPIF_MASK = 0x1,
HDMI_PHY_CONF0_SELDIPIF_OFFSET = 0,
/* PHY_TST0 field values */
HDMI_PHY_TST0_TSTCLR_MASK = 0x20,
HDMI_PHY_TST0_TSTCLR_OFFSET = 5,
HDMI_PHY_TST0_TSTEN_MASK = 0x10,
HDMI_PHY_TST0_TSTEN_OFFSET = 4,
HDMI_PHY_TST0_TSTCLK_MASK = 0x1,
HDMI_PHY_TST0_TSTCLK_OFFSET = 0,
/* PHY_STAT0 field values */
HDMI_PHY_RX_SENSE3 = 0x80,
HDMI_PHY_RX_SENSE2 = 0x40,
HDMI_PHY_RX_SENSE1 = 0x20,
HDMI_PHY_RX_SENSE0 = 0x10,
HDMI_PHY_HPD = 0x02,
HDMI_PHY_TX_PHY_LOCK = 0x01,
/* PHY_I2CM_SLAVE_ADDR field values */
HDMI_PHY_I2CM_SLAVE_ADDR_PHY_GEN2 = 0x69,
HDMI_PHY_I2CM_SLAVE_ADDR_HEAC_PHY = 0x49,
/* PHY_I2CM_OPERATION_ADDR field values */
HDMI_PHY_I2CM_OPERATION_ADDR_WRITE = 0x10,
HDMI_PHY_I2CM_OPERATION_ADDR_READ = 0x1,
/* HDMI_PHY_I2CM_INT_ADDR */
HDMI_PHY_I2CM_INT_ADDR_DONE_POL = 0x08,
HDMI_PHY_I2CM_INT_ADDR_DONE_MASK = 0x04,
/* HDMI_PHY_I2CM_CTLINT_ADDR */
HDMI_PHY_I2CM_CTLINT_ADDR_NAC_POL = 0x80,
HDMI_PHY_I2CM_CTLINT_ADDR_NAC_MASK = 0x40,
HDMI_PHY_I2CM_CTLINT_ADDR_ARBITRATION_POL = 0x08,
HDMI_PHY_I2CM_CTLINT_ADDR_ARBITRATION_MASK = 0x04,
/* AUD_CONF0 field values */
HDMI_AUD_CONF0_SW_RESET = 0x80,
HDMI_AUD_CONF0_I2S_SELECT = 0x20,
HDMI_AUD_CONF0_I2S_EN3 = 0x08,
HDMI_AUD_CONF0_I2S_EN2 = 0x04,
HDMI_AUD_CONF0_I2S_EN1 = 0x02,
HDMI_AUD_CONF0_I2S_EN0 = 0x01,
/* AUD_CONF1 field values */
HDMI_AUD_CONF1_MODE_I2S = 0x00,
HDMI_AUD_CONF1_MODE_RIGHT_J = 0x20,
HDMI_AUD_CONF1_MODE_LEFT_J = 0x40,
HDMI_AUD_CONF1_MODE_BURST_1 = 0x60,
HDMI_AUD_CONF1_MODE_BURST_2 = 0x80,
HDMI_AUD_CONF1_WIDTH_16 = 0x10,
HDMI_AUD_CONF1_WIDTH_24 = 0x18,
/* AUD_CTS3 field values */
HDMI_AUD_CTS3_N_SHIFT_OFFSET = 5,
HDMI_AUD_CTS3_N_SHIFT_MASK = 0xe0,
HDMI_AUD_CTS3_N_SHIFT_1 = 0,
HDMI_AUD_CTS3_N_SHIFT_16 = 0x20,
HDMI_AUD_CTS3_N_SHIFT_32 = 0x40,
HDMI_AUD_CTS3_N_SHIFT_64 = 0x60,
HDMI_AUD_CTS3_N_SHIFT_128 = 0x80,
HDMI_AUD_CTS3_N_SHIFT_256 = 0xa0,
/* note that the CTS3 MANUAL bit has been removed
from our part. Can't set it, will read as 0. */
HDMI_AUD_CTS3_CTS_MANUAL = 0x10,
HDMI_AUD_CTS3_AUDCTS19_16_MASK = 0x0f,
/* HDMI_AUD_INPUTCLKFS field values */
HDMI_AUD_INPUTCLKFS_128FS = 0,
HDMI_AUD_INPUTCLKFS_256FS = 1,
HDMI_AUD_INPUTCLKFS_512FS = 2,
HDMI_AUD_INPUTCLKFS_64FS = 4,
/* AHB_DMA_CONF0 field values */
HDMI_AHB_DMA_CONF0_SW_FIFO_RST_OFFSET = 7,
HDMI_AHB_DMA_CONF0_SW_FIFO_RST_MASK = 0x80,
HDMI_AHB_DMA_CONF0_HBR = 0x10,
HDMI_AHB_DMA_CONF0_EN_HLOCK_OFFSET = 3,
HDMI_AHB_DMA_CONF0_EN_HLOCK_MASK = 0x08,
HDMI_AHB_DMA_CONF0_INCR_TYPE_OFFSET = 1,
HDMI_AHB_DMA_CONF0_INCR_TYPE_MASK = 0x06,
HDMI_AHB_DMA_CONF0_INCR4 = 0x0,
HDMI_AHB_DMA_CONF0_INCR8 = 0x2,
HDMI_AHB_DMA_CONF0_INCR16 = 0x4,
HDMI_AHB_DMA_CONF0_BURST_MODE = 0x1,
/* HDMI_AHB_DMA_START field values */
HDMI_AHB_DMA_START_START_OFFSET = 0,
HDMI_AHB_DMA_START_START_MASK = 0x01,
/* HDMI_AHB_DMA_STOP field values */
HDMI_AHB_DMA_STOP_STOP_OFFSET = 0,
HDMI_AHB_DMA_STOP_STOP_MASK = 0x01,
/* AHB_DMA_STAT, AHB_DMA_INT, AHB_DMA_MASK, AHB_DMA_POL field values */
HDMI_AHB_DMA_DONE = 0x80,
HDMI_AHB_DMA_RETRY_SPLIT = 0x40,
HDMI_AHB_DMA_LOSTOWNERSHIP = 0x20,
HDMI_AHB_DMA_ERROR = 0x10,
HDMI_AHB_DMA_FIFO_THREMPTY = 0x04,
HDMI_AHB_DMA_FIFO_FULL = 0x02,
HDMI_AHB_DMA_FIFO_EMPTY = 0x01,
/* AHB_DMA_BUFFSTAT, AHB_DMA_BUFFINT,AHB_DMA_BUFFMASK,AHB_DMA_BUFFPOL values */
HDMI_AHB_DMA_BUFFSTAT_FULL = 0x02,
HDMI_AHB_DMA_BUFFSTAT_EMPTY = 0x01,
/* MC_CLKDIS field values */
HDMI_MC_CLKDIS_HDCPCLK_DISABLE = 0x40,
HDMI_MC_CLKDIS_CECCLK_DISABLE = 0x20,
HDMI_MC_CLKDIS_CSCCLK_DISABLE = 0x10,
HDMI_MC_CLKDIS_AUDCLK_DISABLE = 0x8,
HDMI_MC_CLKDIS_PREPCLK_DISABLE = 0x4,
HDMI_MC_CLKDIS_TMDSCLK_DISABLE = 0x2,
HDMI_MC_CLKDIS_PIXELCLK_DISABLE = 0x1,
/* MC_SWRSTZ field values */
HDMI_MC_SWRSTZ_I2SSWRST_REQ = 0x08,
HDMI_MC_SWRSTZ_TMDSSWRST_REQ = 0x02,
/* MC_FLOWCTRL field values */
HDMI_MC_FLOWCTRL_FEED_THROUGH_OFF_MASK = 0x1,
HDMI_MC_FLOWCTRL_FEED_THROUGH_OFF_CSC_IN_PATH = 0x1,
HDMI_MC_FLOWCTRL_FEED_THROUGH_OFF_CSC_BYPASS = 0x0,
/* MC_PHYRSTZ field values */
HDMI_MC_PHYRSTZ_PHYRSTZ = 0x01,
/* MC_HEACPHY_RST field values */
HDMI_MC_HEACPHY_RST_ASSERT = 0x1,
HDMI_MC_HEACPHY_RST_DEASSERT = 0x0,
/* CSC_CFG field values */
HDMI_CSC_CFG_INTMODE_MASK = 0x30,
HDMI_CSC_CFG_INTMODE_OFFSET = 4,
HDMI_CSC_CFG_INTMODE_DISABLE = 0x00,
HDMI_CSC_CFG_INTMODE_CHROMA_INT_FORMULA1 = 0x10,
HDMI_CSC_CFG_INTMODE_CHROMA_INT_FORMULA2 = 0x20,
HDMI_CSC_CFG_DECMODE_MASK = 0x3,
HDMI_CSC_CFG_DECMODE_OFFSET = 0,
HDMI_CSC_CFG_DECMODE_DISABLE = 0x0,
HDMI_CSC_CFG_DECMODE_CHROMA_INT_FORMULA1 = 0x1,
HDMI_CSC_CFG_DECMODE_CHROMA_INT_FORMULA2 = 0x2,
HDMI_CSC_CFG_DECMODE_CHROMA_INT_FORMULA3 = 0x3,
/* CSC_SCALE field values */
HDMI_CSC_SCALE_CSC_COLORDE_PTH_MASK = 0xF0,
HDMI_CSC_SCALE_CSC_COLORDE_PTH_24BPP = 0x00,
HDMI_CSC_SCALE_CSC_COLORDE_PTH_30BPP = 0x50,
HDMI_CSC_SCALE_CSC_COLORDE_PTH_36BPP = 0x60,
HDMI_CSC_SCALE_CSC_COLORDE_PTH_48BPP = 0x70,
HDMI_CSC_SCALE_CSCSCALE_MASK = 0x03,
/* A_HDCPCFG0 field values */
HDMI_A_HDCPCFG0_ELVENA_MASK = 0x80,
HDMI_A_HDCPCFG0_ELVENA_ENABLE = 0x80,
HDMI_A_HDCPCFG0_ELVENA_DISABLE = 0x00,
HDMI_A_HDCPCFG0_I2CFASTMODE_MASK = 0x40,
HDMI_A_HDCPCFG0_I2CFASTMODE_ENABLE = 0x40,
HDMI_A_HDCPCFG0_I2CFASTMODE_DISABLE = 0x00,
HDMI_A_HDCPCFG0_BYPENCRYPTION_MASK = 0x20,
HDMI_A_HDCPCFG0_BYPENCRYPTION_ENABLE = 0x20,
HDMI_A_HDCPCFG0_BYPENCRYPTION_DISABLE = 0x00,
HDMI_A_HDCPCFG0_SYNCRICHECK_MASK = 0x10,
HDMI_A_HDCPCFG0_SYNCRICHECK_ENABLE = 0x10,
HDMI_A_HDCPCFG0_SYNCRICHECK_DISABLE = 0x00,
HDMI_A_HDCPCFG0_AVMUTE_MASK = 0x8,
HDMI_A_HDCPCFG0_AVMUTE_ENABLE = 0x8,
HDMI_A_HDCPCFG0_AVMUTE_DISABLE = 0x0,
HDMI_A_HDCPCFG0_RXDETECT_MASK = 0x4,
HDMI_A_HDCPCFG0_RXDETECT_ENABLE = 0x4,
HDMI_A_HDCPCFG0_RXDETECT_DISABLE = 0x0,
HDMI_A_HDCPCFG0_EN11FEATURE_MASK = 0x2,
HDMI_A_HDCPCFG0_EN11FEATURE_ENABLE = 0x2,
HDMI_A_HDCPCFG0_EN11FEATURE_DISABLE = 0x0,
HDMI_A_HDCPCFG0_HDMIDVI_MASK = 0x1,
HDMI_A_HDCPCFG0_HDMIDVI_HDMI = 0x1,
HDMI_A_HDCPCFG0_HDMIDVI_DVI = 0x0,
/* A_HDCPCFG1 field values */
HDMI_A_HDCPCFG1_DISSHA1CHECK_MASK = 0x8,
HDMI_A_HDCPCFG1_DISSHA1CHECK_DISABLE = 0x8,
HDMI_A_HDCPCFG1_DISSHA1CHECK_ENABLE = 0x0,
HDMI_A_HDCPCFG1_PH2UPSHFTENC_MASK = 0x4,
HDMI_A_HDCPCFG1_PH2UPSHFTENC_ENABLE = 0x4,
HDMI_A_HDCPCFG1_PH2UPSHFTENC_DISABLE = 0x0,
HDMI_A_HDCPCFG1_ENCRYPTIONDISABLE_MASK = 0x2,
HDMI_A_HDCPCFG1_ENCRYPTIONDISABLE_DISABLE = 0x2,
HDMI_A_HDCPCFG1_ENCRYPTIONDISABLE_ENABLE = 0x0,
HDMI_A_HDCPCFG1_SWRESET_MASK = 0x1,
HDMI_A_HDCPCFG1_SWRESET_ASSERT = 0x0,
/* A_VIDPOLCFG field values */
HDMI_A_VIDPOLCFG_UNENCRYPTCONF_MASK = 0x60,
HDMI_A_VIDPOLCFG_UNENCRYPTCONF_OFFSET = 5,
HDMI_A_VIDPOLCFG_DATAENPOL_MASK = 0x10,
HDMI_A_VIDPOLCFG_DATAENPOL_ACTIVE_HIGH = 0x10,
HDMI_A_VIDPOLCFG_DATAENPOL_ACTIVE_LOW = 0x0,
HDMI_A_VIDPOLCFG_VSYNCPOL_MASK = 0x8,
HDMI_A_VIDPOLCFG_VSYNCPOL_ACTIVE_HIGH = 0x8,
HDMI_A_VIDPOLCFG_VSYNCPOL_ACTIVE_LOW = 0x0,
HDMI_A_VIDPOLCFG_HSYNCPOL_MASK = 0x2,
HDMI_A_VIDPOLCFG_HSYNCPOL_ACTIVE_HIGH = 0x2,
HDMI_A_VIDPOLCFG_HSYNCPOL_ACTIVE_LOW = 0x0,
/* I2CM_OPERATION field values */
HDMI_I2CM_OPERATION_WRITE = 0x10,
HDMI_I2CM_OPERATION_READ_EXT = 0x2,
HDMI_I2CM_OPERATION_READ = 0x1,
/* I2CM_INT field values */
HDMI_I2CM_INT_DONE_POL = 0x8,
HDMI_I2CM_INT_DONE_MASK = 0x4,
/* I2CM_CTLINT field values */
HDMI_I2CM_CTLINT_NAC_POL = 0x80,
HDMI_I2CM_CTLINT_NAC_MASK = 0x40,
HDMI_I2CM_CTLINT_ARB_POL = 0x8,
HDMI_I2CM_CTLINT_ARB_MASK = 0x4,
};
/*
* HDMI 3D TX PHY registers
*/
#define HDMI_3D_TX_PHY_PWRCTRL 0x00
#define HDMI_3D_TX_PHY_SERDIVCTRL 0x01
#define HDMI_3D_TX_PHY_SERCKCTRL 0x02
#define HDMI_3D_TX_PHY_SERCKKILLCTRL 0x03
#define HDMI_3D_TX_PHY_TXRESCTRL 0x04
#define HDMI_3D_TX_PHY_CKCALCTRL 0x05
#define HDMI_3D_TX_PHY_CPCE_CTRL 0x06
#define HDMI_3D_TX_PHY_TXCLKMEASCTRL 0x07
#define HDMI_3D_TX_PHY_TXMEASCTRL 0x08
#define HDMI_3D_TX_PHY_CKSYMTXCTRL 0x09
#define HDMI_3D_TX_PHY_CMPSEQCTRL 0x0a
#define HDMI_3D_TX_PHY_CMPPWRCTRL 0x0b
#define HDMI_3D_TX_PHY_CMPMODECTRL 0x0c
#define HDMI_3D_TX_PHY_MEASCTRL 0x0d
#define HDMI_3D_TX_PHY_VLEVCTRL 0x0e
#define HDMI_3D_TX_PHY_D2ACTRL 0x0f
#define HDMI_3D_TX_PHY_CURRCTRL 0x10
#define HDMI_3D_TX_PHY_DRVANACTRL 0x11
#define HDMI_3D_TX_PHY_PLLMEASCTRL 0x12
#define HDMI_3D_TX_PHY_PLLPHBYCTRL 0x13
#define HDMI_3D_TX_PHY_GRP_CTRL 0x14
#define HDMI_3D_TX_PHY_GMPCTRL 0x15
#define HDMI_3D_TX_PHY_MPLLMEASCTRL 0x16
#define HDMI_3D_TX_PHY_MSM_CTRL 0x17
#define HDMI_3D_TX_PHY_SCRPB_STATUS 0x18
#define HDMI_3D_TX_PHY_TXTERM 0x19
#define HDMI_3D_TX_PHY_PTRPT_ENBL 0x1a
#define HDMI_3D_TX_PHY_PATTERNGEN 0x1b
#define HDMI_3D_TX_PHY_SDCAP_MODE 0x1c
#define HDMI_3D_TX_PHY_SCOPEMODE 0x1d
#define HDMI_3D_TX_PHY_DIGTXMODE 0x1e
#define HDMI_3D_TX_PHY_STR_STATUS 0x1f
#define HDMI_3D_TX_PHY_SCOPECNT0 0x20
#define HDMI_3D_TX_PHY_SCOPECNT1 0x21
#define HDMI_3D_TX_PHY_SCOPECNT2 0x22
#define HDMI_3D_TX_PHY_SCOPECNTCLK 0x23
#define HDMI_3D_TX_PHY_SCOPESAMPLE 0x24
#define HDMI_3D_TX_PHY_SCOPECNTMSB01 0x25
#define HDMI_3D_TX_PHY_SCOPECNTMSB2CK 0x26
/* HDMI_3D_TX_PHY_CKCALCTRL values */
#define HDMI_3D_TX_PHY_CKCALCTRL_OVERRIDE BIT(15)
/* HDMI_3D_TX_PHY_MSM_CTRL values */
#define HDMI_3D_TX_PHY_MSM_CTRL_MPLL_PH_SEL_CK BIT(13)
#define HDMI_3D_TX_PHY_MSM_CTRL_CKO_SEL_CLK_REF_MPLL (0 << 1)
#define HDMI_3D_TX_PHY_MSM_CTRL_CKO_SEL_OFF (1 << 1)
#define HDMI_3D_TX_PHY_MSM_CTRL_CKO_SEL_PCLK (2 << 1)
#define HDMI_3D_TX_PHY_MSM_CTRL_CKO_SEL_FB_CLK (3 << 1)
#define HDMI_3D_TX_PHY_MSM_CTRL_SCOPE_CK_SEL BIT(0)
/* HDMI_3D_TX_PHY_PTRPT_ENBL values */
#define HDMI_3D_TX_PHY_PTRPT_ENBL_OVERRIDE BIT(15)
#define HDMI_3D_TX_PHY_PTRPT_ENBL_PG_SKIP_BIT2 BIT(8)
#define HDMI_3D_TX_PHY_PTRPT_ENBL_PG_SKIP_BIT1 BIT(7)
#define HDMI_3D_TX_PHY_PTRPT_ENBL_PG_SKIP_BIT0 BIT(6)
#define HDMI_3D_TX_PHY_PTRPT_ENBL_CK_REF_ENB BIT(5)
#define HDMI_3D_TX_PHY_PTRPT_ENBL_RCAL_ENB BIT(4)
#define HDMI_3D_TX_PHY_PTRPT_ENBL_TX_CLK_ALIGN_ENB BIT(3)
#define HDMI_3D_TX_PHY_PTRPT_ENBL_TX_READY BIT(2)
#define HDMI_3D_TX_PHY_PTRPT_ENBL_CKO_WORD_ENB BIT(1)
#define HDMI_3D_TX_PHY_PTRPT_ENBL_REFCLK_ENB BIT(0)
#endif /* __DW_HDMI_H__ */