mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-28 11:18:45 +07:00
4126b99e74
High pixel clocks are required to use a 40 TMDS divider instead of 10, and even low ones may optionally use scrambling depending on device support. Signed-off-by: Ilia Mirkin <imirkin@alum.mit.edu> Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
100 lines
2.2 KiB
C
100 lines
2.2 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef __NVIF_CL5070_H__
|
|
#define __NVIF_CL5070_H__
|
|
|
|
#define NV50_DISP_MTHD 0x00
|
|
|
|
struct nv50_disp_mthd_v0 {
|
|
__u8 version;
|
|
#define NV50_DISP_SCANOUTPOS 0x00
|
|
__u8 method;
|
|
__u8 head;
|
|
__u8 pad03[5];
|
|
};
|
|
|
|
struct nv50_disp_scanoutpos_v0 {
|
|
__u8 version;
|
|
__u8 pad01[7];
|
|
__s64 time[2];
|
|
__u16 vblanks;
|
|
__u16 vblanke;
|
|
__u16 vtotal;
|
|
__u16 vline;
|
|
__u16 hblanks;
|
|
__u16 hblanke;
|
|
__u16 htotal;
|
|
__u16 hline;
|
|
};
|
|
|
|
struct nv50_disp_mthd_v1 {
|
|
__u8 version;
|
|
#define NV50_DISP_MTHD_V1_ACQUIRE 0x01
|
|
#define NV50_DISP_MTHD_V1_RELEASE 0x02
|
|
#define NV50_DISP_MTHD_V1_DAC_LOAD 0x11
|
|
#define NV50_DISP_MTHD_V1_SOR_HDA_ELD 0x21
|
|
#define NV50_DISP_MTHD_V1_SOR_HDMI_PWR 0x22
|
|
#define NV50_DISP_MTHD_V1_SOR_LVDS_SCRIPT 0x23
|
|
#define NV50_DISP_MTHD_V1_SOR_DP_MST_LINK 0x25
|
|
#define NV50_DISP_MTHD_V1_SOR_DP_MST_VCPI 0x26
|
|
__u8 method;
|
|
__u16 hasht;
|
|
__u16 hashm;
|
|
__u8 pad06[2];
|
|
};
|
|
|
|
struct nv50_disp_acquire_v0 {
|
|
__u8 version;
|
|
__u8 or;
|
|
__u8 link;
|
|
__u8 pad03[5];
|
|
};
|
|
|
|
struct nv50_disp_dac_load_v0 {
|
|
__u8 version;
|
|
__u8 load;
|
|
__u8 pad02[2];
|
|
__u32 data;
|
|
};
|
|
|
|
struct nv50_disp_sor_hda_eld_v0 {
|
|
__u8 version;
|
|
__u8 pad01[7];
|
|
__u8 data[];
|
|
};
|
|
|
|
struct nv50_disp_sor_hdmi_pwr_v0 {
|
|
__u8 version;
|
|
__u8 state;
|
|
__u8 max_ac_packet;
|
|
__u8 rekey;
|
|
__u8 avi_infoframe_length;
|
|
__u8 vendor_infoframe_length;
|
|
#define NV50_DISP_SOR_HDMI_PWR_V0_SCDC_SCRAMBLE (1 << 0)
|
|
#define NV50_DISP_SOR_HDMI_PWR_V0_SCDC_DIV_BY_4 (1 << 1)
|
|
__u8 scdc;
|
|
__u8 pad07[1];
|
|
};
|
|
|
|
struct nv50_disp_sor_lvds_script_v0 {
|
|
__u8 version;
|
|
__u8 pad01[1];
|
|
__u16 script;
|
|
__u8 pad04[4];
|
|
};
|
|
|
|
struct nv50_disp_sor_dp_mst_link_v0 {
|
|
__u8 version;
|
|
__u8 state;
|
|
__u8 pad02[6];
|
|
};
|
|
|
|
struct nv50_disp_sor_dp_mst_vcpi_v0 {
|
|
__u8 version;
|
|
__u8 pad01[1];
|
|
__u8 start_slot;
|
|
__u8 num_slots;
|
|
__u16 pbn;
|
|
__u16 aligned_pbn;
|
|
};
|
|
#endif
|