hv_cal_HdmiInc.h 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341
  1. /**
  2. * @file drv_hdmi_inc.h
  3. * @brief HDMI RX driver layer interface.
  4. * @verbatim
  5. * ==============================================================================
  6. * ##### How to use this driver #####
  7. * ==============================================================================
  8. * (+) Use HS_HAL_WDT_Start(...) to start the wdt immediately.
  9. * (+) Use HS_HAL_WDT_Stop(...) to stop the wdt immediately.
  10. * (+) Use HS_HAL_WDT_Feed(...) to feed the watchdog and it will restart the counter immediately.
  11. * @endverbatim
  12. *
  13. * @author HiView SoC Software Team
  14. * @version 0.0.1
  15. * @date 2022-08-22
  16. */
  17. #ifndef __HV_CAL_HDMIINC_H__
  18. #define __HV_CAL_HDMIINC_H__
  19. #include "Common/hv_comm_DataType.h"
  20. #include "hv_cal_HdmiRx.h"
  21. #include "hv_comm_Define.h"
  22. #include "ProjectConfig.h"
  23. typedef struct _HdmiRxLaneCED
  24. {
  25. USHORT16 usLane0CED;
  26. USHORT16 usLane1CED;
  27. USHORT16 usLane2CED;
  28. USHORT16 usLane3CED;
  29. }HdmiRxLaneCED;
  30. typedef struct _CalAmdSpdInfoParam
  31. {
  32. BOOL bFreeSyncSupported;
  33. BOOL bFreeSyncEnabled; /* Sync Should Prapared to Entered FreeSync */
  34. BOOL bFreeSyncActive; /* Entered the Frame changed status */
  35. BOOL bNativeColorSpaceActive;
  36. BOOL bLocalDimmingDisabled; /* 1: disabled Local Dimming. 0: enable the Local Dimming */
  37. BOOL bGamma26EOTFActive;
  38. BOOL bGamma22EOTFActive;
  39. BOOL bBT709EOTFActive;
  40. BOOL bSRGBEOTFActive;
  41. UCHAR8 ucVersion;
  42. UCHAR8 ucFreeSyncMinReFresh;
  43. UCHAR8 ucFreeSyncMaxReFresh;
  44. UCHAR8 ucBrightneesControl;
  45. }CalAmdSpdInfoParam;
  46. typedef struct _CalNvidiaVendSpecInfoParam
  47. {
  48. UCHAR8 ucModeName[HV_VENDOR_DESCRIP_LEN];
  49. SouceInfoType eSourceInfoCode;
  50. }CalNvidiaVendSpecInfoParam;
  51. typedef struct _CalVRRMDContent
  52. {
  53. VfrVRRType eVfrVrrType;
  54. BOOL bVRREnable; /* Including All VfrVRRType: bVRRGamingEnable and bVRRQMSEnable */
  55. UCHAR8 ucFVAFactorM1; /* VfrVRRType_HDMIMDGamingFVA Only */
  56. UCHAR8 ucBase_Vfront;
  57. UCHAR8 ucNextTFR; /* VfrVRRType_HDMIMDQMS Only */
  58. USHORT16 usBaseRefreshRate;
  59. }CalVRRMDContent;
  60. typedef struct _CalVRRInfoParam
  61. {
  62. BOOL bVRREnable; /* HV_TRUE:Source Entered VRR; HV_HV_FALSE:Source Out Of VRR */
  63. VendorType eVendor; /* Type == VendorType_UnKnown±íʾ·ÇVRR±¨ÎÄ */
  64. union
  65. {
  66. CalAmdSpdInfoParam stAmdSpdInfPara;
  67. CalNvidiaVendSpecInfoParam stNvidiaVSIPara;
  68. CalVRRMDContent stCommVRRinMD; /* HF-VRR with EMP */
  69. } uvsi;
  70. }CalVRRInfoParam;
  71. typedef struct _CalVideoTimingParam
  72. {
  73. USHORT16 usHTotal;
  74. USHORT16 usHFProch;
  75. USHORT16 usHSyncW;
  76. USHORT16 usHBProch;
  77. USHORT16 usHActive;
  78. USHORT16 usHPol;
  79. USHORT16 usVTotal;
  80. USHORT16 usVFProch;
  81. USHORT16 usVSyncW;
  82. USHORT16 usVBProch;
  83. USHORT16 usVActive;
  84. USHORT16 usVPol;
  85. USHORT16 usFrameRate;
  86. BOOL bInterlacedMode; /* Interlace mode or not */
  87. BOOL bIsEnterALLM; /* ALLM Mode Open or Closed */
  88. BOOL bIsNoSignal; /* Ture:表示HDMI未解析出信号,无法SyncOK ,提示"No Signal";
  89. False:表示HDMI可以正确识别信号,但是无法解析出Timing 及关键参数 AVI etc,提示"Not Support".
  90. Only 返回 HV_FAILURE 时候该字段有意义 */
  91. UINT32 uiFreqKHz; /* RX Received Pixel Clock KHz */
  92. UINT32 uiHFreqHz; /*horizontal frequency*/
  93. UINT32 uiRxDpllSetFreqKHz; /* RX dpll set Pixel Clock KHz: 0表示未配置,非0表示已经配置 */
  94. FLOAT32 fFrameRate; /* Detail of the Frame rate Detected */
  95. }CalVideoTimingParam;
  96. #define MAX_PACKET_DATA_SIZE 28
  97. typedef struct _PacketInfo
  98. {
  99. UCHAR8 ucVersion;
  100. UCHAR8 ucLegth;
  101. UCHAR8 ucData[MAX_PACKET_DATA_SIZE];
  102. }PacketInfo;
  103. typedef struct _CalVideoColorParam
  104. {
  105. ColorFormatType eClrFormat;
  106. ColorSpaceType eClrSpace;
  107. ColorDepthType eClrDepth;
  108. ColorRangeType eClrRange;
  109. CorlorContentType eContent;
  110. UCHAR8 ucPixelRepe;
  111. }CalVideoColorParam;
  112. typedef struct _CalAudioPara
  113. {
  114. AudioSampleRate enSampleRate;
  115. AudioSampleDepth enSampleDepth;
  116. AudioCodingType enCodingType;
  117. BOOL bAudClkStable;
  118. UCHAR8 ucChnlCnt;
  119. UINT32 uiCtsValue;
  120. UINT32 uiNValue;
  121. }CalAudioPara;
  122. typedef struct _CalHDRParam
  123. {
  124. HDREOTF xType;
  125. UCHAR8 ucMetaID;
  126. USHORT16 usPrimX0;
  127. USHORT16 usPrimY0;
  128. USHORT16 usPrimX1;
  129. USHORT16 usPrimY1;
  130. USHORT16 usPrimX2;
  131. USHORT16 usPrimY2;
  132. USHORT16 usWhtX;
  133. USHORT16 usWhtY;
  134. USHORT16 usMaxLum;
  135. USHORT16 usMinLum;
  136. USHORT16 usMaxCntn;
  137. USHORT16 usMaxFrmAvg;
  138. }CalHDRParam;
  139. /**
  140. * @brief Init the HDMI Interrupt At Beginning.
  141. * @param[in] ucPortIndex used for the HDMI RX.
  142. * @return 0: Success or 1: Fail.
  143. */
  144. Status Hv_Cal_HdmiRx_InterruptInitEvent(UCHAR8 ucPortIndex);
  145. /**
  146. * @brief Clear the HDMI Interrupt without any Event report.
  147. * @param[in] ucPortIndex used for the HDMI RX.
  148. * @param[in] pstHdmiIntRxStatus used for the Default Opened Interrupt Value.
  149. * @return 0: Success or 1: Fail.
  150. */
  151. Status Hv_Cal_HdmiRx_InterruptClearEvent(UCHAR8 ucPortIndex, HdmiRxIntStatus *pstHdmiIntRxStatus);
  152. /**
  153. * @brief HDMI Add InterruptEvent
  154. * @param[in] ucPortIndex used for the HDMI RX.
  155. * @return Status with 0: Success, 1: Failure.
  156. */
  157. Status Hv_Cal_HdmiRx_AddInterruptEvent(UCHAR8 ucPortIndex, const HdmiRxIntStatus *pstHdmiIntRxStatus);
  158. /**
  159. * @brief HDMI Remove InterruptEvent
  160. * @param[in] ucPortIndex used for the HDMI RX.
  161. * @return Status with 0: Success, 1: Failure.
  162. */
  163. Status Hv_Cal_HdmiRx_RemoveInterruptEvent(UCHAR8 ucPortIndex, const HdmiRxIntStatus *pstHdmiIntRxStatus);
  164. /**
  165. * @brief Init +5V/cable connect status detect.
  166. * @param[in]: Port Index of the cable
  167. * @return Status of this Function.
  168. */
  169. Status Hv_Cal_HdmiRx_CableConnectInit(UCHAR8 ucPortIndex);
  170. /**
  171. * @brief Get +5V/cable connect status software value.
  172. * @param[in] Port Index of the cable
  173. * @return Connected or Not.
  174. */
  175. BOOL Hv_Cal_HdmiRx_GetCableStatus(UCHAR8 ucPortIndex);
  176. /**
  177. * @brief Get +5V/cable connect status software value.
  178. * @param[in] Port Index of the cable
  179. * @return Connected or Not.
  180. */
  181. BOOL Hv_Cal_HdmiRx_GetCableConnectStatus(UCHAR8 ucPortIndex);
  182. /**
  183. * @brief Switch HDMI Rx mode.
  184. * @param[in] bEnable: 1 for HDMI 2.0, 0 for HDMI 2.1
  185. * @return VOID.
  186. */
  187. Status Hv_Cal_HdmiRx_SetHdmi21Enable(UCHAR8 ucPortIndex, BOOL bEnable);
  188. /**
  189. * @brief Set CEC default recieve address.
  190. * @param[in] Port Index of HDMI
  191. * @return Status of this Function.
  192. **/
  193. Status Hv_Cal_HdmiRx_CecInit(UCHAR8 ucPortIndex);
  194. /**
  195. * @brief CEC send data.
  196. * @param[in] Port Index of HDMI
  197. * @return Status of this Function.
  198. **/
  199. Status Hv_Cal_HdmiRx_SendCecMsg(UCHAR8 ucPortIndex, UCHAR8 *pucBuf, UCHAR8 ucLen);
  200. /**
  201. * @brief Set CEC revice data.
  202. * @param[in] Port Index of HDMI
  203. * @return Status of this Function.
  204. **/
  205. UCHAR8 Hv_Cal_HdmiRx_ReceiveCecMsg(UCHAR8 ucPortIndex, UCHAR8 *pucBuf);
  206. /**
  207. * @brief Ddcci init on HDMI.
  208. * @param[in] Port Index of HDMI.
  209. * @return Status of this Function.
  210. */
  211. Status Hv_Cal_HdmiRx_DdcInit(UCHAR8 ucPortIndex);
  212. /**
  213. * @brief Action for the HDMI Enter the Standby.
  214. * @param[in] Port Index of HDMI.
  215. * @param[in] Status of Enter or Leave the standby.
  216. * @return Status of this Function.
  217. */
  218. Status Hv_Cal_HdmiRx_EnterStandby(UCHAR8 ucPortIndex, BOOL bEnterStandby);
  219. /**
  220. * @brief set the eq value which to be saved
  221. * @param[in] Port Index of HDMI.
  222. * @param[in] eq value.
  223. */
  224. void Hv_Cal_HdmiRx_WriteEqToStandby(UCHAR8 ucPortIndex, UINT32 uiVal);
  225. /**
  226. * @brief get the eq value which to be saved
  227. * @param[in] Port Index of HDMI.
  228. * @param[out] eq value.
  229. */
  230. void Hv_Cal_HdmiRx_ReadEqFromStandby(UCHAR8 ucPortIndex, UINT32 *puiVal);
  231. /**
  232. * @brief Received the DDCCI message.
  233. * @param[in] Port Index of HDMI.
  234. * @return Status of this Function and the msg from the DDC.
  235. */
  236. UCHAR8 Hv_Cal_HdmiRx_RecvDdcMsg(UCHAR8 ucPortIndex, UCHAR8 *pucBuf);
  237. /**
  238. * @brief Send the DDCCI message.
  239. * @param[in] Port Index of HDMI and the msg want to send with DDC.
  240. * @return Status of this Function.
  241. */
  242. Status Hv_Cal_HdmiRx_SendDdcMsg(UCHAR8 ucPortIndex, UINT32 uiLen, UCHAR8 *pucBuf);
  243. /**
  244. * @brief Clear the ddcci register.
  245. * @param[in] Port Index of HDMI.
  246. * @return Status of this Function.
  247. */
  248. Status Hv_Cal_HdmiRx_ClrDdcSendReg(UCHAR8 ucPortIndex);
  249. /**
  250. * @brief Clear the msg with NULL for DDC.
  251. * @param[in] Port Index of HDMI.
  252. * @return Status of this Function.
  253. */
  254. Status Hv_Cal_HdmiRx_DdcNullMsg(UCHAR8 ucPortIndex, UCHAR8 *pucBuf);
  255. /**
  256. * @brief Calculate the CheckSum of the DDC.
  257. * @param[in] Port Index of HDMI and the Value of the DDC message.
  258. * @return Check sum of Byte of the message.
  259. */
  260. UCHAR8 Hv_Cal_HdmiRx_DdcCheckSum(UCHAR8 ucPortIndex, const UCHAR8 *pucBuf, UCHAR8 ucLen);
  261. /**
  262. * @brief Set the DDC/CI on/off.
  263. * @param[in] Port Index of HDMI.
  264. * @param[in] 1: on, 0: off.
  265. */
  266. VOID Hv_Cal_HdmiRx_DdcciEnable(UCHAR8 ucPortIndex, BOOL bEnable);
  267. /**
  268. * @brief Set the DDC Slave Address.
  269. * @param[in] Port Index of HDMI.
  270. * @param[in] Slave Addr.
  271. */
  272. VOID Hv_Cal_HdmiRx_SetDdcciAddr(UCHAR8 ucPortIndex, UCHAR8 ucSlvAddr);
  273. /**
  274. * @brief Get the DDC Slave Address.
  275. * @param[in] Port Index of HDMI.
  276. * @return Status of this Function and the Address of the DDC Slave.
  277. */
  278. Status Hv_Cal_HdmiRx_GetDdcSlvAddr(UCHAR8 ucPortIndex, UCHAR8 *pucSlvAddr);
  279. /**
  280. * @brief Get the Interrupt status.
  281. * @param[in] Port Index of HDMI.
  282. * @return Status of the Interrupt.
  283. */
  284. Status Hv_Cal_HdmiRx_GetInterruptEvent(UCHAR8 ucPortIndex, HdmiRxInterruptEvent * pstIntEvent);
  285. /**
  286. * @brief Output Hotplug HIGH.
  287. * @param[in] Port Index of HDMI
  288. * @return Status of this Function.
  289. */
  290. Status Hv_Cal_HdmiRx_HPDOn(UCHAR8 ucPortIndex);
  291. /**
  292. * @brief Output Hotplug HIGH with the Source 5V provide HPD
  293. * @param[in] Port Index of HDMI
  294. * @return Status of this Function.
  295. */
  296. Status Hv_Cal_HdmiRx_HPDOnWithSource5V(UCHAR8 ucPortIndex);
  297. /**
  298. * @brief Output Hotplug LOW.
  299. * @param[in] Port Index of HDMI
  300. * @return Status of this Function.
  301. */
  302. Status Hv_Cal_HdmiRx_HPDOff(UCHAR8 ucPortIndex);
  303. /**
  304. * @brief Output Hotplug LOW with the Source 5V provide HPD
  305. * @param[in] Port Index of HDMI
  306. * @return Status of this Function.
  307. */
  308. Status Hv_Cal_HdmiRx_HPDOffWithSource5V(UCHAR8 ucPortIndex);
  309. /**
  310. * @brief Init Hotplug LOW.
  311. * @param[in]
  312. * @return Status of this Function.
  313. */
  314. Status Hv_Cal_HdmiRx_HPDIOInit(UCHAR8 ucPortIndex);
  315. /**
  316. * @brief Enable the HDMI Edid and Esegment.
  317. * @param[in] Port Index of HDMI
  318. * @return Status of this Function.
  319. */
  320. Status Hv_Cal_HdmiRx_EdidReadEnable(UCHAR8 ucPortIndex);
  321. /**
  322. * @brief Init hdmi IRQs trigger.
  323. * @param[in] Port Index of HDMI
  324. * @return Status of this Function.
  325. */
  326. Status Hv_Cal_HdmiRx_SetInterruptTriggerRule(UCHAR8 ucPortIndex);
  327. /**
  328. * @brief Clear hdmi IRQs status.
  329. * @param[in] Port Index of HDMI and the status handled for the interrupt.
  330. * @return VOID.
  331. */
  332. VOID Hv_Cal_HdmiRx_ClearInterruptStatus(UCHAR8 ucPortIndex, HdmiRxInterruptEvent * pstIntEvent);
  333. /**
  334. * @brief Closed the register EDID when the EDID Used the out device EEPROM.
  335. * @param[in] Port Index of HDMI
  336. * @return Status of this Function.
  337. */
  338. Status Hv_Cal_HdmiRx_CloseRegisterEdid(UCHAR8 ucPortIndex);
  339. /**
  340. * @brief Open the register EDID instead of the EDID Used the out device EEPROM.
  341. * @param[in] Port Index of HDMI
  342. * @return Status of this Function.
  343. */
  344. Status Hv_Cal_HdmiRx_OpenRegisterEdid(UCHAR8 ucPortIndex, UCHAR8 ucSupportESegment);
  345. /**
  346. * @brief Get hdmi events from hdmi IRQ status
  347. * @param[in] pstHdmiRxStatus: hdmi IRQ status, pstHdmiRxEventList: hdmi event list
  348. * @return HV_SUCCESS or HV_FAILURE
  349. */
  350. Status Hv_Cal_HdmiRx_GetInputPortEvent(HdmiRxIntStatus *pstHdmiRxStatus, HDMIRxIntEventList *pstHdmiRxEventList);
  351. /**
  352. * @brief Update the EDID of HDMI.
  353. * @param[in] Port Index of HDMI, EDID length and EDID Value.
  354. * @return Status of this Function.
  355. */
  356. Status Hv_Cal_HdmiRx_UpdateEdidData(UCHAR8 ucPortIndex, USHORT16 usLength, const UCHAR8 *pucEdidData);
  357. /**
  358. * @brief SCDC switch Control.
  359. * @param[in] Port Index of HDMI and the switch for the SCDC.
  360. * @param[in] The switch of the SCDC.
  361. * @return Status of this Function.
  362. */
  363. Status Hv_Cal_HdmiRx_ControlScdcByHPDSwitch(UCHAR8 ucPortIndex, BOOL bSwitch);
  364. /**
  365. * @brief SCDC Enable switch.
  366. * @param[in] Port Index of HDMI and the switch for the SCDC.
  367. * @param[in] The switch of the SCDC Enable.
  368. * @return None.
  369. */
  370. VOID Hv_Cal_HdmiRx_EnableScdcBySwitch(UCHAR8 ucPortIndex, BOOL bSwitch);
  371. /**
  372. * @brief Detect HDMI Rx aln lock.
  373. * @param[in] Port Index of HDMI.
  374. * @param[in] Clock Lane Swap ID.
  375. * @return HV_TRUE of HV_FALSE.
  376. */
  377. BOOL Hv_Cal_HdmiRx_IsClockStable(UCHAR8 ucPortIndex, UCHAR8 ucLaneSwap);
  378. /**
  379. * @brief Detect HDMI Timing Statble.
  380. * @param[in] Port Index of HDMI
  381. * @return HV_TRUE of HV_FALSE.
  382. */
  383. BOOL Hv_Cal_HdmiRx_IsTimingStable(UCHAR8 ucPortIndex, UCHAR8 ucLaneSwap);
  384. /**
  385. * @brief Reset the HDMI RX Moudle.
  386. * @param[in] Port Index of HDMI
  387. * @return Status of this Function.
  388. */
  389. Status Hv_Cal_HdmiRx_Reset(UCHAR8 ucPortIndex);
  390. /**
  391. * @brief Reset the HDMI RX Related PHY.
  392. * @param[in] Port Index of HDMI
  393. * @return Status of this Function.
  394. */
  395. Status Hv_Cal_HdmiRx_ResetPhy(UCHAR8 ucPortIndex);
  396. /**
  397. * @brief Reset the HDMI When Signal Loss.
  398. * @param[in] Port Index of HDMI
  399. * @return Status of this Function.
  400. */
  401. Status Hv_Cal_HdmiRx_ResetSingLoss(UCHAR8 ucPortIndex);
  402. /**
  403. * @brief Set the HDMI TMDS Pol Inv.
  404. * @param[in] Port Index of HDMI
  405. * @return HV_SUCCESS as Received.
  406. */
  407. Status Hv_Cal_HdmiRx_ConfigTmdsPolInv(UCHAR8 ucPortIndex, UCHAR8 ucTmdsPolInv);
  408. /**
  409. * @brief Check if the HDMI Edid is Valid.
  410. * @param[in] Port Index of HDMI
  411. * @return HV_TRUE as Valid, HV_FALSE as Unvalid.
  412. */
  413. BOOL Hv_Cal_HdmiRx_IsEdidInvalid(UCHAR8 ucPortIndex);
  414. /**
  415. * @brief Get the EDID Value.
  416. * @param[in] Port Index of HDMI
  417. * @return Value of the EDID.
  418. */
  419. Status Hv_Cal_HdmiRx_GetEdidData(UCHAR8 ucPortIndex, UCHAR8 *pucEdidData);
  420. /**
  421. * @brief Set the Value for debug on Misc register.
  422. * @param[in] Port Index of HDMI
  423. * @return Status of the function.
  424. */
  425. Status Hv_Cal_HdmiRx_SetMiscForDebug(UCHAR8 ucPortIndex, UINT32 uiValue);
  426. /**
  427. * @brief Get frl rate
  428. * @param[in] Port Index of HDMI
  429. * @return 0-6
  430. */
  431. UCHAR8 Hv_Cal_HdmiRx_GetFrlRate(UCHAR8 ucPortIndex);
  432. /**
  433. * @brief Get hdmi sink version
  434. * @param[in] Port Index of HDMI
  435. * @return 0 or 1
  436. */
  437. UCHAR8 Hv_Cal_HdmiRx_GetSinkVersion(UCHAR8 ucPortIndex);
  438. /**
  439. * @brief Get hdmi source version
  440. * @param[in] Port Index of HDMI
  441. * @return 0 or 1
  442. */
  443. UCHAR8 Hv_Cal_HdmiRx_GetSourceVersion(UCHAR8 ucPortIndex);
  444. /**
  445. * @brief Get hdmi TMDS bitclkratio
  446. * @param[in] Port Index of HDMI
  447. * @return 0 or 1
  448. */
  449. UCHAR8 Hv_Cal_HdmiRx_GetScdcTmdsBitClkRatio(UCHAR8 ucPortIndex, UCHAR8 ucLaneSwap);
  450. /**
  451. * @brief Init hdmi TMDS link path.
  452. * @param[in] Port Index of HDMI
  453. * @return VOID.
  454. */
  455. //VOID Hv_Cal_HdmiRx_TmdsLinkInit(UCHAR8 ucPortIndex);
  456. /**
  457. * @brief Init hdmi TMDS deskew setting.
  458. * @param[in] Port Index of HDMI
  459. * @return VOID.
  460. */
  461. VOID Hv_Cal_HdmiRx_TmdsDeskewInit(UCHAR8 ucPortIndex);
  462. /**
  463. * @brief Init hdmi TMDS alignment setting.
  464. * @param[in] Port Index of HDMI
  465. * @return VOID.
  466. */
  467. VOID Hv_Cal_HdmiRx_TmdsCharacterAlignInit(UCHAR8 ucPortIndex);
  468. /**
  469. * @brief Init hdmi TMDS lane clock setting.
  470. * @param[in] Port Index of HDMI
  471. * @return VOID.
  472. */
  473. VOID Hv_Cal_HdmiRx_TmdsLaneClockInit(UCHAR8 ucPortIndex);
  474. /**
  475. * @brief TMDS 4-Lane settings
  476. * @param[in] Port Index of HDMI
  477. * @return VOID.
  478. */
  479. VOID Hv_Cal_HdmiRx_Tmds4LaneMode(UCHAR8 ucPortIndex, UCHAR8 ucLaneSwap);
  480. /**
  481. * @brief FRL 3-Lane settings
  482. * @param[in] Port Index of HDMI
  483. * @return VOID.
  484. */
  485. VOID Hv_Cal_HdmiRx_Frl3LaneMode(UCHAR8 ucPortIndex, UCHAR8 ucLaneSwap);
  486. /**
  487. * @brief FRL 4-Lane settings
  488. * @param[in] Port Index of HDMI
  489. * @return VOID.
  490. */
  491. VOID Hv_Cal_HdmiRx_Frl4LaneMode(UCHAR8 ucPortIndex);
  492. /**
  493. * @brief HDMI Rx Lane mode switch.
  494. * @param[in] Port Index of HDMI and Lane mode
  495. * @return VOID.
  496. */
  497. VOID Hv_Cal_HdmiRX_PhyClockInit(UCHAR8 ucPortIndex, UCHAR8 ucLaneMode, UCHAR8 ucLaneSwap);
  498. /**
  499. * @brief HDMI Rx Phy Gear Mode change.
  500. * @param[in] Port Index of HDMI and gear mode.
  501. * @return VOID.
  502. */
  503. VOID Hv_Cal_HdmiRX_SwitchPhyGearMode(UCHAR8 ucPortIndex, HdmiRxGearMode ucGrearMode, UCHAR8 ucLaneSwap);
  504. /**
  505. * @brief HDMI Rx Phy Gear Mode Robust checking.
  506. * @param[in] Port Index of HDMI and gear mode.
  507. * @return HV_TRUE for Ratio mode and HV_TRUE for Normal.
  508. */
  509. BOOL Hv_Cal_HdmiRX_RobustCheckRatioMode(UCHAR8 ucPortIndex, UCHAR8 ucLaneSwap);
  510. /**
  511. * @brief Get Phy Gear Mode with freq.
  512. * @param[in] Port Index of HDMI and gear mode now configured.
  513. * @return Gear Mode of the new value.
  514. */
  515. HdmiRxGearMode Hv_Cal_HdmiRx_GetGearMode(UCHAR8 ucPortIndex, HdmiRxGearMode emGearModeCfg, UCHAR8 ucLaneSwap);
  516. /**
  517. * @brief Configure the PHY OFFSET.
  518. * @param[in] Port Index of HDMI.
  519. * @return HV_TRUE for HV_SUCCESS.
  520. */
  521. BOOL Hv_Cal_HdmiRX_CfgPhyOffset(UCHAR8 ucPortIndex);
  522. /**
  523. * @brief Init hdmi FRL link path.
  524. * @param[in] Port Index of HDMI
  525. * @return VOID.
  526. */
  527. VOID Hv_Cal_HdmiRx_FrlInit(UCHAR8 ucPortIndex);
  528. /**
  529. * @brief Get HDMI Rx AVI info.
  530. * @param[in] Port Index of HDMI.
  531. * @return Status of the function.
  532. */
  533. Status Hv_Cal_HdmiRx_GetAVIPara(UCHAR8 ucPortIndex, CalVideoColorParam *pstVideoAVIPara);
  534. /**
  535. * @brief Get HDMI Rx audio info.
  536. * @param[in] Port Index of HDMI
  537. * @return Status of the function.
  538. */
  539. Status Hv_Cal_HdmiRx_GetAudioPara(UCHAR8 ucPortIndex, CalAudioPara *pstAudioPara);
  540. /**
  541. * @brief Get AVI Info VIC.
  542. * @param[in] Port Index of HDMI
  543. * @return VIC in AVI.
  544. */
  545. UCHAR8 Hv_Cal_HdmiRx_GetVic(UCHAR8 ucPortIndex);
  546. /**
  547. * @brief Get TMDS Clk (KHz).
  548. * @param[in] Port Index of HDMI
  549. * @return
  550. */
  551. UINT32 Hv_Cal_HdmiRx_GetTmdsClk(UCHAR8 ucPortIndex);
  552. /**
  553. * @brief Get FrameRate.
  554. * @param[in] Port Index of HDMI
  555. * @return Frame Rate of the Timing.
  556. */
  557. UINT32 Hv_Cal_HdmiRx_GetFrameRate(UCHAR8 ucPortIndex);
  558. /**
  559. * @brief Get ColorFormat.
  560. * @param[in] Port Index of HDMI
  561. * @return The color format type of current Vedio, detail ref the define of ColorFormatType.
  562. */
  563. ColorFormatType Hv_Cal_HdmiRx_GetColorFormat(UCHAR8 ucPortIndex);
  564. /**
  565. * @brief Get Aspect Ratio for current Vedio.
  566. * @param[in] Port Index of HDMI
  567. * @return The ratio type aspected, detail ref the define of PicAspRatioType.
  568. */
  569. PicAspRatioType Hv_Cal_HdmiRx_GetPicAspRatio(UCHAR8 ucPortIndex);
  570. /**
  571. * @brief Get ColorDepth.
  572. * @param[in] Port Index of HDMI
  573. * @return
  574. */
  575. ColorDepthType Hv_Cal_HdmiRx_GetColorDepth(UCHAR8 ucPortIndex);
  576. /**
  577. * @brief Init hdmi SCDC and packet settings.
  578. * @param[in] Port Index of HDMI
  579. * @return VOID.
  580. */
  581. Status Hv_Cal_HdmiRx_Init(UCHAR8 ucPortIndex, UCHAR8 ucLanSwp);
  582. /**
  583. * @brief Init hdmi SCDC and packet settings.
  584. * @param[in] Port Index of HDMI
  585. * @return VOID.
  586. */
  587. VOID Hv_Cal_HdmiRx_InitWithCtsOn(UCHAR8 ucPortIndex);
  588. /**
  589. * @brief Init HDMI Rx Audio path.
  590. * @param[in] Port Index of HDMI
  591. * @return Status of the function.
  592. */
  593. Status Hv_Cal_HdmiRx_AudioInit(UCHAR8 ucPortIndex);
  594. /**
  595. * @brief Reset the Audio Fifo when the fifo is Overflow or Underflow.
  596. * @param[in] Port Index of HDMI
  597. * @return Status of the function.
  598. */
  599. Status Hv_Cal_HdmiRx_ResetAudioFifo(UCHAR8 ucPortIndex);
  600. /**
  601. * @brief Reset the Audio of HDMI IP Inner.
  602. * @param[in] Port Index of HDMI
  603. * @return Status of the function.
  604. */
  605. VOID Hv_Cal_HdmiRx_ResetSwAudio(UCHAR8 ucPortIndex);
  606. /**
  607. * @brief Set the Audio Fifo Start Value.
  608. * @param[in] Port Index of HDMI, the value of the audio fifo to play.
  609. * @return Status of the function.
  610. */
  611. Status Hv_Cal_HdmiRx_SetAudioFifoStartValue(UCHAR8 ucPortIndex, UINT32 uiValue);
  612. /**
  613. * @brief Toggle the Auto EQ switch for PHY.
  614. * @param[in] Port Index of HDMI.
  615. * @return Status of the function.
  616. */
  617. Status Hv_Cal_HdmiRx_TogglePhyCtl(UCHAR8 ucPortIndex);
  618. /**
  619. * @brief Get HDR data.
  620. * @param[in] Port Index of HDMI
  621. * @return Parameters of HDR send from Source.
  622. */
  623. Status Hv_Cal_HdmiRx_GetHDRPara(UCHAR8 ucPortIndex, CalHDRParam *pstHDRPara);
  624. /**
  625. * @brief Get ALLM mode From VSI.
  626. * @param[in] Port Index of HDMI
  627. * @return HV_TRUE: Get the ALLM mode from the HF-VSI. HV_FALSE: Leave the ALLM Mode
  628. */
  629. BOOL Hv_Cal_HdmiRx_GetAllmModeInfo(UCHAR8 ucPortIndex, BOOL *pbAllmMode);
  630. /**
  631. * @brief set video colordepth from GCP package.
  632. * @param[in] Port Index of HDMI
  633. * @return Status of the function.
  634. */
  635. Status Hv_Cal_HdmiRx_SetColorDepth(UCHAR8 ucPortIndex, UCHAR8 ucColorDepSelect, UCHAR8 ucColorDepValue);
  636. /**
  637. * @brief Init hdmi phy settings.
  638. * @param[in] Port Index of HDMI
  639. * @return Status of the function.
  640. */
  641. Status Hv_Cal_HdmiRx_PhyInit(UCHAR8 ucPortIndex, UCHAR8 ucInvPn);
  642. /**
  643. * @brief Parse the SPD of AMD.
  644. * @param[in] Port Index of HDMI
  645. * @return HV_SUCCESS or FAILSE.
  646. * @return VRR value from the SPD.
  647. */
  648. Status Hv_Cal_HdmiRx_GetAMDVendSpecInfoPara(UCHAR8 ucPortIndex, CalVRRInfoParam *pstVendSpecInfoPara);
  649. /**
  650. * @brief Parse the SPD of NVIDIA.
  651. * @param[in] Port Index of HDMI
  652. * @return HV_SUCCESS or FAILSE.
  653. * @return VRR value from the SPD.
  654. */
  655. Status Hv_Cal_HdmiRx_GetSPDInfoPara(UCHAR8 ucPortIndex, CalVRRInfoParam *pstSPDPara);
  656. /**
  657. * @brief Clear the Packet Fifo.
  658. * @param[in] Port Index of HDMI
  659. * @return HV_SUCCESS or FAILSE.
  660. */
  661. Status Hv_Cal_HdmiRx_ClearPacketFifo(UCHAR8 ucPortIndex);
  662. /**
  663. * @brief Set the Packet type for the FIFO.
  664. * @param[in] Port Index of HDMI
  665. * @return HV_SUCCESS or FAILSE.
  666. */
  667. Status Hv_Cal_HdmiRx_SelectAndEnPacketFifo(UCHAR8 ucPortIndex);
  668. /**
  669. * @brief Set the Packet FIFO thread hold.
  670. * @param[in] Port Index of HDMI
  671. * @return HV_SUCCESS or FAILSE.
  672. */
  673. Status Hv_Cal_HdmiRx_ConfigPacketFifoThreadhold(UCHAR8 ucPortIndex);
  674. /**
  675. * @brief Get the Packet FIFO Data.
  676. * @param[in] Port Index of HDMI
  677. * @return HV_SUCCESS or FAILSE and the date of the packet.
  678. */
  679. Status Hv_Cal_HdmiRx_GetPacketData(UCHAR8 ucPortIndex, PacketInfo *pstPacketData);
  680. /**
  681. * @brief Open the FIFO new entry interrput with new packet received handle.
  682. * @param[in] Port Index of HDMI
  683. * @return HV_SUCCESS or FAILSE .
  684. */
  685. Status Hv_Cal_HdmiRx_PacketFifoIntrruptInit(UCHAR8 ucPortIndex);
  686. /**
  687. * @brief Clear of the MR Timing in HDMI RX.
  688. * @param[in] Port Index of HDMI
  689. * @return HV_SUCCESS or FAILSE .
  690. */
  691. Status Hv_Cal_HdmiRx_ClrMrTiming(UCHAR8 ucPortIndex);
  692. /**
  693. * @brief Clear of the Aln Status Flag in HDMI RX.
  694. * @param[in] Port Index of HDMI
  695. * @return HV_SUCCESS or FAILSE .
  696. */
  697. Status Hv_Cal_HdmiRx_ClrAlnChangFlag(UCHAR8 ucPortIndex);
  698. /**
  699. * @brief Reset HDMI Aln and Deskew.
  700. * @param[in] Port Index of HDMI
  701. * @return HV_SUCCESS or FAILSE .
  702. */
  703. Status Hv_Cal_HdmiRx_ResetAlnDeskew(UCHAR8 ucPortIndex);
  704. /**
  705. * @brief Clear HDMI Aln and Deskew.
  706. * @param[in] Port Index of HDMI
  707. * @return HV_SUCCESS or FAILSE .
  708. */
  709. Status Hv_Cal_HdmiRx_ClrAlnDeskew(UCHAR8 ucPortIndex);
  710. /**
  711. * @brief Get the Audio status.
  712. * @param[in] Port Index of HDMI
  713. * @return HV_TRUE is Status ready .
  714. */
  715. BOOL Hv_Cal_HdmiRx_GetAudioStatus(UCHAR8 ucPortIndex);
  716. /**
  717. * @brief Action for the Cable plug in or out.
  718. * @param[in] Port Index of HDMI and the cable status.
  719. * @return Status of the function.
  720. */
  721. Status Hv_Cal_HdmiRx_CableConnectAction(UCHAR8 ucPortIndex, BOOL bCableSta, UCHAR8 ucLaneSwap);
  722. /**
  723. * @brief Set the FRL mode.
  724. * @param[in] Port Index of HDMI and the Mode switch.
  725. * @return Status of the function.
  726. */
  727. Status Hv_Cal_HdmiRx_SetFrlModeOn(UCHAR8 ucPortIndex, UCHAR8 ucModeSwitch);
  728. /**
  729. * @brief Get the Pixel repeat factor.
  730. * @param[in] Port Index of HDMI.
  731. * @return Factor of the Pixel repeat.
  732. */
  733. UINT32 Hv_Cal_HdmiRx_GetPixelRepeatFactor(UCHAR8 ucPortIndex);
  734. /**
  735. * @brief Get the Interlace status.
  736. * @param[in] Port Index of HDMI.
  737. * @return 1 is for interlace .
  738. */
  739. UINT32 Hv_Cal_HdmiRx_GetInterlacedStatus(UCHAR8 ucPortIndex);
  740. /**
  741. * @brief Get the AvMute status.
  742. * @param[in] Port Index of HDMI.
  743. * @return True is for Enter AVMute .
  744. */
  745. BOOL Hv_Cal_HdmiRx_GetAvMuteStatus(UCHAR8 ucPortIndex);
  746. /**
  747. * @brief Change the Timing change check mode.
  748. * @param[in] Port Index of HDMI and frame rate report switch.
  749. * @return status of the function.
  750. */
  751. Status Hv_Cal_HdmiRx_SetFrameRateTimingChange(UCHAR8 ucPortIndex, BOOL bRmvFrameRate);
  752. /**
  753. * @brief Get the Segment value for EDDC.
  754. * @param[in] Port Index of HDMI.
  755. * @return Segment value from the source.
  756. */
  757. UINT32 Hv_Cal_HDMIRX_GetSegment(UCHAR8 ucPortIndex);
  758. /**
  759. * @brief Set the AVMute with HDMI autoly.
  760. * @param[in] Port Index of HDMI.
  761. * @return Status of the function.
  762. */
  763. Status Hv_Cal_HdmiRx_SetAutoVmute(UCHAR8 ucPortIndex);
  764. /**
  765. * @brief Closed the AVMute with HDMI autoly.
  766. * @param[in] Port Index of HDMI.
  767. * @return Status of the function.
  768. */
  769. Status Hv_Cal_HdmiRx_ClearAutoVmute(UCHAR8 ucPortIndex);
  770. /**
  771. * @brief Change the Timing change Frame rate threhold.
  772. * @param[in] Port Index of HDMI.
  773. * @param[in] Frame Rate of the threhold for timing change.
  774. * @return Status of the function.
  775. */
  776. Status Hv_Cal_HdmiRx_ChangeFrameTh(UCHAR8 ucPortIndex, UINT32 uiFrameRateTh);
  777. /**
  778. * @brief Set the value of the frequency.
  779. * @param[in] Port Index of HDMI.
  780. * @param[in] Lowest frequency and the Highest of the frequency.
  781. * @return Status of the function.
  782. */
  783. Status Hv_Cal_HdmiRx_SetClkDetFreq(UCHAR8 ucPortIndex, UINT32 uiFreqLow, UINT32 uiFreqHigh);
  784. /**
  785. * @brief Set the frequency of the Timing stable.
  786. * @param[in] Port Index of HDMI.
  787. * @return Status of the function.
  788. */
  789. Status Hv_Cal_HdmiRx_SetTmdsTimeStableFreq(UCHAR8 ucPortIndex);
  790. /**
  791. * @brief Set the Clock unstable interrupt switch.
  792. * @param[in] Port Index of HDMI switch of the interrupt.
  793. * @return Status of the function.
  794. */
  795. Status Hv_Cal_HdmiRx_SetTmdsClkUnstableInterrupt(UCHAR8 ucPortIndex, BOOL bSwitch);
  796. /**
  797. * @brief Get the Mata Date for the VRR with EMP(0x7F) Packet.
  798. * @param[in] Port Index of HDMI.
  799. * @return VRR parameters on EMP.
  800. */
  801. Status Hv_Cal_HdmiRx_GetMDVrrPara(UCHAR8 ucPortIndex, CalVRRInfoParam* pstVrrMdPara);
  802. /**
  803. * @brief Set the HDCP Rx Status for retriger the HDCP 2x Auth.
  804. * @param[in] Port Index of HDMI.
  805. * @return Status of the function.
  806. */
  807. Status Hv_Cal_HdmiRx_SetHDCPRxStatus(UCHAR8 ucPortIndex);
  808. /**
  809. * @brief Open or Closed the packet error interrupt.
  810. * @param[in] Port Index of HDMI.
  811. * @return Status of the function.
  812. */
  813. Status Hv_Cal_HdmiRx_SetPacketErrorInt(UCHAR8 ucPortIndex, BOOL bSwitch);
  814. /**
  815. * @brief Clear the Packet Error Value.
  816. * @param[in] Port Index of HDMI.
  817. * @return Status of the function.
  818. */
  819. Status Hv_Cal_HdmiRx_ClearCEDValue(UCHAR8 ucPortIndex);
  820. /**
  821. * @brief Get the Packet Error Value.
  822. * @param[in] Port Index of HDMI.
  823. * @return Number of the CED Value.
  824. */
  825. Status Hv_Cal_HdmiRx_GetLaneCEDValue(UCHAR8 ucPortIndex, HdmiRxLaneCED *pstLaneCedValue, UCHAR8 ucLaneSwap);
  826. /**
  827. * @brief Set the Timing info on Manu Factor of SCDC which is used for Auto testing checking.
  828. * @param[in] Port Index of HDMI.
  829. * @return Status of the function.
  830. */
  831. Status Hv_Cal_HdmiRx_SetTimingToManuFactorSpec(UCHAR8 ucPortIndex, CalVideoTimingParam *pstTimingPara);
  832. /**
  833. * @brief Set the SCDC Manu Factor.
  834. * @param[in] Port Index of HDMI.
  835. * @return Status of the function.
  836. */
  837. Status Hv_Cal_HdmiRx_InitSCDCManuFactor(UCHAR8 ucPortIndex, CHAR8 *pacManufact, UINT32 uiMManufactOUI);
  838. /**
  839. * @brief Get the Interrupt Enable value for Print.
  840. * @param[in] Port Index of HDMI.
  841. * @return The Interrupt status Value to configure.
  842. */
  843. UINT32 Hv_Cal_HdmiRx_InterruptEnPrint(UCHAR8 ucPortIndex, UCHAR8 ucIntr);
  844. /**
  845. * @brief Get Current Timing parameters decoded by HDMI.
  846. * @param[in] ucPortIndex Port Index of HDMI.
  847. * @param[out] Details of the Timing parameters, including the H V CD information etc.
  848. * @return Status of the function.
  849. */
  850. Status Hv_Cal_HdmiRx_GetTimingHVInfo(UCHAR8 ucPortIndex, CalVideoTimingParam *pstTimingPara, UCHAR8 ucLaneSwap);
  851. /**
  852. * @brief Open the TMDS Auto EQ.
  853. * @param[in] ucPortIndex Port Index of HDMI.
  854. * @return None.
  855. */
  856. VOID Hv_Cal_HdmiRx_OpenTmdsAutoEq(UCHAR8 ucPortIndex);
  857. /**
  858. * @brief Open the FRL Auto EQ.
  859. * @param[in] ucPortIndex Port Index of HDMI.
  860. * @return None.
  861. */
  862. VOID Hv_Cal_HdmiRx_OpenFrlAutoEq(UCHAR8 ucPortIndex);
  863. /**
  864. * @brief Configure the Init EQ value to start.
  865. * @param[in] ucPortIndex Port Index of HDMI.
  866. * @param[in] Eq Value to configure.
  867. * @return : Eq Value configured.
  868. */
  869. UCHAR8 Hv_Cal_HdmiRx_CfgHdmiAutoEQInitValue(UCHAR8 ucPortIndex, UCHAR8 ucCfgEqInitValue);
  870. /**
  871. * @brief Configure the Min Htotal for HDMI to Gen the Timing.
  872. * @param[in] ucPortIndex Port Index of HDMI.
  873. * @param[in] Swith and the Min Htotal Value.
  874. * @return : None.
  875. */
  876. VOID Hv_Cal_HdmiRx_ConfigureMinHtotal(UCHAR8 ucPortIndex, UCHAR8 ucCfgSwitch, USHORT16 usHtotalMinValue);
  877. /**
  878. * @brief Get Current Audio CTS and N decode with packet.
  879. * @param[in] ucPortIndex Port Index of HDMI.
  880. * @param[out] Value of CTS and N.
  881. * @return : None.
  882. */
  883. VOID Hv_Cal_HdmiRx_GetAudioCurrentCTSN(UCHAR8 ucPortIndex, UINT32 *puiCTS, UINT32 *puiN);
  884. /**
  885. * @brief Reset and clear the HDMI decoding para.
  886. * @param[in] ucPortIndex Port Index of HDMI.
  887. * @return Status of the function.
  888. */
  889. Status Hv_Cal_HdmiRx_SWCfgReset(UCHAR8 ucPortIndex);
  890. /**
  891. * @brief Checking if there is a stable timing decoded by the HDMI.
  892. * @param[in] ucPortIndex Port Index of HDMI.
  893. * @return HV_TRUE: No Stable timing ouput; HV_FALSE:Timing is stable for show.
  894. */
  895. BOOL HV_Cal_HdmirRx_CheckNoTiming(UCHAR8 ucPortIndex);
  896. /**
  897. * @brief Reset SCDC with the 5V Change.
  898. * @param[in] ucPortIndex Port Index of HDMI.
  899. * @return : None.
  900. */
  901. VOID HV_Cal_HdmirRx_ResetScdcWith5V(UCHAR8 ucPortIndex);
  902. /**
  903. * @brief Reset SCDC with the 5V Change.
  904. * @param[in] ucPortIndex Port Index of HDMI.
  905. * @return : None.
  906. */
  907. VOID HV_Cal_HdmirRx_ResetScdcWith5VCtsOn(UCHAR8 ucPortIndex);
  908. /**
  909. * @brief Get current AVI VIC for Timing checking.
  910. * @param[in] ucPortIndex Port Index of HDMI.
  911. * @return : VIC of the current AVI.
  912. */
  913. UINT32 Hv_Cal_HdmiRx_GetVicForCurrentTiming(UCHAR8 ucPortIndex);
  914. /**
  915. * @brief Check current AVI Change received or not.
  916. * @param[in] ucPortIndex Port Index of HDMI.
  917. * @return :Status of the AVI Change Status Received.
  918. */
  919. UINT32 Hv_Cal_HdmiRx_GetAviChangeEvent(UCHAR8 ucPortIndex);
  920. /**
  921. * @brief Check current HDMI Esegment received or not.
  922. * @param[in] ucPortIndex Port Index of HDMI.
  923. * @return HV_TRUE:Esegment Received; HV_FALSE:Esegment Not Received.
  924. */
  925. BOOL Hv_Cal_HdmiRx_IsEsegmentIsrRcved(UCHAR8 ucPortIndex);
  926. /**
  927. * @brief Get HDMI HDCP Interrupt Event Status.
  928. * @param[in] ucPortIndex Port Index of HDMI.
  929. * @return Status of the HDCP Interrupt.
  930. */
  931. UINT32 Hv_Cal_HdmiRx_GetHdcpIsrStatus(UCHAR8 ucPortIndex);
  932. /**
  933. * @brief Clear the HDCP2X Rx Status for Nothing Transfered to Source.
  934. * @param[in] ucPortIndex Port Index of HDMI.
  935. * @return None.
  936. */
  937. VOID Hv_Cal_HdmiRx_ClearHDCPRxStatus(UCHAR8 ucPortIndex);
  938. /**
  939. * @brief Get current HDMI Timing Vedio Mode.
  940. * @param[in] ucPortIndex Port Index of HDMI.
  941. * @return HV_TRUE:DVI Mode; HV_FALSE:HDMI Mode.
  942. */
  943. BOOL Hv_Cal_HdmiRx_GetDviMode(UCHAR8 ucPortIndex);
  944. /**
  945. * @brief Get Phy is Locked or not.
  946. * @param[in] ucPortIndex Port Index of HDMI.
  947. * @return HV_TRUE : PHY Is locked; HV_FALSE : PHY is UnLocked.
  948. */
  949. BOOL Hv_Cal_HdmiRX_IsPhyLocked(UCHAR8 ucPortIndex);
  950. /**
  951. * @brief Set the Frame Trigger Postion of Hdmi.
  952. * @param[in] ucPortIndex Port Index of HDMI.
  953. * @param[in] HDMI OSR value for the frequency.
  954. * @return Status of the function.
  955. */
  956. VOID Hv_Cal_HdmiRx_ConfigureFrmTrigPos(UCHAR8 ucPortIndex, UCHAR8 ucGrearMode);
  957. /**
  958. * @brief Set the HDCP Hdmi Mode.
  959. * @param[in] ucPortIndex Port Index of HDMI.
  960. * @param[in] bHdmiMode 1 for HDMI and 0 for DVI.
  961. * @return Status of the function.
  962. */
  963. VOID Hv_Cal_HdmiRx_SetHDCPHdmiMode(UCHAR8 ucPortIndex, BOOL bHdmiMode);
  964. VOID Hv_Cal_HdmiRx_SetHDCP1Xstatus(UCHAR8 ucPortIndex, BOOL bHdmiMode);
  965. /**
  966. * @brief Set the EQ with Software confiured.
  967. * @param[in] ucPortIndex Port Index of HDMI.
  968. * @return Status of the function.
  969. */
  970. Status Hv_Cal_HdmiRx_EnterTmdsSwEq(UCHAR8 ucPortIndex);
  971. /**
  972. * @brief Set the EQ with Hardeware Auto confiured.
  973. * @param[in] ucPortIndex Port Index of HDMI.
  974. * @return Status of the function.
  975. */
  976. Status Hv_Cal_HdmiRx_EnterTmdsHwAutoEq(UCHAR8 ucPortIndex);
  977. /**
  978. * @brief Finished the EQ Configure.
  979. * @param[in] ucPortIndex Port Index of HDMI.
  980. * @return Status of the function.
  981. */
  982. Status Hv_Cal_HdmiRx_FinishTmdsSwEq(UCHAR8 ucPortIndex);
  983. /**
  984. * @brief Set the EQ with Confgiure Date.
  985. * @param[in] ucPortIndex Port Index of HDMI.
  986. * @param[in] pusSwEqValue The 3Lane Eq Value to be configured
  987. * @return Status of the function.
  988. */
  989. Status Hv_Cal_HdmiRx_SetSwEqValue(UCHAR8 ucPortIndex, const USHORT16 *pusSwEqValue, UCHAR8 ucLaneSwap);
  990. /**
  991. * @brief Check the TMDS Signal.
  992. * @param[in] ucPortIndex Port Index of HDMI.
  993. * @return HV_TRUE : Received the TMDS signal; HV_FALSE : Do not receive the Signal.
  994. */
  995. BOOL Hv_Cal_HdmiRx_CheckTmdsSignal(UCHAR8 ucPortIndex);
  996. /**
  997. * @brief Open the Packet Fifo of the HDMI.
  998. * @param[in] ucPortIndex Port Index of HDMI.
  999. * @return Status of the function.
  1000. */
  1001. Status Hv_Cal_HdmiRx_OpenPdFifo(UCHAR8 ucPortIndex);
  1002. /**
  1003. * @brief Close the Packet Fifo of HDMI.
  1004. * @param[in] ucPortIndex Port Index of HDMI.
  1005. * @return Status of the function.
  1006. */
  1007. Status Hv_Cal_HdmiRx_ClosedPdFifo(UCHAR8 ucPortIndex);
  1008. /**
  1009. * @brief Release the Phase configure.
  1010. * @param[in] ucPortIndex Port Index of HDMI.
  1011. * @return Status of the function.
  1012. */
  1013. Status Hv_Cal_HdmiRx_ReleasePhaseConfig(UCHAR8 ucPortIndex);
  1014. /**
  1015. * @brief Configure the Phase with the color depth.
  1016. * @param[in] ucPortIndex Port Index of HDMI.
  1017. * @param[in] Color Deepth of the HDMI.
  1018. * @return Status of the function.
  1019. */
  1020. Status Hv_Cal_HdmiRx_PhaseConfig(UCHAR8 ucPortIndex, ColorDepthType eColorDeepth);
  1021. /**
  1022. * @brief Remove the Interrupt Event of the HDCP.
  1023. * @param[in] ucPortIndex Port Index of HDMI.
  1024. * @return Status of the function.
  1025. */
  1026. Status Hv_Cal_HdmiRx_InterruptRmHdcpEvent(UCHAR8 ucPortIndex);
  1027. /**
  1028. * @brief Reset The TMDS Pre of Sw.
  1029. * @param[in] Port Number used for the HDMI RX.
  1030. * @return Status of the function.
  1031. */
  1032. Status Hv_Cal_HdmiRx_TmdsSwReset(UCHAR8 ucPortIndex);
  1033. /**
  1034. * @brief Reset The TMDS Pre of Bus.
  1035. * @param[in] Port Number used for the HDMI RX.
  1036. * @return Status of the function.
  1037. */
  1038. Status Hv_Cal_HdmiRx_BusSwReset(UCHAR8 ucPortIndex);
  1039. /**
  1040. * @brief Reset The Mode of Pixel.
  1041. * @param[in] Port Number used for the HDMI RX.
  1042. * @return Status of the function.
  1043. */
  1044. Status Hv_Cal_HdmiRx_PixelSwReset(UCHAR8 ucPortIndex);
  1045. /**
  1046. * @brief Reset The Mode of Vid.
  1047. * @param[in] Port Number used for the HDMI RX.
  1048. * @return Status of the function.
  1049. */
  1050. Status Hv_Cal_HdmiRx_VidSwReset(UCHAR8 ucPortIndex);
  1051. /**
  1052. * @brief If the PHY is fast locked.
  1053. * @param[in] Port Number used for the HDMI RX.
  1054. * @return TRUE is Loced False is unlocked.
  1055. */
  1056. BOOL Hv_Cal_HdmiRX_IsPhyFastLocked(UCHAR8 ucPortIndex, UCHAR8 ucLaneSwap);
  1057. /**
  1058. * @brief Set Sw EQ form the HW Eq Value.
  1059. * @param[in] Port Number used for the HDMI RX.
  1060. * @return Status of the function.
  1061. */
  1062. Status Hv_Cal_HdmiRx_SetSwEqFromHwValue(UCHAR8 ucPortIndex);
  1063. /**
  1064. * @brief If the EQ is configured with Software EQ.
  1065. * @param[in] Port Number used for the HDMI RX.
  1066. * @return TRUE is Loced False is unlocked.
  1067. */
  1068. BOOL Hv_Cal_HdmiRx_IsTmdsSwEqCfgured(UCHAR8 ucPortIndex);
  1069. /**
  1070. * @brief Get the TMDS Clock Frequency.
  1071. * @param[in] Port Number used for the HDMI RX.
  1072. * @return Value of the TMDS Clock Freqency with 100K.
  1073. */
  1074. USHORT16 Hv_Cal_HdmiRx_GetTmdsClkFreq(UCHAR8 ucPortIndex);
  1075. /**
  1076. * @brief check ddc current state
  1077. * @param[in] port id
  1078. * @return value of the check result
  1079. */
  1080. BOOL Hv_Cal_HdmiRx_DdcCurStateIsIdle(UCHAR8 ucPortIndex);
  1081. /**
  1082. * @brief Set HDMI Audio CTS N Measue N or CTS
  1083. * @param[in] port id
  1084. * @param[in] Measure Mode : 1 For Cts, 2 is N, 0 is reset.
  1085. * @return Status of the function.
  1086. */
  1087. Status Hv_Cal_HdmiRx_SetCtsNMeasMode(UCHAR8 ucPortIndex, UCHAR8 ucMeasMode);
  1088. /**
  1089. * @brief Set Audio Clock use the Auto or Manual
  1090. * @param[in] port id
  1091. * @param[in] TRUE is for the Manual Audio CTS N Mode
  1092. * @return Status of the function.
  1093. */
  1094. Status Hv_Cal_HdmiRx_SwitchAudioManualClk(UCHAR8 ucPortIndex, BOOL bAudioManual);
  1095. /**
  1096. * @brief Set the Manual CTS Value used for Audio Clock
  1097. * @param[in] port id
  1098. * @param[in] Over Or Under Matched.
  1099. * @param[in] Last configured OverFlow CTS Value.
  1100. * @param[in] Last configured UnderFlow CTS Value.
  1101. * @return Status of the function.
  1102. */
  1103. USHORT16 HV_Cal_HdmiRx_ManualCtsValueSet(UCHAR8 ucPortIndex, BOOL bUnderFlow, USHORT16 uiLastOverValue, USHORT16 uiLastUnderValue);
  1104. /**
  1105. * @brief Check Audio Clock if Normal with N
  1106. * @param[in] port id
  1107. * @return Status of the function.
  1108. */
  1109. BOOL Hv_Cal_HdmiRx_RobustCheckAudioManual(UCHAR8 ucPortIndex);
  1110. /**
  1111. * @brief check and restore audio fifo
  1112. * @param[in] Port Number used for the HDMI RX.
  1113. */
  1114. VOID Hv_Cal_HdmiRx_AudioCheck(UCHAR8 ucPortId);
  1115. /**
  1116. * @brief Start Receive CEC Message.
  1117. * @param[in] port id
  1118. * @return NONE.
  1119. */
  1120. void Hv_Cal_HdmiRx_StartRcvCecMsg(UCHAR8 ucPortIndex);
  1121. /**
  1122. * @brief reload color depth reg
  1123. * @param[in] Port Number used for the HDMI RX.
  1124. */
  1125. VOID Hv_Cal_HdmiRx_ReloadColorDepth(UCHAR8 ucPortIndex);
  1126. /**
  1127. * @brief Phy Sw Trigger to configure
  1128. * @param[in] port id
  1129. * @return Status of the function.
  1130. */
  1131. Status Hv_Cal_HdmiRx_PhyCfgSwTrig(UCHAR8 ucPortIndex);
  1132. /**
  1133. * @brief Set Frl Flt Update Flag to retrain
  1134. * @param[in] port id
  1135. * @return Status of the function.
  1136. */
  1137. Status Hv_Cal_HdmiRx_SetFrlFltUpdate(UCHAR8 ucPortIndex);
  1138. /**
  1139. * @brief Set Ri Update Autoly or not.
  1140. * @param[in] port id
  1141. * @param[in] Ri sel Value = 1 is Autoly.
  1142. * @return Status of the function.
  1143. */
  1144. Status Hv_Cal_HdmiRx_SetHdcp1XRiSel(UCHAR8 ucPortIndex, UCHAR8 ucRiSelValue);
  1145. /**
  1146. * @brief If the PHY TMDS Clock Is OverFlow.
  1147. * @param[in] Port Number used for the HDMI RX.
  1148. * @return TRUE is OverFlow False is not OverFlow.
  1149. */
  1150. BOOL Hv_Cal_HdmiRX_IsTMDSClockOverFlow(UCHAR8 ucPortIndex, UCHAR8 ucLaneSwap);
  1151. BOOL Hv_Cal_HdmiRx_GetSourceCfgRatioMode(UCHAR8 ucPortIndex);
  1152. Status Hv_Cal_HdmiRx_RobustTmdsLockInLowBnd(UCHAR8 ucPortIndex);
  1153. Status Hv_Cal_HdmiRx_ReBackTmdsLockInLowBnd(UCHAR8 ucPortIndex);
  1154. Status Hv_Cal_HdmiRx_SetDviMode(UCHAR8 ucPortIndex, BOOL bDviMode);
  1155. Status Hv_Cal_HdmiRx_ClrDviMode(UCHAR8 ucPortIndex);
  1156. VOID Hv_Cal_HdmiRX_SwitchAutoEqTable(UCHAR8 ucPortIndex, BOOL bFreqLow);
  1157. Status Hv_Cal_HdmiRx_ConfigureEqCheckValue(UCHAR8 ucPortIndex, BOOL bStrick);
  1158. BOOL Hv_Cal_HdmiRx_CheckTmdsClockAbnormal(UCHAR8 ucPortIndex, UCHAR8 ucLaneSwap);
  1159. Status Hv_Cal_HdmiRx_SetEqByPass(UCHAR8 ucPortIndex, UCHAR8 ucBypass);
  1160. Status Hv_Cal_HdmiRx_GetHdmiAudioFsValue(UCHAR8 ucPortIndex, UINT32 *puiFs);
  1161. Status Hv_Cal_HdmiRx_ConfigurePhyRterm(UCHAR8 ucPortIndex, UCHAR8 ucRtermValue);
  1162. #endif