Linux Audio

Check our new training course

Loading...
Note: File does not exist in v4.6.
  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