mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-21 17:09:44 +07:00
1fadf42ed5
soc15 asics have a new vbios interface. These headers define that interface. Acked-by: Christian König <christian.koenig@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
250 lines
12 KiB
C
250 lines
12 KiB
C
/****************************************************************************\
|
|
*
|
|
* Module Name displayobjectsoc15.h
|
|
* Project
|
|
* Device
|
|
*
|
|
* Description Contains the common definitions for display objects for SoC15 products.
|
|
*
|
|
* Copyright 2014 Advanced Micro Devices, Inc.
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy of this software
|
|
* and associated documentation files (the "Software"), to deal in the Software without restriction,
|
|
* including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
* and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so,
|
|
* subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in all copies or substantial
|
|
* portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
|
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
|
* OTHER DEALINGS IN THE SOFTWARE.
|
|
*
|
|
\****************************************************************************/
|
|
#ifndef _DISPLAY_OBJECT_SOC15_H_
|
|
#define _DISPLAY_OBJECT_SOC15_H_
|
|
|
|
#if defined(_X86_)
|
|
#pragma pack(1)
|
|
#endif
|
|
|
|
|
|
/****************************************************
|
|
* Display Object Type Definition
|
|
*****************************************************/
|
|
enum display_object_type{
|
|
DISPLAY_OBJECT_TYPE_NONE =0x00,
|
|
DISPLAY_OBJECT_TYPE_GPU =0x01,
|
|
DISPLAY_OBJECT_TYPE_ENCODER =0x02,
|
|
DISPLAY_OBJECT_TYPE_CONNECTOR =0x03
|
|
};
|
|
|
|
/****************************************************
|
|
* Encorder Object Type Definition
|
|
*****************************************************/
|
|
enum encoder_object_type{
|
|
ENCODER_OBJECT_ID_NONE =0x00,
|
|
ENCODER_OBJECT_ID_INTERNAL_UNIPHY =0x01,
|
|
ENCODER_OBJECT_ID_INTERNAL_UNIPHY1 =0x02,
|
|
ENCODER_OBJECT_ID_INTERNAL_UNIPHY2 =0x03,
|
|
};
|
|
|
|
|
|
/****************************************************
|
|
* Connector Object ID Definition
|
|
*****************************************************/
|
|
|
|
enum connector_object_type{
|
|
CONNECTOR_OBJECT_ID_NONE =0x00,
|
|
CONNECTOR_OBJECT_ID_SINGLE_LINK_DVI_D =0x01,
|
|
CONNECTOR_OBJECT_ID_DUAL_LINK_DVI_D =0x02,
|
|
CONNECTOR_OBJECT_ID_HDMI_TYPE_A =0x03,
|
|
CONNECTOR_OBJECT_ID_LVDS =0x04,
|
|
CONNECTOR_OBJECT_ID_DISPLAYPORT =0x05,
|
|
CONNECTOR_OBJECT_ID_eDP =0x06,
|
|
CONNECTOR_OBJECT_ID_OPM =0x07
|
|
};
|
|
|
|
|
|
/****************************************************
|
|
* Protection Object ID Definition
|
|
*****************************************************/
|
|
//No need
|
|
|
|
/****************************************************
|
|
* Object ENUM ID Definition
|
|
*****************************************************/
|
|
|
|
enum object_enum_id{
|
|
OBJECT_ENUM_ID1 =0x01,
|
|
OBJECT_ENUM_ID2 =0x02,
|
|
OBJECT_ENUM_ID3 =0x03,
|
|
OBJECT_ENUM_ID4 =0x04,
|
|
OBJECT_ENUM_ID5 =0x05,
|
|
OBJECT_ENUM_ID6 =0x06
|
|
};
|
|
|
|
/****************************************************
|
|
*Object ID Bit definition
|
|
*****************************************************/
|
|
enum object_id_bit{
|
|
OBJECT_ID_MASK =0x00FF,
|
|
ENUM_ID_MASK =0x0F00,
|
|
OBJECT_TYPE_MASK =0xF000,
|
|
OBJECT_ID_SHIFT =0x00,
|
|
ENUM_ID_SHIFT =0x08,
|
|
OBJECT_TYPE_SHIFT =0x0C
|
|
};
|
|
|
|
|
|
/****************************************************
|
|
* GPU Object definition - Shared with BIOS
|
|
*****************************************************/
|
|
enum gpu_objet_def{
|
|
GPU_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_GPU << OBJECT_TYPE_SHIFT | OBJECT_ENUM_ID1 << ENUM_ID_SHIFT)
|
|
};
|
|
|
|
/****************************************************
|
|
* Encoder Object definition - Shared with BIOS
|
|
*****************************************************/
|
|
|
|
enum encoder_objet_def{
|
|
ENCODER_INTERNAL_UNIPHY_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_ENCODER << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\
|
|
ENCODER_OBJECT_ID_INTERNAL_UNIPHY << OBJECT_ID_SHIFT),
|
|
|
|
ENCODER_INTERNAL_UNIPHY_ENUM_ID2 =( DISPLAY_OBJECT_TYPE_ENCODER << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\
|
|
ENCODER_OBJECT_ID_INTERNAL_UNIPHY << OBJECT_ID_SHIFT),
|
|
|
|
ENCODER_INTERNAL_UNIPHY1_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_ENCODER << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\
|
|
ENCODER_OBJECT_ID_INTERNAL_UNIPHY1 << OBJECT_ID_SHIFT),
|
|
|
|
ENCODER_INTERNAL_UNIPHY1_ENUM_ID2 =( DISPLAY_OBJECT_TYPE_ENCODER << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\
|
|
ENCODER_OBJECT_ID_INTERNAL_UNIPHY1 << OBJECT_ID_SHIFT),
|
|
|
|
ENCODER_INTERNAL_UNIPHY2_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_ENCODER << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\
|
|
ENCODER_OBJECT_ID_INTERNAL_UNIPHY2 << OBJECT_ID_SHIFT),
|
|
|
|
ENCODER_INTERNAL_UNIPHY2_ENUM_ID2 =( DISPLAY_OBJECT_TYPE_ENCODER << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\
|
|
ENCODER_OBJECT_ID_INTERNAL_UNIPHY2 << OBJECT_ID_SHIFT)
|
|
};
|
|
|
|
|
|
/****************************************************
|
|
* Connector Object definition - Shared with BIOS
|
|
*****************************************************/
|
|
|
|
|
|
enum connector_objet_def{
|
|
CONNECTOR_LVDS_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\
|
|
CONNECTOR_OBJECT_ID_LVDS << OBJECT_ID_SHIFT),
|
|
|
|
|
|
CONNECTOR_eDP_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\
|
|
CONNECTOR_OBJECT_ID_eDP << OBJECT_ID_SHIFT),
|
|
|
|
CONNECTOR_SINGLE_LINK_DVI_D_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\
|
|
CONNECTOR_OBJECT_ID_SINGLE_LINK_DVI_D << OBJECT_ID_SHIFT),
|
|
|
|
CONNECTOR_SINGLE_LINK_DVI_D_ENUM_ID2 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\
|
|
CONNECTOR_OBJECT_ID_SINGLE_LINK_DVI_D << OBJECT_ID_SHIFT),
|
|
|
|
|
|
CONNECTOR_DUAL_LINK_DVI_D_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\
|
|
CONNECTOR_OBJECT_ID_DUAL_LINK_DVI_D << OBJECT_ID_SHIFT),
|
|
|
|
CONNECTOR_DUAL_LINK_DVI_D_ENUM_ID2 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\
|
|
CONNECTOR_OBJECT_ID_DUAL_LINK_DVI_D << OBJECT_ID_SHIFT),
|
|
|
|
CONNECTOR_HDMI_TYPE_A_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\
|
|
CONNECTOR_OBJECT_ID_HDMI_TYPE_A << OBJECT_ID_SHIFT),
|
|
|
|
CONNECTOR_HDMI_TYPE_A_ENUM_ID2 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\
|
|
CONNECTOR_OBJECT_ID_HDMI_TYPE_A << OBJECT_ID_SHIFT),
|
|
|
|
CONNECTOR_DISPLAYPORT_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\
|
|
CONNECTOR_OBJECT_ID_DISPLAYPORT << OBJECT_ID_SHIFT),
|
|
|
|
CONNECTOR_DISPLAYPORT_ENUM_ID2 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\
|
|
CONNECTOR_OBJECT_ID_DISPLAYPORT << OBJECT_ID_SHIFT),
|
|
|
|
CONNECTOR_DISPLAYPORT_ENUM_ID3 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID3 << ENUM_ID_SHIFT |\
|
|
CONNECTOR_OBJECT_ID_DISPLAYPORT << OBJECT_ID_SHIFT),
|
|
|
|
CONNECTOR_DISPLAYPORT_ENUM_ID4 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID4 << ENUM_ID_SHIFT |\
|
|
CONNECTOR_OBJECT_ID_DISPLAYPORT << OBJECT_ID_SHIFT),
|
|
|
|
CONNECTOR_OPM_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\
|
|
CONNECTOR_OBJECT_ID_OPM << OBJECT_ID_SHIFT), //Mapping to MXM_DP_A
|
|
|
|
CONNECTOR_OPM_ENUM_ID2 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\
|
|
CONNECTOR_OBJECT_ID_OPM << OBJECT_ID_SHIFT), //Mapping to MXM_DP_B
|
|
|
|
CONNECTOR_OPM_ENUM_ID3 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID3 << ENUM_ID_SHIFT |\
|
|
CONNECTOR_OBJECT_ID_OPM << OBJECT_ID_SHIFT), //Mapping to MXM_DP_C
|
|
|
|
CONNECTOR_OPM_ENUM_ID4 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID4 << ENUM_ID_SHIFT |\
|
|
CONNECTOR_OBJECT_ID_OPM << OBJECT_ID_SHIFT), //Mapping to MXM_DP_D
|
|
|
|
CONNECTOR_OPM_ENUM_ID5 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID5 << ENUM_ID_SHIFT |\
|
|
CONNECTOR_OBJECT_ID_OPM << OBJECT_ID_SHIFT), //Mapping to MXM_LVDS_TXxx
|
|
|
|
|
|
CONNECTOR_OPM_ENUM_ID6 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
|
|
OBJECT_ENUM_ID6 << ENUM_ID_SHIFT |\
|
|
CONNECTOR_OBJECT_ID_OPM << OBJECT_ID_SHIFT) //Mapping to MXM_LVDS_TXxx
|
|
};
|
|
|
|
/****************************************************
|
|
* Router Object ID definition - Shared with BIOS
|
|
*****************************************************/
|
|
//No Need, in future we ever need, we can define a record in atomfirwareSoC15.h associated with an object that has this router
|
|
|
|
|
|
/****************************************************
|
|
* PROTECTION Object ID definition - Shared with BIOS
|
|
*****************************************************/
|
|
//No need,in future we ever need, all display path are capable of protection now.
|
|
|
|
/****************************************************
|
|
* Generic Object ID definition - Shared with BIOS
|
|
*****************************************************/
|
|
//No need, in future we ever need like GLsync, we can define a record in atomfirwareSoC15.h associated with an object.
|
|
|
|
|
|
#if defined(_X86_)
|
|
#pragma pack()
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|