WIP FPC-III support
[linux/fpc-iii.git] / drivers / gpu / drm / amd / display / dc / dml / display_mode_vba.h
blob3529fedc4c523c1ac37eeb763ef7c8360ae3ff8d
1 /*
2 * Copyright 2017 Advanced Micro Devices, Inc.
4 * Permission is hereby granted, free of charge, to any person obtaining a
5 * copy of this software and associated documentation files (the "Software"),
6 * to deal in the Software without restriction, including without limitation
7 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8 * and/or sell copies of the Software, and to permit persons to whom the
9 * Software is furnished to do so, subject to the following conditions:
11 * The above copyright notice and this permission notice shall be included in
12 * all copies or substantial portions of the Software.
14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
17 * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
18 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
19 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
20 * OTHER DEALINGS IN THE SOFTWARE.
22 * Authors: AMD
27 #ifndef __DML2_DISPLAY_MODE_VBA_H__
28 #define __DML2_DISPLAY_MODE_VBA_H__
30 struct display_mode_lib;
32 void ModeSupportAndSystemConfiguration(struct display_mode_lib *mode_lib);
34 #define dml_get_attr_decl(attr) double get_##attr(struct display_mode_lib *mode_lib, const display_e2e_pipe_params_st *pipes, unsigned int num_pipes)
36 dml_get_attr_decl(clk_dcf_deepsleep);
37 dml_get_attr_decl(wm_urgent);
38 dml_get_attr_decl(wm_memory_trip);
39 dml_get_attr_decl(wm_writeback_urgent);
40 dml_get_attr_decl(wm_stutter_exit);
41 dml_get_attr_decl(wm_stutter_enter_exit);
42 dml_get_attr_decl(wm_dram_clock_change);
43 dml_get_attr_decl(wm_writeback_dram_clock_change);
44 dml_get_attr_decl(stutter_efficiency_no_vblank);
45 dml_get_attr_decl(stutter_efficiency);
46 dml_get_attr_decl(stutter_period);
47 dml_get_attr_decl(urgent_latency);
48 dml_get_attr_decl(urgent_extra_latency);
49 dml_get_attr_decl(nonurgent_latency);
50 dml_get_attr_decl(dram_clock_change_latency);
51 dml_get_attr_decl(dispclk_calculated);
52 dml_get_attr_decl(total_data_read_bw);
53 dml_get_attr_decl(return_bw);
54 dml_get_attr_decl(tcalc);
55 dml_get_attr_decl(fraction_of_urgent_bandwidth);
56 dml_get_attr_decl(fraction_of_urgent_bandwidth_imm_flip);
58 #define dml_get_pipe_attr_decl(attr) double get_##attr(struct display_mode_lib *mode_lib, const display_e2e_pipe_params_st *pipes, unsigned int num_pipes, unsigned int which_pipe)
60 dml_get_pipe_attr_decl(dsc_delay);
61 dml_get_pipe_attr_decl(dppclk_calculated);
62 dml_get_pipe_attr_decl(dscclk_calculated);
63 dml_get_pipe_attr_decl(min_ttu_vblank);
64 dml_get_pipe_attr_decl(min_ttu_vblank_in_us);
65 dml_get_pipe_attr_decl(vratio_prefetch_l);
66 dml_get_pipe_attr_decl(vratio_prefetch_c);
67 dml_get_pipe_attr_decl(dst_x_after_scaler);
68 dml_get_pipe_attr_decl(dst_y_after_scaler);
69 dml_get_pipe_attr_decl(dst_y_per_vm_vblank);
70 dml_get_pipe_attr_decl(dst_y_per_row_vblank);
71 dml_get_pipe_attr_decl(dst_y_prefetch);
72 dml_get_pipe_attr_decl(dst_y_per_vm_flip);
73 dml_get_pipe_attr_decl(dst_y_per_row_flip);
74 dml_get_pipe_attr_decl(refcyc_per_vm_group_vblank);
75 dml_get_pipe_attr_decl(refcyc_per_vm_group_flip);
76 dml_get_pipe_attr_decl(refcyc_per_vm_req_vblank);
77 dml_get_pipe_attr_decl(refcyc_per_vm_req_flip);
78 dml_get_pipe_attr_decl(refcyc_per_vm_group_vblank_in_us);
79 dml_get_pipe_attr_decl(refcyc_per_vm_group_flip_in_us);
80 dml_get_pipe_attr_decl(refcyc_per_vm_req_vblank_in_us);
81 dml_get_pipe_attr_decl(refcyc_per_vm_req_flip_in_us);
82 dml_get_pipe_attr_decl(refcyc_per_vm_dmdata_in_us);
83 dml_get_pipe_attr_decl(dmdata_dl_delta_in_us);
84 dml_get_pipe_attr_decl(refcyc_per_line_delivery_l_in_us);
85 dml_get_pipe_attr_decl(refcyc_per_line_delivery_c_in_us);
86 dml_get_pipe_attr_decl(refcyc_per_line_delivery_pre_l_in_us);
87 dml_get_pipe_attr_decl(refcyc_per_line_delivery_pre_c_in_us);
88 dml_get_pipe_attr_decl(refcyc_per_req_delivery_l_in_us);
89 dml_get_pipe_attr_decl(refcyc_per_req_delivery_c_in_us);
90 dml_get_pipe_attr_decl(refcyc_per_req_delivery_pre_l_in_us);
91 dml_get_pipe_attr_decl(refcyc_per_req_delivery_pre_c_in_us);
92 dml_get_pipe_attr_decl(refcyc_per_cursor_req_delivery_in_us);
93 dml_get_pipe_attr_decl(refcyc_per_cursor_req_delivery_pre_in_us);
94 dml_get_pipe_attr_decl(refcyc_per_meta_chunk_nom_l_in_us);
95 dml_get_pipe_attr_decl(refcyc_per_meta_chunk_nom_c_in_us);
96 dml_get_pipe_attr_decl(refcyc_per_meta_chunk_vblank_l_in_us);
97 dml_get_pipe_attr_decl(refcyc_per_meta_chunk_vblank_c_in_us);
98 dml_get_pipe_attr_decl(refcyc_per_meta_chunk_flip_l_in_us);
99 dml_get_pipe_attr_decl(refcyc_per_meta_chunk_flip_c_in_us);
101 dml_get_pipe_attr_decl(vstartup);
102 dml_get_pipe_attr_decl(vupdate_offset);
103 dml_get_pipe_attr_decl(vupdate_width);
104 dml_get_pipe_attr_decl(vready_offset);
106 double get_total_immediate_flip_bytes(
107 struct display_mode_lib *mode_lib,
108 const display_e2e_pipe_params_st *pipes,
109 unsigned int num_pipes);
110 double get_total_immediate_flip_bw(
111 struct display_mode_lib *mode_lib,
112 const display_e2e_pipe_params_st *pipes,
113 unsigned int num_pipes);
114 double get_total_prefetch_bw(
115 struct display_mode_lib *mode_lib,
116 const display_e2e_pipe_params_st *pipes,
117 unsigned int num_pipes);
118 unsigned int dml_get_voltage_level(
119 struct display_mode_lib *mode_lib,
120 const display_e2e_pipe_params_st *pipes,
121 unsigned int num_pipes);
123 void PixelClockAdjustmentForProgressiveToInterlaceUnit(struct display_mode_lib *mode_lib);
125 bool Calculate256BBlockSizes(
126 enum source_format_class SourcePixelFormat,
127 enum dm_swizzle_mode SurfaceTiling,
128 unsigned int BytePerPixelY,
129 unsigned int BytePerPixelC,
130 unsigned int *BlockHeight256BytesY,
131 unsigned int *BlockHeight256BytesC,
132 unsigned int *BlockWidth256BytesY,
133 unsigned int *BlockWidth256BytesC);
135 struct vba_vars_st {
136 ip_params_st ip;
137 soc_bounding_box_st soc;
139 int maxMpcComb;
140 bool UseMaximumVStartup;
142 double WritebackDISPCLK;
143 double DPPCLKUsingSingleDPPLuma;
144 double DPPCLKUsingSingleDPPChroma;
145 double DISPCLKWithRamping;
146 double DISPCLKWithoutRamping;
147 double GlobalDPPCLK;
148 double DISPCLKWithRampingRoundedToDFSGranularity;
149 double DISPCLKWithoutRampingRoundedToDFSGranularity;
150 double MaxDispclkRoundedToDFSGranularity;
151 bool DCCEnabledAnyPlane;
152 double ReturnBandwidthToDCN;
153 unsigned int TotalActiveDPP;
154 unsigned int TotalDCCActiveDPP;
155 double UrgentRoundTripAndOutOfOrderLatency;
156 double StutterPeriod;
157 double FrameTimeForMinFullDETBufferingTime;
158 double AverageReadBandwidth;
159 double TotalRowReadBandwidth;
160 double PartOfBurstThatFitsInROB;
161 double StutterBurstTime;
162 unsigned int NextPrefetchMode;
163 double NextMaxVStartup;
164 double VBlankTime;
165 double SmallestVBlank;
166 double DCFCLKDeepSleepPerPlane[DC__NUM_DPP__MAX];
167 double EffectiveDETPlusLBLinesLuma;
168 double EffectiveDETPlusLBLinesChroma;
169 double UrgentLatencySupportUsLuma;
170 double UrgentLatencySupportUsChroma;
171 unsigned int DSCFormatFactor;
173 bool DummyPStateCheck;
174 bool DRAMClockChangeSupportsVActive;
175 bool PrefetchModeSupported;
176 bool PrefetchAndImmediateFlipSupported;
177 enum self_refresh_affinity AllowDRAMSelfRefreshOrDRAMClockChangeInVblank; // Mode Support only
178 double XFCRemoteSurfaceFlipDelay;
179 double TInitXFill;
180 double TslvChk;
181 double SrcActiveDrainRate;
182 bool ImmediateFlipSupported;
183 enum mpc_combine_affinity WhenToDoMPCCombine; // Mode Support only
185 bool PrefetchERROR;
187 unsigned int VStartupLines;
188 unsigned int ActiveDPPs;
189 unsigned int LBLatencyHidingSourceLinesY;
190 unsigned int LBLatencyHidingSourceLinesC;
191 double ActiveDRAMClockChangeLatencyMargin[DC__NUM_DPP__MAX];
192 double MinActiveDRAMClockChangeMargin;
193 double InitFillLevel;
194 double FinalFillMargin;
195 double FinalFillLevel;
196 double RemainingFillLevel;
197 double TFinalxFill;
200 // SOC Bounding Box Parameters
202 double SRExitTime;
203 double SREnterPlusExitTime;
204 double UrgentLatencyPixelDataOnly;
205 double UrgentLatencyPixelMixedWithVMData;
206 double UrgentLatencyVMDataOnly;
207 double UrgentLatency; // max of the above three
208 double WritebackLatency;
209 double PercentOfIdealDRAMFabricAndSDPPortBWReceivedAfterUrgLatencyPixelDataOnly; // Mode Support
210 double PercentOfIdealDRAMFabricAndSDPPortBWReceivedAfterUrgLatencyPixelMixedWithVMData; // Mode Support
211 double PercentOfIdealDRAMFabricAndSDPPortBWReceivedAfterUrgLatencyVMDataOnly; // Mode Support
212 double MaxAveragePercentOfIdealSDPPortBWDisplayCanUseInNormalSystemOperation; // Mode Support
213 double MaxAveragePercentOfIdealDRAMBWDisplayCanUseInNormalSystemOperation; // Mode Support
214 double NumberOfChannels;
215 double DRAMChannelWidth;
216 double FabricDatapathToDCNDataReturn;
217 double ReturnBusWidth;
218 double Downspreading;
219 double DISPCLKDPPCLKDSCCLKDownSpreading;
220 double DISPCLKDPPCLKVCOSpeed;
221 double RoundTripPingLatencyCycles;
222 double UrgentOutOfOrderReturnPerChannel;
223 double UrgentOutOfOrderReturnPerChannelPixelDataOnly;
224 double UrgentOutOfOrderReturnPerChannelPixelMixedWithVMData;
225 double UrgentOutOfOrderReturnPerChannelVMDataOnly;
226 unsigned int VMMPageSize;
227 double DRAMClockChangeLatency;
228 double XFCBusTransportTime;
229 bool UseUrgentBurstBandwidth;
230 double XFCXBUFLatencyTolerance;
233 // IP Parameters
235 unsigned int ROBBufferSizeInKByte;
236 double DETBufferSizeInKByte;
237 double DETBufferSizeInTime;
238 unsigned int DPPOutputBufferPixels;
239 unsigned int OPPOutputBufferLines;
240 unsigned int PixelChunkSizeInKByte;
241 double ReturnBW;
242 bool GPUVMEnable;
243 bool HostVMEnable;
244 unsigned int GPUVMMaxPageTableLevels;
245 unsigned int HostVMMaxPageTableLevels;
246 unsigned int HostVMCachedPageTableLevels;
247 unsigned int OverrideGPUVMPageTableLevels;
248 unsigned int OverrideHostVMPageTableLevels;
249 unsigned int MetaChunkSize;
250 unsigned int MinMetaChunkSizeBytes;
251 unsigned int WritebackChunkSize;
252 bool ODMCapability;
253 unsigned int NumberOfDSC;
254 unsigned int LineBufferSize;
255 unsigned int MaxLineBufferLines;
256 unsigned int WritebackInterfaceLumaBufferSize;
257 unsigned int WritebackInterfaceChromaBufferSize;
258 unsigned int WritebackChromaLineBufferWidth;
259 enum writeback_config WritebackConfiguration;
260 double MaxDCHUBToPSCLThroughput;
261 double MaxPSCLToLBThroughput;
262 unsigned int PTEBufferSizeInRequestsLuma;
263 unsigned int PTEBufferSizeInRequestsChroma;
264 double DISPCLKRampingMargin;
265 unsigned int MaxInterDCNTileRepeaters;
266 bool XFCSupported;
267 double XFCSlvChunkSize;
268 double XFCFillBWOverhead;
269 double XFCFillConstant;
270 double XFCTSlvVupdateOffset;
271 double XFCTSlvVupdateWidth;
272 double XFCTSlvVreadyOffset;
273 double DPPCLKDelaySubtotal;
274 double DPPCLKDelaySCL;
275 double DPPCLKDelaySCLLBOnly;
276 double DPPCLKDelayCNVCFormater;
277 double DPPCLKDelayCNVCCursor;
278 double DISPCLKDelaySubtotal;
279 bool ProgressiveToInterlaceUnitInOPP;
280 // Pipe/Plane Parameters
281 int VoltageLevel;
282 double FabricClock;
283 double DRAMSpeed;
284 double DISPCLK;
285 double SOCCLK;
286 double DCFCLK;
288 unsigned int NumberOfActivePlanes;
289 unsigned int NumberOfDSCSlices[DC__NUM_DPP__MAX];
290 unsigned int ViewportWidth[DC__NUM_DPP__MAX];
291 unsigned int ViewportHeight[DC__NUM_DPP__MAX];
292 unsigned int ViewportYStartY[DC__NUM_DPP__MAX];
293 unsigned int ViewportYStartC[DC__NUM_DPP__MAX];
294 unsigned int PitchY[DC__NUM_DPP__MAX];
295 unsigned int PitchC[DC__NUM_DPP__MAX];
296 double HRatio[DC__NUM_DPP__MAX];
297 double VRatio[DC__NUM_DPP__MAX];
298 unsigned int htaps[DC__NUM_DPP__MAX];
299 unsigned int vtaps[DC__NUM_DPP__MAX];
300 unsigned int HTAPsChroma[DC__NUM_DPP__MAX];
301 unsigned int VTAPsChroma[DC__NUM_DPP__MAX];
302 unsigned int HTotal[DC__NUM_DPP__MAX];
303 unsigned int VTotal[DC__NUM_DPP__MAX];
304 unsigned int VTotal_Max[DC__NUM_DPP__MAX];
305 unsigned int VTotal_Min[DC__NUM_DPP__MAX];
306 int DPPPerPlane[DC__NUM_DPP__MAX];
307 double PixelClock[DC__NUM_DPP__MAX];
308 double PixelClockBackEnd[DC__NUM_DPP__MAX];
309 bool DCCEnable[DC__NUM_DPP__MAX];
310 bool FECEnable[DC__NUM_DPP__MAX];
311 unsigned int DCCMetaPitchY[DC__NUM_DPP__MAX];
312 unsigned int DCCMetaPitchC[DC__NUM_DPP__MAX];
313 enum scan_direction_class SourceScan[DC__NUM_DPP__MAX];
314 enum source_format_class SourcePixelFormat[DC__NUM_DPP__MAX];
315 bool WritebackEnable[DC__NUM_DPP__MAX];
316 unsigned int ActiveWritebacksPerPlane[DC__NUM_DPP__MAX];
317 double WritebackDestinationWidth[DC__NUM_DPP__MAX];
318 double WritebackDestinationHeight[DC__NUM_DPP__MAX];
319 double WritebackSourceHeight[DC__NUM_DPP__MAX];
320 enum source_format_class WritebackPixelFormat[DC__NUM_DPP__MAX];
321 unsigned int WritebackLumaHTaps[DC__NUM_DPP__MAX];
322 unsigned int WritebackLumaVTaps[DC__NUM_DPP__MAX];
323 unsigned int WritebackChromaHTaps[DC__NUM_DPP__MAX];
324 unsigned int WritebackChromaVTaps[DC__NUM_DPP__MAX];
325 double WritebackHRatio[DC__NUM_DPP__MAX];
326 double WritebackVRatio[DC__NUM_DPP__MAX];
327 unsigned int HActive[DC__NUM_DPP__MAX];
328 unsigned int VActive[DC__NUM_DPP__MAX];
329 bool Interlace[DC__NUM_DPP__MAX];
330 enum dm_swizzle_mode SurfaceTiling[DC__NUM_DPP__MAX];
331 unsigned int ScalerRecoutWidth[DC__NUM_DPP__MAX];
332 bool DynamicMetadataEnable[DC__NUM_DPP__MAX];
333 int DynamicMetadataLinesBeforeActiveRequired[DC__NUM_DPP__MAX];
334 unsigned int DynamicMetadataTransmittedBytes[DC__NUM_DPP__MAX];
335 double DCCRate[DC__NUM_DPP__MAX];
336 double AverageDCCCompressionRate;
337 enum odm_combine_mode ODMCombineEnabled[DC__NUM_DPP__MAX];
338 double OutputBpp[DC__NUM_DPP__MAX];
339 bool DSCEnabled[DC__NUM_DPP__MAX];
340 unsigned int DSCInputBitPerComponent[DC__NUM_DPP__MAX];
341 enum output_format_class OutputFormat[DC__NUM_DPP__MAX];
342 enum output_encoder_class Output[DC__NUM_DPP__MAX];
343 unsigned int BlendingAndTiming[DC__NUM_DPP__MAX];
344 bool SynchronizedVBlank;
345 unsigned int NumberOfCursors[DC__NUM_DPP__MAX];
346 unsigned int CursorWidth[DC__NUM_DPP__MAX][DC__NUM_CURSOR__MAX];
347 unsigned int CursorBPP[DC__NUM_DPP__MAX][DC__NUM_CURSOR__MAX];
348 bool XFCEnabled[DC__NUM_DPP__MAX];
349 bool ScalerEnabled[DC__NUM_DPP__MAX];
351 // Intermediates/Informational
352 bool ImmediateFlipSupport;
353 double DETBufferSizeY[DC__NUM_DPP__MAX];
354 double DETBufferSizeC[DC__NUM_DPP__MAX];
355 unsigned int SwathHeightY[DC__NUM_DPP__MAX];
356 unsigned int SwathHeightC[DC__NUM_DPP__MAX];
357 unsigned int LBBitPerPixel[DC__NUM_DPP__MAX];
358 double LastPixelOfLineExtraWatermark;
359 double TotalDataReadBandwidth;
360 unsigned int TotalActiveWriteback;
361 unsigned int EffectiveLBLatencyHidingSourceLinesLuma;
362 unsigned int EffectiveLBLatencyHidingSourceLinesChroma;
363 double BandwidthAvailableForImmediateFlip;
364 unsigned int PrefetchMode[DC__VOLTAGE_STATES][2];
365 unsigned int PrefetchModePerState[DC__VOLTAGE_STATES][2];
366 unsigned int MinPrefetchMode;
367 unsigned int MaxPrefetchMode;
368 bool AnyLinesForVMOrRowTooLarge;
369 double MaxVStartup;
370 bool IgnoreViewportPositioning;
371 bool ErrorResult[DC__NUM_DPP__MAX];
373 // Calculated dml_ml->vba.Outputs
375 double DCFCLKDeepSleep;
376 double UrgentWatermark;
377 double UrgentExtraLatency;
378 double WritebackUrgentWatermark;
379 double StutterExitWatermark;
380 double StutterEnterPlusExitWatermark;
381 double DRAMClockChangeWatermark;
382 double WritebackDRAMClockChangeWatermark;
383 double StutterEfficiency;
384 double StutterEfficiencyNotIncludingVBlank;
385 double NonUrgentLatencyTolerance;
386 double MinActiveDRAMClockChangeLatencySupported;
388 // These are the clocks calcuated by the library but they are not actually
389 // used explicitly. They are fetched by tests and then possibly used. The
390 // ultimate values to use are the ones specified by the parameters to DML
391 double DISPCLK_calculated;
392 double DPPCLK_calculated[DC__NUM_DPP__MAX];
394 unsigned int VUpdateOffsetPix[DC__NUM_DPP__MAX];
395 double VUpdateWidthPix[DC__NUM_DPP__MAX];
396 double VReadyOffsetPix[DC__NUM_DPP__MAX];
398 unsigned int TotImmediateFlipBytes;
399 double TCalc;
401 display_e2e_pipe_params_st cache_pipes[DC__NUM_DPP__MAX];
402 unsigned int cache_num_pipes;
403 unsigned int pipe_plane[DC__NUM_DPP__MAX];
405 /* vba mode support */
406 /*inputs*/
407 bool SupportGFX7CompatibleTilingIn32bppAnd64bpp;
408 double MaxHSCLRatio;
409 double MaxVSCLRatio;
410 unsigned int MaxNumWriteback;
411 bool WritebackLumaAndChromaScalingSupported;
412 bool Cursor64BppSupport;
413 double DCFCLKPerState[DC__VOLTAGE_STATES];
414 double DCFCLKState[DC__VOLTAGE_STATES][2];
415 double FabricClockPerState[DC__VOLTAGE_STATES];
416 double SOCCLKPerState[DC__VOLTAGE_STATES];
417 double PHYCLKPerState[DC__VOLTAGE_STATES];
418 double DTBCLKPerState[DC__VOLTAGE_STATES];
419 double MaxDppclk[DC__VOLTAGE_STATES];
420 double MaxDSCCLK[DC__VOLTAGE_STATES];
421 double DRAMSpeedPerState[DC__VOLTAGE_STATES];
422 double MaxDispclk[DC__VOLTAGE_STATES];
423 int VoltageOverrideLevel;
425 /*outputs*/
426 bool ScaleRatioAndTapsSupport;
427 bool SourceFormatPixelAndScanSupport;
428 double TotalBandwidthConsumedGBytePerSecond;
429 bool DCCEnabledInAnyPlane;
430 bool WritebackLatencySupport;
431 bool WritebackModeSupport;
432 bool Writeback10bpc420Supported;
433 bool BandwidthSupport[DC__VOLTAGE_STATES];
434 unsigned int TotalNumberOfActiveWriteback;
435 double CriticalPoint;
436 double ReturnBWToDCNPerState;
437 bool IsErrorResult[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
438 bool prefetch_vm_bw_valid;
439 bool prefetch_row_bw_valid;
440 bool NumberOfOTGSupport;
441 bool NonsupportedDSCInputBPC;
442 bool WritebackScaleRatioAndTapsSupport;
443 bool CursorSupport;
444 bool PitchSupport;
445 enum dm_validation_status ValidationStatus[DC__VOLTAGE_STATES];
447 double WritebackLineBufferLumaBufferSize;
448 double WritebackLineBufferChromaBufferSize;
449 double WritebackMinHSCLRatio;
450 double WritebackMinVSCLRatio;
451 double WritebackMaxHSCLRatio;
452 double WritebackMaxVSCLRatio;
453 double WritebackMaxHSCLTaps;
454 double WritebackMaxVSCLTaps;
455 unsigned int MaxNumDPP;
456 unsigned int MaxNumOTG;
457 double CursorBufferSize;
458 double CursorChunkSize;
459 unsigned int Mode;
460 double OutputLinkDPLanes[DC__NUM_DPP__MAX];
461 double ForcedOutputLinkBPP[DC__NUM_DPP__MAX]; // Mode Support only
462 double ImmediateFlipBW[DC__NUM_DPP__MAX];
463 double MaxMaxVStartup[DC__VOLTAGE_STATES][2];
465 double WritebackLumaVExtra;
466 double WritebackChromaVExtra;
467 double WritebackRequiredDISPCLK;
468 double MaximumSwathWidthSupport;
469 double MaximumSwathWidthInDETBuffer;
470 double MaximumSwathWidthInLineBuffer;
471 double MaxDispclkRoundedDownToDFSGranularity;
472 double MaxDppclkRoundedDownToDFSGranularity;
473 double PlaneRequiredDISPCLKWithoutODMCombine;
474 double PlaneRequiredDISPCLKWithODMCombine;
475 double PlaneRequiredDISPCLK;
476 double TotalNumberOfActiveOTG;
477 double FECOverhead;
478 double EffectiveFECOverhead;
479 double Outbpp;
480 unsigned int OutbppDSC;
481 double TotalDSCUnitsRequired;
482 double bpp;
483 unsigned int slices;
484 double SwathWidthGranularityY;
485 double RoundedUpMaxSwathSizeBytesY;
486 double SwathWidthGranularityC;
487 double RoundedUpMaxSwathSizeBytesC;
488 double EffectiveDETLBLinesLuma;
489 double EffectiveDETLBLinesChroma;
490 double ProjectedDCFCLKDeepSleep[DC__VOLTAGE_STATES][2];
491 double PDEAndMetaPTEBytesPerFrameY;
492 double PDEAndMetaPTEBytesPerFrameC;
493 unsigned int MetaRowBytesY;
494 unsigned int MetaRowBytesC;
495 unsigned int DPTEBytesPerRowC;
496 unsigned int DPTEBytesPerRowY;
497 double ExtraLatency;
498 double TimeCalc;
499 double TWait;
500 double MaximumReadBandwidthWithPrefetch;
501 double MaximumReadBandwidthWithoutPrefetch;
502 double total_dcn_read_bw_with_flip;
503 double total_dcn_read_bw_with_flip_no_urgent_burst;
504 double FractionOfUrgentBandwidth;
505 double FractionOfUrgentBandwidthImmediateFlip; // Mode Support debugging output
507 /* ms locals */
508 double IdealSDPPortBandwidthPerState[DC__VOLTAGE_STATES][2];
509 unsigned int NoOfDPP[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
510 int NoOfDPPThisState[DC__NUM_DPP__MAX];
511 enum odm_combine_mode ODMCombineEnablePerState[DC__VOLTAGE_STATES][DC__NUM_DPP__MAX];
512 double SwathWidthYThisState[DC__NUM_DPP__MAX];
513 unsigned int SwathHeightCPerState[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
514 unsigned int SwathHeightYThisState[DC__NUM_DPP__MAX];
515 unsigned int SwathHeightCThisState[DC__NUM_DPP__MAX];
516 double VRatioPreY[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
517 double VRatioPreC[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
518 double RequiredPrefetchPixelDataBWLuma[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
519 double RequiredPrefetchPixelDataBWChroma[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
520 double RequiredDPPCLK[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
521 double RequiredDPPCLKThisState[DC__NUM_DPP__MAX];
522 bool PTEBufferSizeNotExceededY[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
523 bool PTEBufferSizeNotExceededC[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
524 bool BandwidthWithoutPrefetchSupported[DC__VOLTAGE_STATES][2];
525 bool PrefetchSupported[DC__VOLTAGE_STATES][2];
526 bool VRatioInPrefetchSupported[DC__VOLTAGE_STATES][2];
527 double RequiredDISPCLK[DC__VOLTAGE_STATES][2];
528 bool DISPCLK_DPPCLK_Support[DC__VOLTAGE_STATES][2];
529 bool TotalAvailablePipesSupport[DC__VOLTAGE_STATES][2];
530 unsigned int TotalNumberOfActiveDPP[DC__VOLTAGE_STATES][2];
531 unsigned int TotalNumberOfDCCActiveDPP[DC__VOLTAGE_STATES][2];
532 bool ModeSupport[DC__VOLTAGE_STATES][2];
533 double ReturnBWPerState[DC__VOLTAGE_STATES][2];
534 bool DIOSupport[DC__VOLTAGE_STATES];
535 bool NotEnoughDSCUnits[DC__VOLTAGE_STATES];
536 bool DSCCLKRequiredMoreThanSupported[DC__VOLTAGE_STATES];
537 bool DTBCLKRequiredMoreThanSupported[DC__VOLTAGE_STATES];
538 double UrgentRoundTripAndOutOfOrderLatencyPerState[DC__VOLTAGE_STATES];
539 bool ROBSupport[DC__VOLTAGE_STATES][2];
540 bool PTEBufferSizeNotExceeded[DC__VOLTAGE_STATES][2];
541 bool TotalVerticalActiveBandwidthSupport[DC__VOLTAGE_STATES][2];
542 double MaxTotalVerticalActiveAvailableBandwidth[DC__VOLTAGE_STATES][2];
543 double PrefetchBW[DC__NUM_DPP__MAX];
544 double PDEAndMetaPTEBytesPerFrame[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
545 double MetaRowBytes[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
546 double DPTEBytesPerRow[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
547 double PrefetchLinesY[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
548 double PrefetchLinesC[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
549 unsigned int MaxNumSwY[DC__NUM_DPP__MAX];
550 unsigned int MaxNumSwC[DC__NUM_DPP__MAX];
551 double PrefillY[DC__NUM_DPP__MAX];
552 double PrefillC[DC__NUM_DPP__MAX];
553 double LineTimesForPrefetch[DC__NUM_DPP__MAX];
554 double LinesForMetaPTE[DC__NUM_DPP__MAX];
555 double LinesForMetaAndDPTERow[DC__NUM_DPP__MAX];
556 double MinDPPCLKUsingSingleDPP[DC__NUM_DPP__MAX];
557 double SwathWidthYSingleDPP[DC__NUM_DPP__MAX];
558 double BytePerPixelInDETY[DC__NUM_DPP__MAX];
559 double BytePerPixelInDETC[DC__NUM_DPP__MAX];
560 bool RequiresDSC[DC__VOLTAGE_STATES][DC__NUM_DPP__MAX];
561 unsigned int NumberOfDSCSlice[DC__VOLTAGE_STATES][DC__NUM_DPP__MAX];
562 double RequiresFEC[DC__VOLTAGE_STATES][DC__NUM_DPP__MAX];
563 double OutputBppPerState[DC__VOLTAGE_STATES][DC__NUM_DPP__MAX];
564 double DSCDelayPerState[DC__VOLTAGE_STATES][DC__NUM_DPP__MAX];
565 bool ViewportSizeSupport[DC__VOLTAGE_STATES][2];
566 unsigned int Read256BlockHeightY[DC__NUM_DPP__MAX];
567 unsigned int Read256BlockWidthY[DC__NUM_DPP__MAX];
568 unsigned int Read256BlockHeightC[DC__NUM_DPP__MAX];
569 unsigned int Read256BlockWidthC[DC__NUM_DPP__MAX];
570 double MaxSwathHeightY[DC__NUM_DPP__MAX];
571 double MaxSwathHeightC[DC__NUM_DPP__MAX];
572 double MinSwathHeightY[DC__NUM_DPP__MAX];
573 double MinSwathHeightC[DC__NUM_DPP__MAX];
574 double ReadBandwidthLuma[DC__NUM_DPP__MAX];
575 double ReadBandwidthChroma[DC__NUM_DPP__MAX];
576 double ReadBandwidth[DC__NUM_DPP__MAX];
577 double WriteBandwidth[DC__NUM_DPP__MAX];
578 double PSCL_FACTOR[DC__NUM_DPP__MAX];
579 double PSCL_FACTOR_CHROMA[DC__NUM_DPP__MAX];
580 double MaximumVStartup[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
581 unsigned int MacroTileWidthY[DC__NUM_DPP__MAX];
582 unsigned int MacroTileWidthC[DC__NUM_DPP__MAX];
583 double AlignedDCCMetaPitch[DC__NUM_DPP__MAX];
584 double AlignedYPitch[DC__NUM_DPP__MAX];
585 double AlignedCPitch[DC__NUM_DPP__MAX];
586 double MaximumSwathWidth[DC__NUM_DPP__MAX];
587 double cursor_bw[DC__NUM_DPP__MAX];
588 double cursor_bw_pre[DC__NUM_DPP__MAX];
589 double Tno_bw[DC__NUM_DPP__MAX];
590 double prefetch_vmrow_bw[DC__NUM_DPP__MAX];
591 double DestinationLinesToRequestVMInImmediateFlip[DC__NUM_DPP__MAX];
592 double DestinationLinesToRequestRowInImmediateFlip[DC__NUM_DPP__MAX];
593 double final_flip_bw[DC__NUM_DPP__MAX];
594 bool ImmediateFlipSupportedForState[DC__VOLTAGE_STATES][2];
595 double WritebackDelay[DC__VOLTAGE_STATES][DC__NUM_DPP__MAX];
596 unsigned int vm_group_bytes[DC__NUM_DPP__MAX];
597 unsigned int dpte_group_bytes[DC__NUM_DPP__MAX];
598 unsigned int dpte_row_height[DC__NUM_DPP__MAX];
599 unsigned int meta_req_height[DC__NUM_DPP__MAX];
600 unsigned int meta_req_width[DC__NUM_DPP__MAX];
601 unsigned int meta_row_height[DC__NUM_DPP__MAX];
602 unsigned int meta_row_width[DC__NUM_DPP__MAX];
603 unsigned int dpte_row_height_chroma[DC__NUM_DPP__MAX];
604 unsigned int meta_req_height_chroma[DC__NUM_DPP__MAX];
605 unsigned int meta_req_width_chroma[DC__NUM_DPP__MAX];
606 unsigned int meta_row_height_chroma[DC__NUM_DPP__MAX];
607 unsigned int meta_row_width_chroma[DC__NUM_DPP__MAX];
608 bool ImmediateFlipSupportedForPipe[DC__NUM_DPP__MAX];
609 double meta_row_bw[DC__NUM_DPP__MAX];
610 double dpte_row_bw[DC__NUM_DPP__MAX];
611 double DisplayPipeLineDeliveryTimeLuma[DC__NUM_DPP__MAX]; // WM
612 double DisplayPipeLineDeliveryTimeChroma[DC__NUM_DPP__MAX]; // WM
613 double DisplayPipeRequestDeliveryTimeLuma[DC__NUM_DPP__MAX];
614 double DisplayPipeRequestDeliveryTimeChroma[DC__NUM_DPP__MAX];
615 enum clock_change_support DRAMClockChangeSupport[DC__VOLTAGE_STATES][2];
616 double UrgentBurstFactorCursor[DC__NUM_DPP__MAX];
617 double UrgentBurstFactorCursorPre[DC__NUM_DPP__MAX];
618 double UrgentBurstFactorLuma[DC__NUM_DPP__MAX];
619 double UrgentBurstFactorLumaPre[DC__NUM_DPP__MAX];
620 double UrgentBurstFactorChroma[DC__NUM_DPP__MAX];
621 double UrgentBurstFactorChromaPre[DC__NUM_DPP__MAX];
624 bool MPCCombine[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
625 double SwathWidthCSingleDPP[DC__NUM_DPP__MAX];
626 double MaximumSwathWidthInLineBufferLuma;
627 double MaximumSwathWidthInLineBufferChroma;
628 double MaximumSwathWidthLuma[DC__NUM_DPP__MAX];
629 double MaximumSwathWidthChroma[DC__NUM_DPP__MAX];
630 enum odm_combine_mode odm_combine_dummy[DC__NUM_DPP__MAX];
631 double dummy1[DC__NUM_DPP__MAX];
632 double dummy2[DC__NUM_DPP__MAX];
633 double dummy3[DC__NUM_DPP__MAX];
634 double dummy4[DC__NUM_DPP__MAX];
635 double dummy5;
636 double dummy6;
637 double dummy7[DC__NUM_DPP__MAX];
638 double dummy8[DC__NUM_DPP__MAX];
639 double dummy13[DC__NUM_DPP__MAX];
640 unsigned int dummyinteger1ms[DC__NUM_DPP__MAX];
641 double dummyinteger2ms[DC__NUM_DPP__MAX];
642 unsigned int dummyinteger3[DC__NUM_DPP__MAX];
643 unsigned int dummyinteger4[DC__NUM_DPP__MAX];
644 unsigned int dummyinteger5;
645 unsigned int dummyinteger6;
646 unsigned int dummyinteger7;
647 unsigned int dummyinteger8;
648 unsigned int dummyinteger9;
649 unsigned int dummyinteger10;
650 unsigned int dummyinteger11;
651 unsigned int dummyinteger12;
652 unsigned int dummyinteger30;
653 unsigned int dummyinteger31;
654 unsigned int dummyinteger32;
655 unsigned int dummyintegerarr1[DC__NUM_DPP__MAX];
656 unsigned int dummyintegerarr2[DC__NUM_DPP__MAX];
657 unsigned int dummyintegerarr3[DC__NUM_DPP__MAX];
658 unsigned int dummyintegerarr4[DC__NUM_DPP__MAX];
659 bool dummysinglestring;
660 bool SingleDPPViewportSizeSupportPerPlane[DC__NUM_DPP__MAX];
661 double PlaneRequiredDISPCLKWithODMCombine2To1;
662 double PlaneRequiredDISPCLKWithODMCombine4To1;
663 unsigned int TotalNumberOfSingleDPPPlanes[DC__VOLTAGE_STATES][2];
664 bool LinkDSCEnable;
665 bool ODMCombine4To1SupportCheckOK[DC__VOLTAGE_STATES];
666 enum odm_combine_mode ODMCombineEnableThisState[DC__NUM_DPP__MAX];
667 double SwathWidthCThisState[DC__NUM_DPP__MAX];
668 bool ViewportSizeSupportPerPlane[DC__NUM_DPP__MAX];
669 double AlignedDCCMetaPitchY[DC__NUM_DPP__MAX];
670 double AlignedDCCMetaPitchC[DC__NUM_DPP__MAX];
672 unsigned int NotEnoughUrgentLatencyHiding;
673 unsigned int NotEnoughUrgentLatencyHidingPre;
674 int PTEBufferSizeInRequestsForLuma;
675 int PTEBufferSizeInRequestsForChroma;
677 // Missing from VBA
678 int dpte_group_bytes_chroma;
679 unsigned int vm_group_bytes_chroma;
680 double dst_x_after_scaler;
681 double dst_y_after_scaler;
682 unsigned int VStartupRequiredWhenNotEnoughTimeForDynamicMetadata;
684 /* perf locals*/
685 double PrefetchBandwidth[DC__NUM_DPP__MAX];
686 double VInitPreFillY[DC__NUM_DPP__MAX];
687 double VInitPreFillC[DC__NUM_DPP__MAX];
688 unsigned int MaxNumSwathY[DC__NUM_DPP__MAX];
689 unsigned int MaxNumSwathC[DC__NUM_DPP__MAX];
690 unsigned int VStartup[DC__NUM_DPP__MAX];
691 double DSTYAfterScaler[DC__NUM_DPP__MAX];
692 double DSTXAfterScaler[DC__NUM_DPP__MAX];
693 bool AllowDRAMClockChangeDuringVBlank[DC__NUM_DPP__MAX];
694 bool AllowDRAMSelfRefreshDuringVBlank[DC__NUM_DPP__MAX];
695 double VRatioPrefetchY[DC__NUM_DPP__MAX];
696 double VRatioPrefetchC[DC__NUM_DPP__MAX];
697 double DestinationLinesForPrefetch[DC__NUM_DPP__MAX];
698 double DestinationLinesToRequestVMInVBlank[DC__NUM_DPP__MAX];
699 double DestinationLinesToRequestRowInVBlank[DC__NUM_DPP__MAX];
700 double MinTTUVBlank[DC__NUM_DPP__MAX];
701 double BytePerPixelDETY[DC__NUM_DPP__MAX];
702 double BytePerPixelDETC[DC__NUM_DPP__MAX];
703 double SwathWidthY[DC__NUM_DPP__MAX];
704 double SwathWidthSingleDPPY[DC__NUM_DPP__MAX];
705 double CursorRequestDeliveryTime[DC__NUM_DPP__MAX];
706 double CursorRequestDeliveryTimePrefetch[DC__NUM_DPP__MAX];
707 double ReadBandwidthPlaneLuma[DC__NUM_DPP__MAX];
708 double ReadBandwidthPlaneChroma[DC__NUM_DPP__MAX];
709 double DisplayPipeLineDeliveryTimeLumaPrefetch[DC__NUM_DPP__MAX];
710 double DisplayPipeLineDeliveryTimeChromaPrefetch[DC__NUM_DPP__MAX];
711 double DisplayPipeRequestDeliveryTimeLumaPrefetch[DC__NUM_DPP__MAX];
712 double DisplayPipeRequestDeliveryTimeChromaPrefetch[DC__NUM_DPP__MAX];
713 double PixelPTEBytesPerRow[DC__NUM_DPP__MAX];
714 double PDEAndMetaPTEBytesFrame[DC__NUM_DPP__MAX];
715 double MetaRowByte[DC__NUM_DPP__MAX];
716 double PrefetchSourceLinesY[DC__NUM_DPP__MAX];
717 double RequiredPrefetchPixDataBWLuma[DC__NUM_DPP__MAX];
718 double RequiredPrefetchPixDataBWChroma[DC__NUM_DPP__MAX];
719 double PrefetchSourceLinesC[DC__NUM_DPP__MAX];
720 double PSCL_THROUGHPUT_LUMA[DC__NUM_DPP__MAX];
721 double PSCL_THROUGHPUT_CHROMA[DC__NUM_DPP__MAX];
722 double DSCCLK_calculated[DC__NUM_DPP__MAX];
723 unsigned int DSCDelay[DC__NUM_DPP__MAX];
724 unsigned int MaxVStartupLines[DC__NUM_DPP__MAX];
725 double DPPCLKUsingSingleDPP[DC__NUM_DPP__MAX];
726 double DPPCLK[DC__NUM_DPP__MAX];
727 unsigned int DCCYMaxUncompressedBlock[DC__NUM_DPP__MAX];
728 unsigned int DCCYMaxCompressedBlock[DC__NUM_DPP__MAX];
729 unsigned int DCCYIndependent64ByteBlock[DC__NUM_DPP__MAX];
730 double MaximumDCCCompressionYSurface[DC__NUM_DPP__MAX];
731 unsigned int BlockHeight256BytesY[DC__NUM_DPP__MAX];
732 unsigned int BlockHeight256BytesC[DC__NUM_DPP__MAX];
733 unsigned int BlockWidth256BytesY[DC__NUM_DPP__MAX];
734 unsigned int BlockWidth256BytesC[DC__NUM_DPP__MAX];
735 double XFCSlaveVUpdateOffset[DC__NUM_DPP__MAX];
736 double XFCSlaveVupdateWidth[DC__NUM_DPP__MAX];
737 double XFCSlaveVReadyOffset[DC__NUM_DPP__MAX];
738 double XFCTransferDelay[DC__NUM_DPP__MAX];
739 double XFCPrechargeDelay[DC__NUM_DPP__MAX];
740 double XFCRemoteSurfaceFlipLatency[DC__NUM_DPP__MAX];
741 double XFCPrefetchMargin[DC__NUM_DPP__MAX];
742 unsigned int dpte_row_width_luma_ub[DC__NUM_DPP__MAX];
743 unsigned int dpte_row_width_chroma_ub[DC__NUM_DPP__MAX];
744 double FullDETBufferingTimeY[DC__NUM_DPP__MAX]; // WM
745 double FullDETBufferingTimeC[DC__NUM_DPP__MAX]; // WM
746 double DST_Y_PER_PTE_ROW_NOM_L[DC__NUM_DPP__MAX];
747 double DST_Y_PER_PTE_ROW_NOM_C[DC__NUM_DPP__MAX];
748 double DST_Y_PER_META_ROW_NOM_L[DC__NUM_DPP__MAX];
749 double TimePerMetaChunkNominal[DC__NUM_DPP__MAX];
750 double TimePerMetaChunkVBlank[DC__NUM_DPP__MAX];
751 double TimePerMetaChunkFlip[DC__NUM_DPP__MAX];
752 unsigned int swath_width_luma_ub[DC__NUM_DPP__MAX];
753 unsigned int swath_width_chroma_ub[DC__NUM_DPP__MAX];
754 unsigned int PixelPTEReqWidthY[DC__NUM_DPP__MAX];
755 unsigned int PixelPTEReqHeightY[DC__NUM_DPP__MAX];
756 unsigned int PTERequestSizeY[DC__NUM_DPP__MAX];
757 unsigned int PixelPTEReqWidthC[DC__NUM_DPP__MAX];
758 unsigned int PixelPTEReqHeightC[DC__NUM_DPP__MAX];
759 unsigned int PTERequestSizeC[DC__NUM_DPP__MAX];
760 double time_per_pte_group_nom_luma[DC__NUM_DPP__MAX];
761 double time_per_pte_group_nom_chroma[DC__NUM_DPP__MAX];
762 double time_per_pte_group_vblank_luma[DC__NUM_DPP__MAX];
763 double time_per_pte_group_vblank_chroma[DC__NUM_DPP__MAX];
764 double time_per_pte_group_flip_luma[DC__NUM_DPP__MAX];
765 double time_per_pte_group_flip_chroma[DC__NUM_DPP__MAX];
766 double TimePerVMGroupVBlank[DC__NUM_DPP__MAX];
767 double TimePerVMGroupFlip[DC__NUM_DPP__MAX];
768 double TimePerVMRequestVBlank[DC__NUM_DPP__MAX];
769 double TimePerVMRequestFlip[DC__NUM_DPP__MAX];
770 unsigned int dpde0_bytes_per_frame_ub_l[DC__NUM_DPP__MAX];
771 unsigned int meta_pte_bytes_per_frame_ub_l[DC__NUM_DPP__MAX];
772 unsigned int dpde0_bytes_per_frame_ub_c[DC__NUM_DPP__MAX];
773 unsigned int meta_pte_bytes_per_frame_ub_c[DC__NUM_DPP__MAX];
774 double LinesToFinishSwathTransferStutterCriticalPlane;
775 unsigned int BytePerPixelYCriticalPlane;
776 double SwathWidthYCriticalPlane;
777 double LinesInDETY[DC__NUM_DPP__MAX];
778 double LinesInDETYRoundedDownToSwath[DC__NUM_DPP__MAX];
780 double SwathWidthSingleDPPC[DC__NUM_DPP__MAX];
781 double SwathWidthC[DC__NUM_DPP__MAX];
782 unsigned int BytePerPixelY[DC__NUM_DPP__MAX];
783 unsigned int BytePerPixelC[DC__NUM_DPP__MAX];
784 unsigned int dummyinteger1;
785 unsigned int dummyinteger2;
786 double FinalDRAMClockChangeLatency;
787 double Tdmdl_vm[DC__NUM_DPP__MAX];
788 double Tdmdl[DC__NUM_DPP__MAX];
789 double TSetup[DC__NUM_DPP__MAX];
790 unsigned int ThisVStartup;
791 bool WritebackAllowDRAMClockChangeEndPosition[DC__NUM_DPP__MAX];
792 double DST_Y_PER_META_ROW_NOM_C[DC__NUM_DPP__MAX];
793 double TimePerChromaMetaChunkNominal[DC__NUM_DPP__MAX];
794 double TimePerChromaMetaChunkVBlank[DC__NUM_DPP__MAX];
795 double TimePerChromaMetaChunkFlip[DC__NUM_DPP__MAX];
796 unsigned int DCCCMaxUncompressedBlock[DC__NUM_DPP__MAX];
797 unsigned int DCCCMaxCompressedBlock[DC__NUM_DPP__MAX];
798 unsigned int DCCCIndependent64ByteBlock[DC__NUM_DPP__MAX];
799 double VStartupMargin;
800 bool NotEnoughTimeForDynamicMetadata[DC__NUM_DPP__MAX];
802 /* Missing from VBA */
803 unsigned int MaximumMaxVStartupLines;
804 double FabricAndDRAMBandwidth;
805 double LinesInDETLuma;
806 double LinesInDETChroma;
807 unsigned int ImmediateFlipBytes[DC__NUM_DPP__MAX];
808 unsigned int LinesInDETC[DC__NUM_DPP__MAX];
809 unsigned int LinesInDETCRoundedDownToSwath[DC__NUM_DPP__MAX];
810 double UrgentLatencySupportUsPerState[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
811 double UrgentLatencySupportUs[DC__NUM_DPP__MAX];
812 double FabricAndDRAMBandwidthPerState[DC__VOLTAGE_STATES];
813 bool UrgentLatencySupport[DC__VOLTAGE_STATES][2];
814 unsigned int SwathWidthYPerState[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
815 unsigned int SwathHeightYPerState[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
816 double qual_row_bw[DC__NUM_DPP__MAX];
817 double prefetch_row_bw[DC__NUM_DPP__MAX];
818 double prefetch_vm_bw[DC__NUM_DPP__MAX];
820 double PTEGroupSize;
821 unsigned int PDEProcessingBufIn64KBReqs;
823 double MaxTotalVActiveRDBandwidth;
824 bool DoUrgentLatencyAdjustment;
825 double UrgentLatencyAdjustmentFabricClockComponent;
826 double UrgentLatencyAdjustmentFabricClockReference;
827 double MinUrgentLatencySupportUs;
828 double MinFullDETBufferingTime;
829 double AverageReadBandwidthGBytePerSecond;
830 bool FirstMainPlane;
832 unsigned int ViewportWidthChroma[DC__NUM_DPP__MAX];
833 unsigned int ViewportHeightChroma[DC__NUM_DPP__MAX];
834 double HRatioChroma[DC__NUM_DPP__MAX];
835 double VRatioChroma[DC__NUM_DPP__MAX];
836 int WritebackSourceWidth[DC__NUM_DPP__MAX];
838 bool ModeIsSupported;
839 bool ODMCombine4To1Supported;
841 unsigned int SurfaceWidthY[DC__NUM_DPP__MAX];
842 unsigned int SurfaceWidthC[DC__NUM_DPP__MAX];
843 unsigned int SurfaceHeightY[DC__NUM_DPP__MAX];
844 unsigned int SurfaceHeightC[DC__NUM_DPP__MAX];
845 unsigned int WritebackHTaps[DC__NUM_DPP__MAX];
846 unsigned int WritebackVTaps[DC__NUM_DPP__MAX];
847 bool DSCEnable[DC__NUM_DPP__MAX];
849 double DRAMClockChangeLatencyOverride;
851 double GPUVMMinPageSize;
852 double HostVMMinPageSize;
854 bool MPCCombineEnable[DC__NUM_DPP__MAX];
855 unsigned int HostVMMaxNonCachedPageTableLevels;
856 bool DynamicMetadataVMEnabled;
857 double WritebackInterfaceBufferSize;
858 double WritebackLineBufferSize;
860 double DCCRateLuma[DC__NUM_DPP__MAX];
861 double DCCRateChroma[DC__NUM_DPP__MAX];
863 double PHYCLKD18PerState[DC__VOLTAGE_STATES];
865 bool WritebackSupportInterleaveAndUsingWholeBufferForASingleStream;
866 bool NumberOfHDMIFRLSupport;
867 unsigned int MaxNumHDMIFRLOutputs;
868 int AudioSampleRate[DC__NUM_DPP__MAX];
869 int AudioSampleLayout[DC__NUM_DPP__MAX];
871 int PercentMarginOverMinimumRequiredDCFCLK;
872 bool DynamicMetadataSupported[DC__VOLTAGE_STATES][2];
873 enum immediate_flip_requirement ImmediateFlipRequirement;
874 double DETBufferSizeYThisState[DC__NUM_DPP__MAX];
875 double DETBufferSizeCThisState[DC__NUM_DPP__MAX];
876 bool NoUrgentLatencyHiding[DC__NUM_DPP__MAX];
877 bool NoUrgentLatencyHidingPre[DC__NUM_DPP__MAX];
878 int swath_width_luma_ub_this_state[DC__NUM_DPP__MAX];
879 int swath_width_chroma_ub_this_state[DC__NUM_DPP__MAX];
880 double UrgLatency[DC__VOLTAGE_STATES];
881 double VActiveCursorBandwidth[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
882 double VActivePixelBandwidth[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
883 bool NoTimeForPrefetch[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
884 bool NoTimeForDynamicMetadata[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
885 double dpte_row_bandwidth[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
886 double meta_row_bandwidth[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
887 double DETBufferSizeYAllStates[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
888 double DETBufferSizeCAllStates[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
889 int swath_width_luma_ub_all_states[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
890 int swath_width_chroma_ub_all_states[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
891 bool NotUrgentLatencyHiding[DC__VOLTAGE_STATES][2];
892 unsigned int SwathHeightYAllStates[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
893 unsigned int SwathHeightCAllStates[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
894 unsigned int SwathWidthYAllStates[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
895 unsigned int SwathWidthCAllStates[DC__VOLTAGE_STATES][2][DC__NUM_DPP__MAX];
896 double TotalDPTERowBandwidth[DC__VOLTAGE_STATES][2];
897 double TotalMetaRowBandwidth[DC__VOLTAGE_STATES][2];
898 double TotalVActiveCursorBandwidth[DC__VOLTAGE_STATES][2];
899 double TotalVActivePixelBandwidth[DC__VOLTAGE_STATES][2];
900 double WritebackDelayTime[DC__NUM_DPP__MAX];
901 unsigned int DCCYIndependentBlock[DC__NUM_DPP__MAX];
902 unsigned int DCCCIndependentBlock[DC__NUM_DPP__MAX];
903 unsigned int dummyinteger15;
904 unsigned int dummyinteger16;
905 unsigned int dummyinteger17;
906 unsigned int dummyinteger18;
907 unsigned int dummyinteger19;
908 unsigned int dummyinteger20;
909 unsigned int dummyinteger21;
910 unsigned int dummyinteger22;
911 unsigned int dummyinteger23;
912 unsigned int dummyinteger24;
913 unsigned int dummyinteger25;
914 unsigned int dummyinteger26;
915 unsigned int dummyinteger27;
916 unsigned int dummyinteger28;
917 unsigned int dummyinteger29;
918 bool dummystring[DC__NUM_DPP__MAX];
919 double BPP;
920 enum odm_combine_policy ODMCombinePolicy;
921 bool UseMinimumRequiredDCFCLK;
922 bool ClampMinDCFCLK;
923 bool AllowDramClockChangeOneDisplayVactive;
927 bool CalculateMinAndMaxPrefetchMode(
928 enum self_refresh_affinity AllowDRAMSelfRefreshOrDRAMClockChangeInVblank,
929 unsigned int *MinPrefetchMode,
930 unsigned int *MaxPrefetchMode);
932 double CalculateWriteBackDISPCLK(
933 enum source_format_class WritebackPixelFormat,
934 double PixelClock,
935 double WritebackHRatio,
936 double WritebackVRatio,
937 unsigned int WritebackLumaHTaps,
938 unsigned int WritebackLumaVTaps,
939 unsigned int WritebackChromaHTaps,
940 unsigned int WritebackChromaVTaps,
941 double WritebackDestinationWidth,
942 unsigned int HTotal,
943 unsigned int WritebackChromaLineBufferWidth);
945 #endif /* _DML2_DISPLAY_MODE_VBA_H_ */