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