Path: blob/master/drivers/gpu/drm/amd/include/displayobject.h
26517 views
/****************************************************************************\1*2* Module Name displayobjectsoc15.h3* Project4* Device5*6* Description Contains the common definitions for display objects for SoC15 products.7*8* Copyright 2014 Advanced Micro Devices, Inc.9*10* Permission is hereby granted, free of charge, to any person obtaining a copy of this software11* and associated documentation files (the "Software"), to deal in the Software without restriction,12* including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense,13* and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so,14* subject to the following conditions:15*16* The above copyright notice and this permission notice shall be included in all copies or substantial17* portions of the Software.18*19* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR20* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,21* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL22* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR23* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,24* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR25* OTHER DEALINGS IN THE SOFTWARE.26*27\****************************************************************************/28#ifndef _DISPLAY_OBJECT_SOC15_H_29#define _DISPLAY_OBJECT_SOC15_H_3031#if defined(_X86_)32#pragma pack(1)33#endif343536/****************************************************37* Display Object Type Definition38*****************************************************/39enum display_object_type{40DISPLAY_OBJECT_TYPE_NONE =0x00,41DISPLAY_OBJECT_TYPE_GPU =0x01,42DISPLAY_OBJECT_TYPE_ENCODER =0x02,43DISPLAY_OBJECT_TYPE_CONNECTOR =0x0344};4546/****************************************************47* Encorder Object Type Definition48*****************************************************/49enum encoder_object_type{50ENCODER_OBJECT_ID_NONE =0x00,51ENCODER_OBJECT_ID_INTERNAL_UNIPHY =0x01,52ENCODER_OBJECT_ID_INTERNAL_UNIPHY1 =0x02,53ENCODER_OBJECT_ID_INTERNAL_UNIPHY2 =0x03,54};555657/****************************************************58* Connector Object ID Definition59*****************************************************/6061enum connector_object_type{62CONNECTOR_OBJECT_ID_NONE =0x00,63CONNECTOR_OBJECT_ID_SINGLE_LINK_DVI_D =0x01,64CONNECTOR_OBJECT_ID_DUAL_LINK_DVI_D =0x02,65CONNECTOR_OBJECT_ID_HDMI_TYPE_A =0x03,66CONNECTOR_OBJECT_ID_LVDS =0x04,67CONNECTOR_OBJECT_ID_DISPLAYPORT =0x05,68CONNECTOR_OBJECT_ID_eDP =0x06,69CONNECTOR_OBJECT_ID_OPM =0x0770};717273/****************************************************74* Protection Object ID Definition75*****************************************************/76//No need7778/****************************************************79* Object ENUM ID Definition80*****************************************************/8182enum object_enum_id{83OBJECT_ENUM_ID1 =0x01,84OBJECT_ENUM_ID2 =0x02,85OBJECT_ENUM_ID3 =0x03,86OBJECT_ENUM_ID4 =0x04,87OBJECT_ENUM_ID5 =0x05,88OBJECT_ENUM_ID6 =0x0689};9091/****************************************************92*Object ID Bit definition93*****************************************************/94enum object_id_bit{95OBJECT_ID_MASK =0x00FF,96ENUM_ID_MASK =0x0F00,97OBJECT_TYPE_MASK =0xF000,98OBJECT_ID_SHIFT =0x00,99ENUM_ID_SHIFT =0x08,100OBJECT_TYPE_SHIFT =0x0C101};102103104/****************************************************105* GPU Object definition - Shared with BIOS106*****************************************************/107enum gpu_objet_def{108GPU_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_GPU << OBJECT_TYPE_SHIFT | OBJECT_ENUM_ID1 << ENUM_ID_SHIFT)109};110111/****************************************************112* Encoder Object definition - Shared with BIOS113*****************************************************/114115enum encoder_objet_def{116ENCODER_INTERNAL_UNIPHY_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_ENCODER << OBJECT_TYPE_SHIFT |\117OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\118ENCODER_OBJECT_ID_INTERNAL_UNIPHY << OBJECT_ID_SHIFT),119120ENCODER_INTERNAL_UNIPHY_ENUM_ID2 =( DISPLAY_OBJECT_TYPE_ENCODER << OBJECT_TYPE_SHIFT |\121OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\122ENCODER_OBJECT_ID_INTERNAL_UNIPHY << OBJECT_ID_SHIFT),123124ENCODER_INTERNAL_UNIPHY1_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_ENCODER << OBJECT_TYPE_SHIFT |\125OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\126ENCODER_OBJECT_ID_INTERNAL_UNIPHY1 << OBJECT_ID_SHIFT),127128ENCODER_INTERNAL_UNIPHY1_ENUM_ID2 =( DISPLAY_OBJECT_TYPE_ENCODER << OBJECT_TYPE_SHIFT |\129OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\130ENCODER_OBJECT_ID_INTERNAL_UNIPHY1 << OBJECT_ID_SHIFT),131132ENCODER_INTERNAL_UNIPHY2_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_ENCODER << OBJECT_TYPE_SHIFT |\133OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\134ENCODER_OBJECT_ID_INTERNAL_UNIPHY2 << OBJECT_ID_SHIFT),135136ENCODER_INTERNAL_UNIPHY2_ENUM_ID2 =( DISPLAY_OBJECT_TYPE_ENCODER << OBJECT_TYPE_SHIFT |\137OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\138ENCODER_OBJECT_ID_INTERNAL_UNIPHY2 << OBJECT_ID_SHIFT)139};140141142/****************************************************143* Connector Object definition - Shared with BIOS144*****************************************************/145146147enum connector_objet_def{148CONNECTOR_LVDS_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\149OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\150CONNECTOR_OBJECT_ID_LVDS << OBJECT_ID_SHIFT),151152153CONNECTOR_eDP_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\154OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\155CONNECTOR_OBJECT_ID_eDP << OBJECT_ID_SHIFT),156157CONNECTOR_SINGLE_LINK_DVI_D_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\158OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\159CONNECTOR_OBJECT_ID_SINGLE_LINK_DVI_D << OBJECT_ID_SHIFT),160161CONNECTOR_SINGLE_LINK_DVI_D_ENUM_ID2 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\162OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\163CONNECTOR_OBJECT_ID_SINGLE_LINK_DVI_D << OBJECT_ID_SHIFT),164165166CONNECTOR_DUAL_LINK_DVI_D_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\167OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\168CONNECTOR_OBJECT_ID_DUAL_LINK_DVI_D << OBJECT_ID_SHIFT),169170CONNECTOR_DUAL_LINK_DVI_D_ENUM_ID2 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\171OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\172CONNECTOR_OBJECT_ID_DUAL_LINK_DVI_D << OBJECT_ID_SHIFT),173174CONNECTOR_HDMI_TYPE_A_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\175OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\176CONNECTOR_OBJECT_ID_HDMI_TYPE_A << OBJECT_ID_SHIFT),177178CONNECTOR_HDMI_TYPE_A_ENUM_ID2 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\179OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\180CONNECTOR_OBJECT_ID_HDMI_TYPE_A << OBJECT_ID_SHIFT),181182CONNECTOR_DISPLAYPORT_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\183OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\184CONNECTOR_OBJECT_ID_DISPLAYPORT << OBJECT_ID_SHIFT),185186CONNECTOR_DISPLAYPORT_ENUM_ID2 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\187OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\188CONNECTOR_OBJECT_ID_DISPLAYPORT << OBJECT_ID_SHIFT),189190CONNECTOR_DISPLAYPORT_ENUM_ID3 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\191OBJECT_ENUM_ID3 << ENUM_ID_SHIFT |\192CONNECTOR_OBJECT_ID_DISPLAYPORT << OBJECT_ID_SHIFT),193194CONNECTOR_DISPLAYPORT_ENUM_ID4 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\195OBJECT_ENUM_ID4 << ENUM_ID_SHIFT |\196CONNECTOR_OBJECT_ID_DISPLAYPORT << OBJECT_ID_SHIFT),197198CONNECTOR_OPM_ENUM_ID1 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\199OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\200CONNECTOR_OBJECT_ID_OPM << OBJECT_ID_SHIFT), //Mapping to MXM_DP_A201202CONNECTOR_OPM_ENUM_ID2 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\203OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\204CONNECTOR_OBJECT_ID_OPM << OBJECT_ID_SHIFT), //Mapping to MXM_DP_B205206CONNECTOR_OPM_ENUM_ID3 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\207OBJECT_ENUM_ID3 << ENUM_ID_SHIFT |\208CONNECTOR_OBJECT_ID_OPM << OBJECT_ID_SHIFT), //Mapping to MXM_DP_C209210CONNECTOR_OPM_ENUM_ID4 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\211OBJECT_ENUM_ID4 << ENUM_ID_SHIFT |\212CONNECTOR_OBJECT_ID_OPM << OBJECT_ID_SHIFT), //Mapping to MXM_DP_D213214CONNECTOR_OPM_ENUM_ID5 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\215OBJECT_ENUM_ID5 << ENUM_ID_SHIFT |\216CONNECTOR_OBJECT_ID_OPM << OBJECT_ID_SHIFT), //Mapping to MXM_LVDS_TXxx217218219CONNECTOR_OPM_ENUM_ID6 =( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\220OBJECT_ENUM_ID6 << ENUM_ID_SHIFT |\221CONNECTOR_OBJECT_ID_OPM << OBJECT_ID_SHIFT) //Mapping to MXM_LVDS_TXxx222};223224/****************************************************225* Router Object ID definition - Shared with BIOS226*****************************************************/227//No Need, in future we ever need, we can define a record in atomfirwareSoC15.h associated with an object that has this router228229230/****************************************************231* PROTECTION Object ID definition - Shared with BIOS232*****************************************************/233//No need,in future we ever need, all display path are capable of protection now.234235/****************************************************236* Generic Object ID definition - Shared with BIOS237*****************************************************/238//No need, in future we ever need like GLsync, we can define a record in atomfirwareSoC15.h associated with an object.239240241#if defined(_X86_)242#pragma pack()243#endif244245#endif246247248249250251