cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

hdmi5_core.h (10819B)


      1/* SPDX-License-Identifier: GPL-2.0-only */
      2/*
      3 * HDMI driver definition for TI OMAP5 processors.
      4 *
      5 * Copyright (C) 2011-2012 Texas Instruments Incorporated - https://www.ti.com/
      6 */
      7
      8#ifndef _HDMI5_CORE_H_
      9#define _HDMI5_CORE_H_
     10
     11#include "hdmi.h"
     12
     13/* HDMI IP Core System */
     14
     15/* HDMI Identification */
     16#define HDMI_CORE_DESIGN_ID			0x00000
     17#define HDMI_CORE_REVISION_ID			0x00004
     18#define HDMI_CORE_PRODUCT_ID0			0x00008
     19#define HDMI_CORE_PRODUCT_ID1			0x0000C
     20#define HDMI_CORE_CONFIG0_ID			0x00010
     21#define HDMI_CORE_CONFIG1_ID			0x00014
     22#define HDMI_CORE_CONFIG2_ID			0x00018
     23#define HDMI_CORE_CONFIG3_ID			0x0001C
     24
     25/* HDMI Interrupt */
     26#define HDMI_CORE_IH_FC_STAT0			0x00400
     27#define HDMI_CORE_IH_FC_STAT1			0x00404
     28#define HDMI_CORE_IH_FC_STAT2			0x00408
     29#define HDMI_CORE_IH_AS_STAT0			0x0040C
     30#define HDMI_CORE_IH_PHY_STAT0			0x00410
     31#define HDMI_CORE_IH_I2CM_STAT0			0x00414
     32#define HDMI_CORE_IH_CEC_STAT0			0x00418
     33#define HDMI_CORE_IH_VP_STAT0			0x0041C
     34#define HDMI_CORE_IH_I2CMPHY_STAT0		0x00420
     35#define HDMI_CORE_IH_MUTE			0x007FC
     36
     37/* HDMI Video Sampler */
     38#define HDMI_CORE_TX_INVID0			0x00800
     39#define HDMI_CORE_TX_INSTUFFING			0x00804
     40#define HDMI_CORE_TX_RGYDATA0			0x00808
     41#define HDMI_CORE_TX_RGYDATA1			0x0080C
     42#define HDMI_CORE_TX_RCRDATA0			0x00810
     43#define HDMI_CORE_TX_RCRDATA1			0x00814
     44#define HDMI_CORE_TX_BCBDATA0			0x00818
     45#define HDMI_CORE_TX_BCBDATA1			0x0081C
     46
     47/* HDMI Video Packetizer */
     48#define HDMI_CORE_VP_STATUS			0x02000
     49#define HDMI_CORE_VP_PR_CD			0x02004
     50#define HDMI_CORE_VP_STUFF			0x02008
     51#define HDMI_CORE_VP_REMAP			0x0200C
     52#define HDMI_CORE_VP_CONF			0x02010
     53#define HDMI_CORE_VP_STAT			0x02014
     54#define HDMI_CORE_VP_INT			0x02018
     55#define HDMI_CORE_VP_MASK			0x0201C
     56#define HDMI_CORE_VP_POL			0x02020
     57
     58/* Frame Composer */
     59#define HDMI_CORE_FC_INVIDCONF			0x04000
     60#define HDMI_CORE_FC_INHACTIV0			0x04004
     61#define HDMI_CORE_FC_INHACTIV1			0x04008
     62#define HDMI_CORE_FC_INHBLANK0			0x0400C
     63#define HDMI_CORE_FC_INHBLANK1			0x04010
     64#define HDMI_CORE_FC_INVACTIV0			0x04014
     65#define HDMI_CORE_FC_INVACTIV1			0x04018
     66#define HDMI_CORE_FC_INVBLANK			0x0401C
     67#define HDMI_CORE_FC_HSYNCINDELAY0		0x04020
     68#define HDMI_CORE_FC_HSYNCINDELAY1		0x04024
     69#define HDMI_CORE_FC_HSYNCINWIDTH0		0x04028
     70#define HDMI_CORE_FC_HSYNCINWIDTH1		0x0402C
     71#define HDMI_CORE_FC_VSYNCINDELAY		0x04030
     72#define HDMI_CORE_FC_VSYNCINWIDTH		0x04034
     73#define HDMI_CORE_FC_INFREQ0			0x04038
     74#define HDMI_CORE_FC_INFREQ1			0x0403C
     75#define HDMI_CORE_FC_INFREQ2			0x04040
     76#define HDMI_CORE_FC_CTRLDUR			0x04044
     77#define HDMI_CORE_FC_EXCTRLDUR			0x04048
     78#define HDMI_CORE_FC_EXCTRLSPAC			0x0404C
     79#define HDMI_CORE_FC_CH0PREAM			0x04050
     80#define HDMI_CORE_FC_CH1PREAM			0x04054
     81#define HDMI_CORE_FC_CH2PREAM			0x04058
     82#define HDMI_CORE_FC_AVICONF3			0x0405C
     83#define HDMI_CORE_FC_GCP			0x04060
     84#define HDMI_CORE_FC_AVICONF0			0x04064
     85#define HDMI_CORE_FC_AVICONF1			0x04068
     86#define HDMI_CORE_FC_AVICONF2			0x0406C
     87#define HDMI_CORE_FC_AVIVID			0x04070
     88#define HDMI_CORE_FC_AVIETB0			0x04074
     89#define HDMI_CORE_FC_AVIETB1			0x04078
     90#define HDMI_CORE_FC_AVISBB0			0x0407C
     91#define HDMI_CORE_FC_AVISBB1			0x04080
     92#define HDMI_CORE_FC_AVIELB0			0x04084
     93#define HDMI_CORE_FC_AVIELB1			0x04088
     94#define HDMI_CORE_FC_AVISRB0			0x0408C
     95#define HDMI_CORE_FC_AVISRB1			0x04090
     96#define HDMI_CORE_FC_AUDICONF0			0x04094
     97#define HDMI_CORE_FC_AUDICONF1			0x04098
     98#define HDMI_CORE_FC_AUDICONF2			0x0409C
     99#define HDMI_CORE_FC_AUDICONF3			0x040A0
    100#define HDMI_CORE_FC_VSDIEEEID0			0x040A4
    101#define HDMI_CORE_FC_VSDSIZE			0x040A8
    102#define HDMI_CORE_FC_VSDIEEEID1			0x040C0
    103#define HDMI_CORE_FC_VSDIEEEID2			0x040C4
    104#define HDMI_CORE_FC_VSDPAYLOAD(n)		(n * 4 + 0x040C8)
    105#define HDMI_CORE_FC_SPDVENDORNAME(n)		(n * 4 + 0x04128)
    106#define HDMI_CORE_FC_SPDPRODUCTNAME(n)		(n * 4 + 0x04148)
    107#define HDMI_CORE_FC_SPDDEVICEINF		0x04188
    108#define HDMI_CORE_FC_AUDSCONF			0x0418C
    109#define HDMI_CORE_FC_AUDSSTAT			0x04190
    110#define HDMI_CORE_FC_AUDSV			0x04194
    111#define HDMI_CORE_FC_AUDSU			0x04198
    112#define HDMI_CORE_FC_AUDSCHNLS(n)		(n * 4 + 0x0419C)
    113#define HDMI_CORE_FC_CTRLQHIGH			0x041CC
    114#define HDMI_CORE_FC_CTRLQLOW			0x041D0
    115#define HDMI_CORE_FC_ACP0			0x041D4
    116#define HDMI_CORE_FC_ACP(n)			((16-n) * 4 + 0x04208)
    117#define HDMI_CORE_FC_ISCR1_0			0x04248
    118#define HDMI_CORE_FC_ISCR1(n)			((16-n) * 4 + 0x0424C)
    119#define HDMI_CORE_FC_ISCR2(n)			((15-n) * 4 + 0x0428C)
    120#define HDMI_CORE_FC_DATAUTO0			0x042CC
    121#define HDMI_CORE_FC_DATAUTO1			0x042D0
    122#define HDMI_CORE_FC_DATAUTO2			0x042D4
    123#define HDMI_CORE_FC_DATMAN			0x042D8
    124#define HDMI_CORE_FC_DATAUTO3			0x042DC
    125#define HDMI_CORE_FC_RDRB(n)			(n * 4 + 0x042E0)
    126#define HDMI_CORE_FC_STAT0			0x04340
    127#define HDMI_CORE_FC_INT0			0x04344
    128#define HDMI_CORE_FC_MASK0			0x04348
    129#define HDMI_CORE_FC_POL0			0x0434C
    130#define HDMI_CORE_FC_STAT1			0x04350
    131#define HDMI_CORE_FC_INT1			0x04354
    132#define HDMI_CORE_FC_MASK1			0x04358
    133#define HDMI_CORE_FC_POL1			0x0435C
    134#define HDMI_CORE_FC_STAT2			0x04360
    135#define HDMI_CORE_FC_INT2			0x04364
    136#define HDMI_CORE_FC_MASK2			0x04368
    137#define HDMI_CORE_FC_POL2			0x0436C
    138#define HDMI_CORE_FC_PRCONF			0x04380
    139#define HDMI_CORE_FC_GMD_STAT			0x04400
    140#define HDMI_CORE_FC_GMD_EN			0x04404
    141#define HDMI_CORE_FC_GMD_UP			0x04408
    142#define HDMI_CORE_FC_GMD_CONF			0x0440C
    143#define HDMI_CORE_FC_GMD_HB			0x04410
    144#define HDMI_CORE_FC_GMD_PB(n)			(n * 4 + 0x04414)
    145#define HDMI_CORE_FC_DBGFORCE			0x04800
    146#define HDMI_CORE_FC_DBGAUD0CH0			0x04804
    147#define HDMI_CORE_FC_DBGAUD1CH0			0x04808
    148#define HDMI_CORE_FC_DBGAUD2CH0			0x0480C
    149#define HDMI_CORE_FC_DBGAUD0CH1			0x04810
    150#define HDMI_CORE_FC_DBGAUD1CH1			0x04814
    151#define HDMI_CORE_FC_DBGAUD2CH1			0x04818
    152#define HDMI_CORE_FC_DBGAUD0CH2			0x0481C
    153#define HDMI_CORE_FC_DBGAUD1CH2			0x04820
    154#define HDMI_CORE_FC_DBGAUD2CH2			0x04824
    155#define HDMI_CORE_FC_DBGAUD0CH3			0x04828
    156#define HDMI_CORE_FC_DBGAUD1CH3			0x0482C
    157#define HDMI_CORE_FC_DBGAUD2CH3			0x04830
    158#define HDMI_CORE_FC_DBGAUD0CH4			0x04834
    159#define HDMI_CORE_FC_DBGAUD1CH4			0x04838
    160#define HDMI_CORE_FC_DBGAUD2CH4			0x0483C
    161#define HDMI_CORE_FC_DBGAUD0CH5			0x04840
    162#define HDMI_CORE_FC_DBGAUD1CH5			0x04844
    163#define HDMI_CORE_FC_DBGAUD2CH5			0x04848
    164#define HDMI_CORE_FC_DBGAUD0CH6			0x0484C
    165#define HDMI_CORE_FC_DBGAUD1CH6			0x04850
    166#define HDMI_CORE_FC_DBGAUD2CH6			0x04854
    167#define HDMI_CORE_FC_DBGAUD0CH7			0x04858
    168#define HDMI_CORE_FC_DBGAUD1CH7			0x0485C
    169#define HDMI_CORE_FC_DBGAUD2CH7			0x04860
    170#define HDMI_CORE_FC_DBGTMDS0			0x04864
    171#define HDMI_CORE_FC_DBGTMDS1			0x04868
    172#define HDMI_CORE_FC_DBGTMDS2			0x0486C
    173#define HDMI_CORE_PHY_MASK0			0x0C018
    174#define HDMI_CORE_PHY_I2CM_INT_ADDR		0x0C09C
    175#define HDMI_CORE_PHY_I2CM_CTLINT_ADDR		0x0C0A0
    176
    177/* HDMI Audio */
    178#define HDMI_CORE_AUD_CONF0			0x0C400
    179#define HDMI_CORE_AUD_CONF1			0x0C404
    180#define HDMI_CORE_AUD_INT			0x0C408
    181#define HDMI_CORE_AUD_N1			0x0C800
    182#define HDMI_CORE_AUD_N2			0x0C804
    183#define HDMI_CORE_AUD_N3			0x0C808
    184#define HDMI_CORE_AUD_CTS1			0x0C80C
    185#define HDMI_CORE_AUD_CTS2			0x0C810
    186#define HDMI_CORE_AUD_CTS3			0x0C814
    187#define HDMI_CORE_AUD_INCLKFS			0x0C818
    188#define HDMI_CORE_AUD_CC08			0x0CC08
    189#define HDMI_CORE_AUD_GP_CONF0			0x0D400
    190#define HDMI_CORE_AUD_GP_CONF1			0x0D404
    191#define HDMI_CORE_AUD_GP_CONF2			0x0D408
    192#define HDMI_CORE_AUD_D010			0x0D010
    193#define HDMI_CORE_AUD_GP_STAT			0x0D40C
    194#define HDMI_CORE_AUD_GP_INT			0x0D410
    195#define HDMI_CORE_AUD_GP_POL			0x0D414
    196#define HDMI_CORE_AUD_GP_MASK			0x0D418
    197
    198/* HDMI Main Controller */
    199#define HDMI_CORE_MC_CLKDIS			0x10004
    200#define HDMI_CORE_MC_SWRSTZREQ			0x10008
    201#define HDMI_CORE_MC_FLOWCTRL			0x10010
    202#define HDMI_CORE_MC_PHYRSTZ			0x10014
    203#define HDMI_CORE_MC_LOCKONCLOCK		0x10018
    204
    205/* HDMI COLOR SPACE CONVERTER */
    206#define HDMI_CORE_CSC_CFG			0x10400
    207#define HDMI_CORE_CSC_SCALE			0x10404
    208#define HDMI_CORE_CSC_COEF_A1_MSB		0x10408
    209#define HDMI_CORE_CSC_COEF_A1_LSB		0x1040C
    210#define HDMI_CORE_CSC_COEF_A2_MSB		0x10410
    211#define HDMI_CORE_CSC_COEF_A2_LSB		0x10414
    212#define HDMI_CORE_CSC_COEF_A3_MSB		0x10418
    213#define HDMI_CORE_CSC_COEF_A3_LSB		0x1041C
    214#define HDMI_CORE_CSC_COEF_A4_MSB		0x10420
    215#define HDMI_CORE_CSC_COEF_A4_LSB		0x10424
    216#define HDMI_CORE_CSC_COEF_B1_MSB		0x10428
    217#define HDMI_CORE_CSC_COEF_B1_LSB		0x1042C
    218#define HDMI_CORE_CSC_COEF_B2_MSB		0x10430
    219#define HDMI_CORE_CSC_COEF_B2_LSB		0x10434
    220#define HDMI_CORE_CSC_COEF_B3_MSB		0x10438
    221#define HDMI_CORE_CSC_COEF_B3_LSB		0x1043C
    222#define HDMI_CORE_CSC_COEF_B4_MSB		0x10440
    223#define HDMI_CORE_CSC_COEF_B4_LSB		0x10444
    224#define HDMI_CORE_CSC_COEF_C1_MSB		0x10448
    225#define HDMI_CORE_CSC_COEF_C1_LSB		0x1044C
    226#define HDMI_CORE_CSC_COEF_C2_MSB		0x10450
    227#define HDMI_CORE_CSC_COEF_C2_LSB		0x10454
    228#define HDMI_CORE_CSC_COEF_C3_MSB		0x10458
    229#define HDMI_CORE_CSC_COEF_C3_LSB		0x1045C
    230#define HDMI_CORE_CSC_COEF_C4_MSB		0x10460
    231#define HDMI_CORE_CSC_COEF_C4_LSB		0x10464
    232
    233/* HDMI HDCP */
    234#define HDMI_CORE_HDCP_MASK			0x14020
    235
    236/* HDMI CEC */
    237#define HDMI_CORE_CEC_MASK			0x17408
    238
    239/* HDMI I2C Master */
    240#define HDMI_CORE_I2CM_SLAVE			0x157C8
    241#define HDMI_CORE_I2CM_ADDRESS			0x157CC
    242#define HDMI_CORE_I2CM_DATAO			0x157D0
    243#define HDMI_CORE_I2CM_DATAI			0X157D4
    244#define HDMI_CORE_I2CM_OPERATION		0x157D8
    245#define HDMI_CORE_I2CM_INT			0x157DC
    246#define HDMI_CORE_I2CM_CTLINT			0x157E0
    247#define HDMI_CORE_I2CM_DIV			0x157E4
    248#define HDMI_CORE_I2CM_SEGADDR			0x157E8
    249#define HDMI_CORE_I2CM_SOFTRSTZ			0x157EC
    250#define HDMI_CORE_I2CM_SEGPTR			0x157F0
    251#define HDMI_CORE_I2CM_SS_SCL_HCNT_1_ADDR	0x157F4
    252#define HDMI_CORE_I2CM_SS_SCL_HCNT_0_ADDR	0x157F8
    253#define HDMI_CORE_I2CM_SS_SCL_LCNT_1_ADDR	0x157FC
    254#define HDMI_CORE_I2CM_SS_SCL_LCNT_0_ADDR	0x15800
    255#define HDMI_CORE_I2CM_FS_SCL_HCNT_1_ADDR	0x15804
    256#define HDMI_CORE_I2CM_FS_SCL_HCNT_0_ADDR	0x15808
    257#define HDMI_CORE_I2CM_FS_SCL_LCNT_1_ADDR	0x1580C
    258#define HDMI_CORE_I2CM_FS_SCL_LCNT_0_ADDR	0x15810
    259#define HDMI_CORE_I2CM_SDA_HOLD_ADDR		0x15814
    260
    261enum hdmi_core_packet_mode {
    262	HDMI_PACKETMODERESERVEDVALUE = 0,
    263	HDMI_PACKETMODE24BITPERPIXEL = 4,
    264	HDMI_PACKETMODE30BITPERPIXEL = 5,
    265	HDMI_PACKETMODE36BITPERPIXEL = 6,
    266	HDMI_PACKETMODE48BITPERPIXEL = 7,
    267};
    268
    269struct hdmi_core_vid_config {
    270	struct hdmi_config v_fc_config;
    271	enum hdmi_core_packet_mode packet_mode;
    272	int data_enable_pol;
    273	int vblank_osc;
    274	int hblank;
    275	int vblank;
    276};
    277
    278struct csc_table {
    279	u16 a1, a2, a3, a4;
    280	u16 b1, b2, b3, b4;
    281	u16 c1, c2, c3, c4;
    282};
    283
    284void hdmi5_core_ddc_init(struct hdmi_core_data *core);
    285int hdmi5_core_ddc_read(void *data, u8 *buf, unsigned int block, size_t len);
    286void hdmi5_core_ddc_uninit(struct hdmi_core_data *core);
    287
    288void hdmi5_core_dump(struct hdmi_core_data *core, struct seq_file *s);
    289int hdmi5_core_handle_irqs(struct hdmi_core_data *core);
    290void hdmi5_configure(struct hdmi_core_data *core, struct hdmi_wp_data *wp,
    291			struct hdmi_config *cfg);
    292int hdmi5_core_init(struct platform_device *pdev, struct hdmi_core_data *core);
    293
    294int hdmi5_audio_config(struct hdmi_core_data *core, struct hdmi_wp_data *wp,
    295			struct omap_dss_audio *audio, u32 pclk);
    296#endif