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

displayobject.h (12043B)


      1/****************************************************************************\
      2* 
      3*  Module Name    displayobjectsoc15.h
      4*  Project        
      5*  Device         
      6*
      7*  Description    Contains the common definitions for display objects for SoC15 products.
      8*
      9*  Copyright 2014 Advanced Micro Devices, Inc.
     10*
     11* Permission is hereby granted, free of charge, to any person obtaining a copy of this software 
     12* and associated documentation files (the "Software"), to deal in the Software without restriction,
     13* including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense,
     14* and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so,
     15* subject to the following conditions:
     16*
     17* The above copyright notice and this permission notice shall be included in all copies or substantial
     18* portions of the Software.
     19*
     20* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
     21* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
     22* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
     23* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
     24* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
     25* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
     26* OTHER DEALINGS IN THE SOFTWARE.
     27*
     28\****************************************************************************/
     29#ifndef _DISPLAY_OBJECT_SOC15_H_
     30#define _DISPLAY_OBJECT_SOC15_H_
     31
     32#if defined(_X86_)
     33#pragma pack(1)
     34#endif
     35
     36
     37/****************************************************
     38* Display Object Type Definition 
     39*****************************************************/
     40enum display_object_type{
     41DISPLAY_OBJECT_TYPE_NONE						=0x00,
     42DISPLAY_OBJECT_TYPE_GPU							=0x01,
     43DISPLAY_OBJECT_TYPE_ENCODER						=0x02,
     44DISPLAY_OBJECT_TYPE_CONNECTOR					=0x03
     45};
     46
     47/****************************************************
     48* Encorder Object Type Definition 
     49*****************************************************/
     50enum encoder_object_type{
     51ENCODER_OBJECT_ID_NONE							 =0x00,
     52ENCODER_OBJECT_ID_INTERNAL_UNIPHY				 =0x01,
     53ENCODER_OBJECT_ID_INTERNAL_UNIPHY1				 =0x02,
     54ENCODER_OBJECT_ID_INTERNAL_UNIPHY2				 =0x03,
     55};
     56
     57
     58/****************************************************
     59* Connector Object ID Definition 
     60*****************************************************/
     61
     62enum connector_object_type{
     63CONNECTOR_OBJECT_ID_NONE						  =0x00, 
     64CONNECTOR_OBJECT_ID_SINGLE_LINK_DVI_D			  =0x01,
     65CONNECTOR_OBJECT_ID_DUAL_LINK_DVI_D				  =0x02,
     66CONNECTOR_OBJECT_ID_HDMI_TYPE_A					  =0x03,
     67CONNECTOR_OBJECT_ID_LVDS						  =0x04,
     68CONNECTOR_OBJECT_ID_DISPLAYPORT					  =0x05,
     69CONNECTOR_OBJECT_ID_eDP							  =0x06,
     70CONNECTOR_OBJECT_ID_OPM							  =0x07
     71};
     72
     73
     74/****************************************************
     75* Protection Object ID Definition 
     76*****************************************************/
     77//No need
     78
     79/****************************************************
     80*  Object ENUM ID Definition 
     81*****************************************************/
     82
     83enum object_enum_id{
     84OBJECT_ENUM_ID1									  =0x01,
     85OBJECT_ENUM_ID2									  =0x02,
     86OBJECT_ENUM_ID3									  =0x03,
     87OBJECT_ENUM_ID4									  =0x04,
     88OBJECT_ENUM_ID5									  =0x05,
     89OBJECT_ENUM_ID6									  =0x06
     90};
     91
     92/****************************************************
     93*Object ID Bit definition 
     94*****************************************************/
     95enum object_id_bit{
     96OBJECT_ID_MASK									  =0x00FF,
     97ENUM_ID_MASK									  =0x0F00,
     98OBJECT_TYPE_MASK								  =0xF000,
     99OBJECT_ID_SHIFT									  =0x00,
    100ENUM_ID_SHIFT									  =0x08,
    101OBJECT_TYPE_SHIFT								  =0x0C
    102};
    103
    104
    105/****************************************************
    106* GPU Object definition - Shared with BIOS
    107*****************************************************/
    108enum gpu_objet_def{
    109GPU_ENUM_ID1                            =( DISPLAY_OBJECT_TYPE_GPU << OBJECT_TYPE_SHIFT | OBJECT_ENUM_ID1 << ENUM_ID_SHIFT)
    110};
    111
    112/****************************************************
    113* Encoder Object definition - Shared with BIOS
    114*****************************************************/
    115
    116enum encoder_objet_def{
    117ENCODER_INTERNAL_UNIPHY_ENUM_ID1         =( DISPLAY_OBJECT_TYPE_ENCODER << OBJECT_TYPE_SHIFT |\
    118                                                 OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\
    119                                                 ENCODER_OBJECT_ID_INTERNAL_UNIPHY << OBJECT_ID_SHIFT),
    120
    121ENCODER_INTERNAL_UNIPHY_ENUM_ID2         =( DISPLAY_OBJECT_TYPE_ENCODER << OBJECT_TYPE_SHIFT |\
    122                                                 OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\
    123                                                 ENCODER_OBJECT_ID_INTERNAL_UNIPHY << OBJECT_ID_SHIFT),
    124
    125ENCODER_INTERNAL_UNIPHY1_ENUM_ID1        =( DISPLAY_OBJECT_TYPE_ENCODER << OBJECT_TYPE_SHIFT |\
    126                                                 OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\
    127                                                 ENCODER_OBJECT_ID_INTERNAL_UNIPHY1 << OBJECT_ID_SHIFT),
    128
    129ENCODER_INTERNAL_UNIPHY1_ENUM_ID2        =( DISPLAY_OBJECT_TYPE_ENCODER << OBJECT_TYPE_SHIFT |\
    130                                                 OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\
    131                                                 ENCODER_OBJECT_ID_INTERNAL_UNIPHY1 << OBJECT_ID_SHIFT),
    132
    133ENCODER_INTERNAL_UNIPHY2_ENUM_ID1        =( DISPLAY_OBJECT_TYPE_ENCODER << OBJECT_TYPE_SHIFT |\
    134                                                 OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\
    135                                                 ENCODER_OBJECT_ID_INTERNAL_UNIPHY2 << OBJECT_ID_SHIFT),
    136
    137ENCODER_INTERNAL_UNIPHY2_ENUM_ID2        =( DISPLAY_OBJECT_TYPE_ENCODER << OBJECT_TYPE_SHIFT |\
    138                                                 OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\
    139                                                 ENCODER_OBJECT_ID_INTERNAL_UNIPHY2 << OBJECT_ID_SHIFT)
    140};
    141
    142
    143/****************************************************
    144* Connector Object definition - Shared with BIOS
    145*****************************************************/
    146
    147
    148enum connector_objet_def{
    149CONNECTOR_LVDS_ENUM_ID1							=( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
    150                                                 OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\
    151                                                 CONNECTOR_OBJECT_ID_LVDS << OBJECT_ID_SHIFT),
    152
    153
    154CONNECTOR_eDP_ENUM_ID1							=( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
    155                                                 OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\
    156                                                 CONNECTOR_OBJECT_ID_eDP << OBJECT_ID_SHIFT),
    157
    158CONNECTOR_SINGLE_LINK_DVI_D_ENUM_ID1			=( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
    159                                                 OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\
    160                                                 CONNECTOR_OBJECT_ID_SINGLE_LINK_DVI_D << OBJECT_ID_SHIFT),
    161
    162CONNECTOR_SINGLE_LINK_DVI_D_ENUM_ID2			=( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
    163                                                 OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\
    164                                                 CONNECTOR_OBJECT_ID_SINGLE_LINK_DVI_D << OBJECT_ID_SHIFT),
    165
    166
    167CONNECTOR_DUAL_LINK_DVI_D_ENUM_ID1				=( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
    168                                                 OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\
    169                                                 CONNECTOR_OBJECT_ID_DUAL_LINK_DVI_D << OBJECT_ID_SHIFT),
    170
    171CONNECTOR_DUAL_LINK_DVI_D_ENUM_ID2				=( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
    172                                                 OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\
    173                                                 CONNECTOR_OBJECT_ID_DUAL_LINK_DVI_D << OBJECT_ID_SHIFT),
    174
    175CONNECTOR_HDMI_TYPE_A_ENUM_ID1					=( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
    176                                                 OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\
    177                                                 CONNECTOR_OBJECT_ID_HDMI_TYPE_A << OBJECT_ID_SHIFT),
    178
    179CONNECTOR_HDMI_TYPE_A_ENUM_ID2					=( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
    180                                                 OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\
    181                                                 CONNECTOR_OBJECT_ID_HDMI_TYPE_A << OBJECT_ID_SHIFT),
    182
    183CONNECTOR_DISPLAYPORT_ENUM_ID1					=( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
    184                                                 OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\
    185                                                 CONNECTOR_OBJECT_ID_DISPLAYPORT << OBJECT_ID_SHIFT),
    186
    187CONNECTOR_DISPLAYPORT_ENUM_ID2					=( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
    188                                                 OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\
    189                                                 CONNECTOR_OBJECT_ID_DISPLAYPORT << OBJECT_ID_SHIFT),
    190
    191CONNECTOR_DISPLAYPORT_ENUM_ID3					=( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
    192                                                 OBJECT_ENUM_ID3 << ENUM_ID_SHIFT |\
    193                                                 CONNECTOR_OBJECT_ID_DISPLAYPORT << OBJECT_ID_SHIFT),
    194
    195CONNECTOR_DISPLAYPORT_ENUM_ID4					=( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
    196                                                 OBJECT_ENUM_ID4 << ENUM_ID_SHIFT |\
    197                                                 CONNECTOR_OBJECT_ID_DISPLAYPORT << OBJECT_ID_SHIFT),
    198
    199CONNECTOR_OPM_ENUM_ID1							=( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
    200                                                 OBJECT_ENUM_ID1 << ENUM_ID_SHIFT |\
    201                                                 CONNECTOR_OBJECT_ID_OPM << OBJECT_ID_SHIFT),          //Mapping to MXM_DP_A
    202
    203CONNECTOR_OPM_ENUM_ID2							=( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
    204                                                 OBJECT_ENUM_ID2 << ENUM_ID_SHIFT |\
    205                                                 CONNECTOR_OBJECT_ID_OPM << OBJECT_ID_SHIFT),          //Mapping to MXM_DP_B
    206
    207CONNECTOR_OPM_ENUM_ID3							=( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
    208                                                 OBJECT_ENUM_ID3 << ENUM_ID_SHIFT |\
    209                                                 CONNECTOR_OBJECT_ID_OPM << OBJECT_ID_SHIFT),          //Mapping to MXM_DP_C
    210
    211CONNECTOR_OPM_ENUM_ID4							=( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
    212                                                 OBJECT_ENUM_ID4 << ENUM_ID_SHIFT |\
    213                                                 CONNECTOR_OBJECT_ID_OPM << OBJECT_ID_SHIFT),          //Mapping to MXM_DP_D
    214
    215CONNECTOR_OPM_ENUM_ID5							=( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
    216                                                 OBJECT_ENUM_ID5 << ENUM_ID_SHIFT |\
    217                                                 CONNECTOR_OBJECT_ID_OPM << OBJECT_ID_SHIFT),          //Mapping to MXM_LVDS_TXxx
    218
    219
    220CONNECTOR_OPM_ENUM_ID6							=( DISPLAY_OBJECT_TYPE_CONNECTOR << OBJECT_TYPE_SHIFT |\
    221                                                 OBJECT_ENUM_ID6 << ENUM_ID_SHIFT |\
    222                                                 CONNECTOR_OBJECT_ID_OPM << OBJECT_ID_SHIFT)         //Mapping to MXM_LVDS_TXxx
    223};
    224
    225/****************************************************
    226* Router Object ID definition - Shared with BIOS
    227*****************************************************/
    228//No Need, in future we ever need, we can define a record in atomfirwareSoC15.h associated with an object that has this router
    229
    230
    231/****************************************************
    232* PROTECTION Object ID definition - Shared with BIOS
    233*****************************************************/
    234//No need,in future we ever need, all display path are capable of protection now.
    235
    236/****************************************************
    237* Generic Object ID definition - Shared with BIOS
    238*****************************************************/
    239//No need, in future we ever need like GLsync, we can define a record in atomfirwareSoC15.h associated with an object.
    240
    241
    242#if defined(_X86_)
    243#pragma pack()
    244#endif
    245
    246#endif
    247
    248
    249