xref: /utopia/UTPA2-700.0.x/modules/vdec_v2/api/vdec_ex/_apiVDEC_EX_weak.h (revision 53ee8cc121a030b8d368113ac3e966b4705770ef)
1 //<MStar Software>
2 //******************************************************************************
3 // MStar Software
4 // Copyright (c) 2010 - 2012 MStar Semiconductor, Inc. All rights reserved.
5 // All software, firmware and related documentation herein ("MStar Software") are
6 // intellectual property of MStar Semiconductor, Inc. ("MStar") and protected by
7 // law, including, but not limited to, copyright law and international treaties.
8 // Any use, modification, reproduction, retransmission, or republication of all
9 // or part of MStar Software is expressly prohibited, unless prior written
10 // permission has been granted by MStar.
11 //
12 // By accessing, browsing and/or using MStar Software, you acknowledge that you
13 // have read, understood, and agree, to be bound by below terms ("Terms") and to
14 // comply with all applicable laws and regulations:
15 //
16 // 1. MStar shall retain any and all right, ownership and interest to MStar
17 //    Software and any modification/derivatives thereof.
18 //    No right, ownership, or interest to MStar Software and any
19 //    modification/derivatives thereof is transferred to you under Terms.
20 //
21 // 2. You understand that MStar Software might include, incorporate or be
22 //    supplied together with third party`s software and the use of MStar
23 //    Software may require additional licenses from third parties.
24 //    Therefore, you hereby agree it is your sole responsibility to separately
25 //    obtain any and all third party right and license necessary for your use of
26 //    such third party`s software.
27 //
28 // 3. MStar Software and any modification/derivatives thereof shall be deemed as
29 //    MStar`s confidential information and you agree to keep MStar`s
30 //    confidential information in strictest confidence and not disclose to any
31 //    third party.
32 //
33 // 4. MStar Software is provided on an "AS IS" basis without warranties of any
34 //    kind. Any warranties are hereby expressly disclaimed by MStar, including
35 //    without limitation, any warranties of merchantability, non-infringement of
36 //    intellectual property rights, fitness for a particular purpose, error free
37 //    and in conformity with any international standard.  You agree to waive any
38 //    claim against MStar for any loss, damage, cost or expense that you may
39 //    incur related to your use of MStar Software.
40 //    In no event shall MStar be liable for any direct, indirect, incidental or
41 //    consequential damages, including without limitation, lost of profit or
42 //    revenues, lost or damage of data, and unauthorized system use.
43 //    You agree that this Section 4 shall still apply without being affected
44 //    even if MStar Software has been modified by MStar in accordance with your
45 //    request or instruction for your use, except otherwise agreed by both
46 //    parties in writing.
47 //
48 // 5. If requested, MStar may from time to time provide technical supports or
49 //    services in relation with MStar Software to you for your use of
50 //    MStar Software in conjunction with your or your customer`s product
51 //    ("Services").
52 //    You understand and agree that, except otherwise agreed by both parties in
53 //    writing, Services are provided on an "AS IS" basis and the warranty
54 //    disclaimer set forth in Section 4 above shall apply.
55 //
56 // 6. Nothing contained herein shall be construed as by implication, estoppels
57 //    or otherwise:
58 //    (a) conferring any license or right to use MStar name, trademark, service
59 //        mark, symbol or any other identification;
60 //    (b) obligating MStar or any of its affiliates to furnish any person,
61 //        including without limitation, you and your customers, any assistance
62 //        of any kind whatsoever, or any information; or
63 //    (c) conferring any license or right under any intellectual property right.
64 //
65 // 7. These terms shall be governed by and construed in accordance with the laws
66 //    of Taiwan, R.O.C., excluding its conflict of law rules.
67 //    Any and all dispute arising out hereof or related hereto shall be finally
68 //    settled by arbitration referred to the Chinese Arbitration Association,
69 //    Taipei in accordance with the ROC Arbitration Law and the Arbitration
70 //    Rules of the Association by three (3) arbitrators appointed in accordance
71 //    with the said Rules.
72 //    The place of arbitration shall be in Taipei, Taiwan and the language shall
73 //    be English.
74 //    The arbitration award shall be final and binding to both parties.
75 //
76 //******************************************************************************
77 //<MStar Software>
78 ////////////////////////////////////////////////////////////////////////////////
79 //
80 // Copyright (c) 2008-2009 MStar Semiconductor, Inc.
81 // All rights reserved.
82 //
83 // Unless otherwise stipulated in writing, any and all information contained
84 // herein regardless in any format shall remain the sole proprietary of
85 // MStar Semiconductor Inc. and be kept in strict confidence
86 // ("MStar Confidential Information") by the recipient.
87 // Any unauthorized act including without limitation unauthorized disclosure,
88 // copying, use, reproduction, sale, distribution, modification, disassembling,
89 // reverse engineering and compiling of the contents of MStar Confidential
90 // Information is unlawful and strictly prohibited. MStar hereby reserves the
91 // rights to any and all damages, losses, costs and expenses resulting therefrom.
92 //
93 ////////////////////////////////////////////////////////////////////////////////
94 
95 ///////////////////////////////////////////////////////////////////////////////////////////////////
96 ///
97 /// @file   _apiVDEC_weak.h
98 /// @brief  VDEC element API
99 /// @author MStar Semiconductor Inc.
100 ///////////////////////////////////////////////////////////////////////////////////////////////////
101 
102 #ifndef _API_VDEC_WEAK_H_
103 #define _API_VDEC_WEAK_H_
104 
105 #include "drvMVD_EX.h"
106 #include "drvHVD_EX.h"
107 
108 #if !defined(MSOS_TYPE_NUTTX) || defined(SUPPORT_X_MODEL_FEATURE)
109 
110 //-------------------------------------------------------------------------------------------------
111 //  Macro and Define
112 //-------------------------------------------------------------------------------------------------
113 #define __vdec_weak      __attribute__((weak))
114 #define __vdec_if            extern
115 
116 //-------------------------------------------------------------------------------------------------
117 //  Function and Variable
118 //-------------------------------------------------------------------------------------------------
119 
120 //======================================================
121 // strong symbol ( necessary!!! can not remove for elf compile envi)
122 __vdec_if MS_BOOL MDrv_MVD_LinkWeakSymbolPatch(void);
123 __vdec_if MS_BOOL MDrv_HVD_LinkWeakSymbolPatch(void);
124 
125 
126 
127 //======================================================
128 // MVD
129 __vdec_if E_MVD_Result MDrv_MVD_SetCfg(MS_U32 u32Id, MVD_FWCfg* fwCfg, MVD_MEMCfg* memCfg) __vdec_weak;
130 __vdec_if MS_U32 MDrv_MVD_GetFWVer(MS_U32 u32Id) __vdec_weak;
131 __vdec_if void MDrv_MVD_SetDbgLevel(MS_U8 level) __vdec_weak;
132 __vdec_if const MVD_DrvInfo* MDrv_MVD_GetInfo(void) __vdec_weak;
133 __vdec_if E_MVD_Result MDrv_MVD_GetLibVer(const MSIF_Version **ppVersion) __vdec_weak;
134 
135 __vdec_if void MDrv_MVD_SetCodecInfo(MS_U32 u32Id, MVD_CodecType u8CodecType, MVD_SrcMode u8BSProviderMode, MS_U8 bDisablePESParsing) __vdec_weak;
136 __vdec_if void MDrv_MVD_SetDivXCfg(MS_U32 u32Id, MS_U8 u8MvAdjust, MS_U8 u8IdctSel) __vdec_weak;
137 
138 __vdec_if void MDrv_MVD_SetFrameBuffAddr(MS_U32 u32Id, MS_VIRT u32addr) __vdec_weak;
139 __vdec_if void MDrv_MVD_GetFrameInfo(MS_U32 u32Id, MVD_FrameInfo *pinfo ) __vdec_weak;
140 __vdec_if void MDrv_MVD_SetOverflowTH (MS_U32 u32Id, MS_U32 u32Threshold) __vdec_weak;
141 __vdec_if void MDrv_MVD_SetUnderflowTH (MS_U32 u32Id, MS_U32 u32Threshold) __vdec_weak;
142 
143 __vdec_if void MDrv_MVD_RstIFrameDec(MS_U32 u32Id,MVD_CodecType eCodecType) __vdec_weak;
144 __vdec_if MS_BOOL MDrv_MVD_GetIsIFrameDecoding(MS_U32 u32Id) __vdec_weak;
145 
146 __vdec_if MS_U8 MDrv_MVD_GetSyncStatus(MS_U32 u32Id) __vdec_weak;
147 __vdec_if MS_U8 MDrv_MVD_GetIsIPicFound(MS_U32 u32Id) __vdec_weak;
148 
149 //for MM
150 __vdec_if MS_U32 MDrv_MVD_GetResidualStreamSize(MS_U32 u32Id) __vdec_weak;
151 
152 __vdec_if MS_BOOL MDrv_MVD_DecodeIFrame(MS_U32 u32Id, MS_PHY u32FrameBufAddr, MS_PHY u32StreamBufAddr, MS_PHY u32StreamBufEndAddr ) __vdec_weak;
153 __vdec_if MS_BOOL MDrv_MVD_GetValidStreamFlag(MS_U32 u32Id) __vdec_weak;
154 
155 //for MM
156 __vdec_if void MDrv_MVD_SetFrameInfo(MS_U32 u32Id, MVD_FrameInfo *pinfo ) __vdec_weak;
157 __vdec_if void MDrv_MVD_GetErrInfo(MS_U32 u32Id, MVD_ErrCode *errCode, MVD_ErrStatus *errStatus) __vdec_weak;
158 __vdec_if MS_U32 MDrv_MVD_GetSkipPicCounter(MS_U32 u32Id) __vdec_weak;
159 
160 __vdec_if MS_U8 MDrv_MVD_GetSLQAvailableLevel(MS_U32 u32Id) __vdec_weak;
161 __vdec_if void MDrv_MVD_SetSLQWritePtr(MS_U32 u32Id, MS_BOOL bCheckData) __vdec_weak;
162 __vdec_if MS_U32 MDrv_MVD_GetSLQReadPtr(MS_U32 u32Id) __vdec_weak;
163 
164 __vdec_if MVD_PicType MDrv_MVD_GetPicType(MS_U32 u32Id) __vdec_weak;
165 __vdec_if MS_U32 MDrv_MVD_GetBitsRate(MS_U32 u32Id) __vdec_weak;
166 __vdec_if MS_U8 MDrv_MVD_GetVideoRange(MS_U32 u32Id) __vdec_weak;
167 __vdec_if MS_BOOL MDrv_MVD_GetLowDelayFlag(MS_U32 u32Id) __vdec_weak;
168 
169 __vdec_if void MDrv_MVD_Pause(MS_U32 u32Id) __vdec_weak;
170 __vdec_if void MDrv_MVD_Resume(MS_U32 u32Id) __vdec_weak;
171 __vdec_if MS_BOOL MDrv_MVD_StepDisp(MS_U32 u32Id) __vdec_weak;
172 __vdec_if MS_BOOL MDrv_MVD_IsStepDispDone(MS_U32 u32Id) __vdec_weak;
173 __vdec_if MS_BOOL MDrv_MVD_StepDecode(MS_U32 u32Id) __vdec_weak;
174 __vdec_if MS_BOOL MDrv_MVD_IsStepDecodeDone(MS_U32 u32Id) __vdec_weak;
175 __vdec_if MS_BOOL MDrv_MVD_SeekToPTS(MS_U32 u32Id, MS_U32 u32Pts) __vdec_weak;
176 __vdec_if MS_BOOL MDrv_MVD_IsStep2PtsDone(MS_U32 u32Id) __vdec_weak;
177 __vdec_if MS_BOOL MDrv_MVD_SkipToPTS(MS_U32 u32Id, MS_U32 u32Pts) __vdec_weak;
178 __vdec_if MS_BOOL MDrv_MVD_TrickPlay(MS_U32 u32Id, MVD_TrickDec trickDec, MS_U8 u8DispDuration) __vdec_weak;
179 __vdec_if void MDrv_MVD_EnableForcePlay(MS_U32 u32Id) __vdec_weak;
180 
181 __vdec_if void MDrv_MVD_RegSetBase(MS_VIRT u32RegBaseAddr) __vdec_weak;
182 __vdec_if MS_BOOL MDrv_MVD_Init(MS_U32 u32Id,MVD_CodecType eCodecType) __vdec_weak;
183 __vdec_if MS_BOOL MDrv_MVD_Exit(MS_U32 u32Id) __vdec_weak;
184 __vdec_if E_MVD_Result MDrv_MVD_Rst(MS_U32 u32Id,MVD_CodecType eCodecType) __vdec_weak;
185 
186 __vdec_if void MDrv_MVD_Play(MS_U32 u32Id) __vdec_weak;
187 __vdec_if void MDrv_MVD_SetAVSync(MS_U32 u32Id, MS_BOOL bEnable, MS_U32 u32Delay) __vdec_weak;
188 __vdec_if MS_U32 MDrv_MVD_GetAVSyncDelay(MS_U32 u32Id) __vdec_weak;
189 __vdec_if MS_BOOL MDrv_MVD_GetIsAVSyncOn(MS_U32 u32Id) __vdec_weak;
190 __vdec_if MS_BOOL MDrv_MVD_GetIsSyncRep(MS_U32 u32Id) __vdec_weak;
191 __vdec_if MS_BOOL MDrv_MVD_GetIsSyncSkip(MS_U32 u32Id) __vdec_weak;
192 __vdec_if MS_BOOL MDrv_MVD_ChangeAVsync(MS_U32 u32Id, MS_BOOL bEnable, MS_U16 u16PTS) __vdec_weak;
193 __vdec_if MS_BOOL MDrv_MVD_DispCtrl(MS_U32 u32Id, MS_BOOL bDecOrder, MS_BOOL bDropErr, MS_BOOL bDropDisp, MVD_FrcMode eFrcMode) __vdec_weak;
194 __vdec_if MS_BOOL MDrv_MVD_DispRepeatField(MS_U32 u32Id, MS_BOOL bEnable) __vdec_weak;
195 
196 __vdec_if MS_U8 MDrv_MVD_GetActiveFormat(MS_U32 u32Id) __vdec_weak;
197 __vdec_if MS_U8 MDrv_MVD_GetDispRdy(MS_U32 u32Id) __vdec_weak;
198 __vdec_if MS_BOOL MDrv_MVD_Is1stFrmRdy(MS_U32 u32Id) __vdec_weak;
199 __vdec_if MS_U32 MDrv_MVD_GetGOPCount(MS_U32 u32Id) __vdec_weak;
200 __vdec_if MS_U32 MDrv_MVD_GetPicCounter(MS_U32 u32Id) __vdec_weak;
201 __vdec_if MS_U32 MDrv_MVD_GetParserByteCnt(MS_U32 u32Id) __vdec_weak;
202 __vdec_if MVD_DecStat MDrv_MVD_GetDecodeStatus(MS_U32 u32Id) __vdec_weak;
203 __vdec_if MS_U8 MDrv_MVD_GetLastCmd(MS_U32 u32Id) __vdec_weak;
204 __vdec_if MS_U32 MDrv_MVD_GetVldErrCount(MS_U32 u32Id) __vdec_weak;
205 __vdec_if MS_BOOL MDrv_MVD_DropErrorFrame(MS_U32 u32Id, MS_BOOL bDrop) __vdec_weak;
206 __vdec_if MS_BOOL MDrv_MVD_MVDCommand ( MS_U8 u8cmd, MVD_CmdArg *pstCmdArg ) __vdec_weak;
207 __vdec_if MS_BOOL MDrv_MVD_SkipData(MS_U32 u32Id) __vdec_weak;
208 __vdec_if MS_BOOL MDrv_MVD_SkipToIFrame(MS_U32 u32Id) __vdec_weak;
209 __vdec_if MS_BOOL MDrv_MVD_GetCaps(MVD_Caps* pCaps) __vdec_weak;
210 
211 __vdec_if E_MVD_Result MDrv_MVD_DisableErrConceal(MS_U32 u32Id, MS_BOOL bDisable) __vdec_weak;
212 __vdec_if E_MVD_Result MDrv_MVD_PushQueue(MS_U32 u32Id, MVD_PacketInfo* pInfo) __vdec_weak;
213 __vdec_if E_MVD_Result MDrv_MVD_FlushQueue(MS_U32 u32Id) __vdec_weak;
214 __vdec_if MS_BOOL MDrv_MVD_FlushDisplayBuf(MS_U32 u32Id) __vdec_weak;
215 __vdec_if MS_U32 MDrv_MVD_GetQueueVacancy(MS_U32 u32Id, MS_BOOL bCached) __vdec_weak;
216 __vdec_if MS_U32 MDrv_MVD_GetESReadPtr(MS_U32 u32Id) __vdec_weak;
217 __vdec_if MS_U32 MDrv_MVD_GetESWritePtr(MS_U32 u32Id) __vdec_weak;
218 __vdec_if E_MVD_Result MDrv_MVD_EnableLastFrameShow(MS_U32 u32Id, MS_BOOL bEnable) __vdec_weak;
219 __vdec_if E_MVD_Result MDrv_MVD_IsDispFinish(MS_U32 u32Id) __vdec_weak;
220 __vdec_if E_MVD_Result MDrv_MVD_SetSpeed(MS_U32 u32Id, MVD_SpeedType eSpeedType, MS_U8 u8Multiple) __vdec_weak;
221 __vdec_if E_MVD_Result MDrv_MVD_ResetPTS(MS_U32 u32Id, MS_U32 u32PtsBase) __vdec_weak;
222 __vdec_if MS_U32 MDrv_MVD_GetPTS(MS_U32 u32Id) __vdec_weak;
223 __vdec_if MVD_TrickDec MDrv_MVD_GetTrickMode(MS_U32 u32Id) __vdec_weak;
224 __vdec_if MS_BOOL MDrv_MVD_IsPlaying(MS_U32 u32Id) __vdec_weak;
225 __vdec_if MS_BOOL MDrv_MVD_IsIdle(MS_U32 u32Id) __vdec_weak;
226 __vdec_if MS_BOOL MDrv_MVD_IsSeqChg(MS_U32 u32Id) __vdec_weak;
227 __vdec_if E_MVD_Result MDrv_MVD_DbgSetData(MS_U32 u32Id, MS_VIRT u32Addr, MS_U32 u32Data) __vdec_weak;
228 __vdec_if E_MVD_Result MDrv_MVD_DbgGetData(MS_U32 u32Id, MS_VIRT u32Addr, MS_U32* u32Data) __vdec_weak;
229 __vdec_if MS_U8 MDrv_MVD_GetDecodedFrameIdx (MS_U32 u32Id) __vdec_weak;
230 __vdec_if MS_BOOL MDrv_MVD_SetFileModeAVSync(MS_U32 u32Id, MVD_TIMESTAMP_TYPE eSyncMode) __vdec_weak;
231 __vdec_if MS_BOOL MDrv_MVD_IsAllBufferEmpty(MS_U32 u32Id) __vdec_weak;
232 __vdec_if MS_BOOL MDrv_MVD_GenPattern(MS_U32 u32Id, MVD_PatternType ePattern, MS_PHY u32PAddr, MS_U32* pu32Size) __vdec_weak;
233 __vdec_if MS_U32 MDrv_MVD_GetPatternInfo(void) __vdec_weak;
234 __vdec_if MS_BOOL MDrv_MVD_SetVirtualBox(MS_U32 u32Id, MS_U16 u16Width, MS_U16 u16Height) __vdec_weak;
235 __vdec_if MS_BOOL MDrv_MVD_SetBlueScreen(MS_U32 u32Id, MS_BOOL bEn) __vdec_weak;
236 __vdec_if E_MVD_Result MDrv_MVD_EnableDispOneField(MS_U32 u32Id, MS_BOOL bEn) __vdec_weak;
237 __vdec_if E_MVD_Result MDrv_MVD_GetFrmInfo(MS_U32 u32Id, MVD_FrmInfoType eType, MVD_FrmInfo* pInfo) __vdec_weak;
238 __vdec_if E_MVD_Result MDrv_MVD_SetFreezeDisp(MS_U32 u32Id, MS_BOOL bEn) __vdec_weak;
239 __vdec_if MS_BOOL MDrv_MVD_SetVSizeAlign(MS_U32 u32Id, MS_BOOL bEnable) __vdec_weak;
240 __vdec_if void MDrv_MVD_DbgDump(MS_U32 u32Id) __vdec_weak;
241 __vdec_if void MDrv_MVD_SetAVSyncThreshold(MS_U32 u32Id, MS_U32 u32Th) __vdec_weak;
242 __vdec_if E_MVD_Result MDrv_MVD_SetFdMaskDelayCount(MS_U32 u32Id, MS_U16 u16Cnt) __vdec_weak;
243 __vdec_if E_MVD_Result MDrv_MVD_SetOutputFRCMode(MS_U32 u32Id, MS_U8 u8FrameRate, MS_U8 u8Interlace) __vdec_weak;
244 __vdec_if E_MVD_Result MDrv_MVD_SetFRCDropType(MS_U32 u32Id, MS_U8 u8DropType) __vdec_weak;
245 __vdec_if E_MVD_Result MDrv_MVD_SetDisableSeqChange(MS_U32 u32Id, MS_BOOL bEnable) __vdec_weak;
246 __vdec_if MS_BOOL MDrv_MVD_ParserRstDone(MS_U32 u32Id, MS_BOOL bEnable) __vdec_weak;
247 __vdec_if MS_U32 MDrv_MVD_GetChromaFormat(MS_U32 u32Id) __vdec_weak;
248 __vdec_if MS_BOOL MDrv_MVD_SetMcuMode(MS_U32 u32Id, MS_U8 u8Mode) __vdec_weak;
249 __vdec_if MS_BOOL MDrv_MVD_ReleaseFdMask(MS_U32 u32Id, MS_BOOL bRls) __vdec_weak;
250 __vdec_if MS_BOOL MDrv_MVD_ShowDecodeOrder(MS_U32 u32Id, MS_U8 u8Mode) __vdec_weak;
251 __vdec_if MS_BOOL MDrv_MVD_SuspendDynamicScale(MS_U32 u32Id, MS_BOOL bEnable) __vdec_weak;
252 __vdec_if E_MVD_Result MDrv_MVD_SetAutoMute(MS_U32 u32Id, MS_BOOL bEnable) __vdec_weak;
253 __vdec_if E_MVD_Result MDrv_MVD_SetDispFinishMode(MS_U32 u32Id,MS_U8 u8Mode) __vdec_weak;
254 __vdec_if E_MVD_Result MDrv_MVD_SetAVSyncMode(MS_U8 u8Mode) __vdec_weak;
255 __vdec_if MS_BOOL MDrv_MVD_SetIdctMode(MS_U32 u32Id, MS_U8 u8Mode) __vdec_weak;
256 __vdec_if E_MVD_Result MDrv_MVD_EX_SetMVDClockSpeed(MVD_EX_ClockSpeed eClockSpeed) __vdec_weak;
257 __vdec_if E_MVD_Result MDrv_MVD_SetDbgMode(MS_U32 u32Id, MVD_DbgMode enDbgMode, MS_BOOL bEn) __vdec_weak;
258 __vdec_if MS_BOOL MDrv_MVD_FlushPTSBuf(MS_U32 u32Id,MS_BOOL bEnable) __vdec_weak;
259 __vdec_if MS_U8 MDrv_MVD_GetMatrixCoef(MS_U32 u32Id) __vdec_weak;
260 __vdec_if MS_BOOL MDrv_MVD_GetIsDynScalingEnabled(MS_U32 u32Id) __vdec_weak;
261 __vdec_if MS_BOOL MDrv_MVD_SetSingleDecodeMode(MS_BOOL bEnable) __vdec_weak;
262 __vdec_if MS_U64 MDrv_MVD_GetU64PTS(MS_U32 u32Id) __vdec_weak;
263 __vdec_if MS_BOOL MDrv_MVD_GetIs32PullDown(MS_U32 u32Id) __vdec_weak;
264 __vdec_if MS_S32 MDrv_MVD_GetPtsStcDiff(MS_U32 u32Id) __vdec_weak;
265 __vdec_if void MDrv_MVD_SetAVSyncFreerunThreshold(MS_U32 u32Id, MS_U32 u32Th) __vdec_weak;
266 __vdec_if MS_BOOL MDrv_MVD_GetIsFreerun(MS_U32 u32Id) __vdec_weak;
267 __vdec_if MS_U32 MDrv_MVD_GetNextPTS(MS_U32 u32Id) __vdec_weak;
268 __vdec_if MS_U8 MDrv_MVD_GetColorFormat(MS_U32 u32Id) __vdec_weak;
269 __vdec_if E_MVD_Result MDrv_MVD_SetDynScalingParam(MS_U32 u32Id, MS_PHY u32StAddr, MS_VIRT u32Size) __vdec_weak;
270 __vdec_if E_MVD_Result MDrv_MVD_GetExtDispInfo(MS_U32 u32Id, MVD_ExtDispInfo* pInfo) __vdec_weak;
271 __vdec_if E_MVD_Result MDrv_MVD_GetTimeCode(MS_U32 u32Id, MVD_FrmInfoType eType, MVD_TimeCode* pInfo) __vdec_weak;
272 __vdec_if MS_BOOL MDrv_MVD_GetUsrDataIsAvailable(MS_U32 u32Id) __vdec_weak;
273 __vdec_if MS_BOOL MDrv_MVD_GetUsrDataInfo(MS_U32 u32Id, MVD_UsrDataInfo* pUsrInfo) __vdec_weak;
274 __vdec_if MS_U32 MDrv_MVD_GetDispCount(MS_U32 u32Id) __vdec_weak;
275 __vdec_if MS_BOOL MDrv_MVD_SetMStreamerMode(MS_U32 u32Id, MS_U8 u8Mode) __vdec_weak;
276 __vdec_if MS_BOOL MDrv_MVD_FrameFlip(MS_U32 u32Id, MS_U8 u8FrmIdx) __vdec_weak;
277 __vdec_if MS_BOOL MDrv_MVD_FrameRelease(MS_U32 u32Id, MS_U8 u8FrmIdx) __vdec_weak;
278 __vdec_if MS_BOOL MDrv_MVD_FrameCapture(MS_U32 u32Id, MS_U8 u8FrmIdx, MS_BOOL bEnable) __vdec_weak;
279 __vdec_if E_MVD_Result MDrv_MVD_Init_Share_Mem(void) __vdec_weak;
280 __vdec_if E_MVD_Result MDrv_MVD_GetFreeStream(MS_U32 *pu32Id, MVD_DRV_StreamType eStreamType) __vdec_weak;
281 __vdec_if MS_U32 MDrv_MVD_GetSLQNum(MS_U32 u32Id) __vdec_weak;
282 __vdec_if MS_BOOL MDrv_MVD_GetFrmRateIsSupported(MS_U32 u32Id) __vdec_weak;
283 __vdec_if E_MVD_Result MDrv_MVD_GetCrcValue(MS_U32 u32Id, MVD_CrcIn *pCrcIn, MVD_CrcOut *pCrcOut) __vdec_weak;
284 __vdec_if MS_U32 MDrv_MVD_GetDispQNum(MS_U32 u32Id) __vdec_weak;
285 __vdec_if MS_U32 MDrv_MVD_GetDivxVer(MS_U32 u32Id) __vdec_weak;
286 
287 #ifdef MVD_ENABLE_ISR
288 __vdec_if E_MVD_Result MDrv_MVD_SetIsrEvent(MS_U32 u32Id, MS_U32 eEvent, MVD_InterruptCb fnHandler) __vdec_weak;
289 __vdec_if MS_U32 MDrv_MVD_GetIsrEvent(MS_U32 u32Id) __vdec_weak;
290 #else
291 #define MDrv_MVD_SetIsrEvent(x, y, z) (E_MVD_RET_OK)
292 #define MDrv_MVD_GetIsrEvent(x)     (MVD_Event)0
293 #endif
294 
295 
296 //======================================================
297 // HVD
298 __vdec_if void MDrv_HVD_EX_PowerCtrl(MS_BOOL bEnable) __vdec_weak;
299 __vdec_if void MDrv_HVD_EX_SetOSRegBase(MS_U32 u32RegBaseAddr) __vdec_weak;
300 __vdec_if HVD_EX_Result MDrv_HVD_EX_Init(MS_U32 u32Id, HVD_EX_MemCfg *mem, HVD_EX_InitSettings *InitParam) __vdec_weak;
301 __vdec_if HVD_EX_Result MDrv_HVD_EX_Rst(MS_U32 u32Id, MS_BOOL bErrHandle) __vdec_weak;
302 __vdec_if HVD_EX_Result MDrv_HVD_EX_Play(MS_U32 u32Id) __vdec_weak;
303 __vdec_if HVD_EX_Result MDrv_HVD_EX_Exit(MS_U32 u32Id) __vdec_weak;
304 __vdec_if HVD_EX_Result MDrv_HVD_EX_Pause(MS_U32 u32Id) __vdec_weak;
305 __vdec_if HVD_EX_Result MDrv_HVD_EX_Flush(MS_U32 u32Id, MS_BOOL bShowLast) __vdec_weak;
306 __vdec_if HVD_EX_Result MDrv_HVD_EX_StepDisp(MS_U32 u32Id) __vdec_weak;
307 __vdec_if HVD_EX_Result MDrv_HVD_EX_StepDecode(MS_U32 u32Id) __vdec_weak;
308 __vdec_if HVD_EX_Result MDrv_HVD_EX_PushQueue(MS_U32 u32Id, HVD_EX_PacketInfo *pInfo) __vdec_weak;
309 __vdec_if HVD_EX_Result MDrv_HVD_EX_PushQueue_Fire(MS_U32 u32Id) __vdec_weak;
310 __vdec_if HVD_EX_Result MDrv_HVD_EX_DecodeIFrame(MS_U32 u32Id, MS_PHY u32SrcSt, MS_VIRT u32SrcSize) __vdec_weak;
311 
312 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetDataEnd(MS_U32 u32Id, MS_BOOL bEnd) __vdec_weak;
313 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetDispErrFrm(MS_U32 u32Id, MS_BOOL bEnable) __vdec_weak;
314 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetDispRepeatField(MS_U32 u32Id, MS_BOOL bEnable) __vdec_weak;
315 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetSkipDecMode(MS_U32 u32Id, HVD_EX_SkipDecode eDecType) __vdec_weak;
316 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetDispSpeed(MS_U32 u32Id, HVD_EX_DispSpeed eSpeed) __vdec_weak;
317 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetSyncActive(MS_U32 u32Id, MS_BOOL bEnable) __vdec_weak;
318 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetDropMode(MS_U32 u32Id, HVD_EX_DropDisp eMode , MS_U32 u32Arg) __vdec_weak;
319 __vdec_if HVD_EX_Result MDrv_HVD_EX_RstPTS(MS_U32 u32Id, MS_U32 u32PTS) __vdec_weak;
320 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetFrcMode(MS_U32 u32Id, HVD_EX_FrmRateConvMode eMode) __vdec_weak;
321 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetSyncTolerance(MS_U32 u32Id, MS_U32 u32Arg) __vdec_weak;
322 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetSyncVideoDelay(MS_U32 u32Id, MS_U32 u32Arg) __vdec_weak;
323 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetSyncFreeRunTH(MS_U32 u32Id, MS_U32 u32Arg) __vdec_weak;
324 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetSyncRepeatTH(MS_U32 u32Id, MS_U32 u32Arg) __vdec_weak;
325 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetErrConceal(MS_U32 u32Id, MS_BOOL u32Arg) __vdec_weak;
326 __vdec_if void MDrv_HVD_EX_SetDbgLevel(HVD_EX_UartLevel elevel) __vdec_weak;
327 __vdec_if HVD_EX_Result MDrv_HVD_EX_SeekToPTS(MS_U32 u32Id, MS_U32 u32PTS) __vdec_weak;
328 __vdec_if HVD_EX_Result MDrv_HVD_EX_SkipToPTS(MS_U32 u32Id, MS_U32 u32PTS) __vdec_weak;
329 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetFreezeImg(MS_U32 u32Id, MS_BOOL bEnable) __vdec_weak;
330 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetBlueScreen(MS_U32 u32Id, MS_BOOL bEnable) __vdec_weak;
331 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetDispOneField(MS_U32 u32Id, MS_BOOL bEnable) __vdec_weak;
332 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetISREvent(MS_U32 u32Id, MS_U32 u32Event ,HVD_InterruptCb fnISRHandler) __vdec_weak;
333 __vdec_if MS_BOOL MDrv_HVD_EX_SetEnableISR(MS_U32 u32Id, MS_BOOL bEnable) __vdec_weak;
334 __vdec_if MS_BOOL MDrv_HVD_EX_SetForceISR(MS_U32 u32Id, MS_BOOL bEnable) __vdec_weak;
335 __vdec_if MS_BOOL MDrv_HVD_EX_SetMVOPDone(MS_U32 u32Id) __vdec_weak;
336 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetVirtualBox(MS_U32 u32Id, MS_U16 u16Width, MS_U16 u16Height) __vdec_weak;
337 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetDynScalingParam(MS_U32 u32Id, void *pStAddr, MS_U32 u32Size) __vdec_weak;
338 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetAutoRmLstZeroByte(MS_U32 u32Id, MS_BOOL bOn) __vdec_weak;
339 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetDispInfoTH(MS_U32 u32Id, HVD_EX_DispInfoThreshold* DispInfoTH ) __vdec_weak;
340 
341 __vdec_if MS_BOOL MDrv_HVD_EX_IsISROccured(MS_U32 u32Id) __vdec_weak;
342 __vdec_if MS_BOOL MDrv_HVD_EX_IsDispFinish(MS_U32 u32Id) __vdec_weak;
343 __vdec_if MS_BOOL MDrv_HVD_EX_IsFrameShowed(MS_U32 u32Id) __vdec_weak;
344 __vdec_if MS_BOOL MDrv_HVD_EX_IsStepDecodeDone(MS_U32 u32Id) __vdec_weak;
345 __vdec_if HVD_EX_Result MDrv_HVD_EX_CheckDispInfoRdy(MS_U32 u32Id) __vdec_weak;
346 __vdec_if MS_BOOL MDrv_HVD_EX_IsDispInfoChg(MS_U32 u32Id) __vdec_weak;
347 __vdec_if MS_BOOL MDrv_HVD_EX_IsIdle(MS_U32 u32Id) __vdec_weak;
348 __vdec_if MS_BOOL MDrv_HVD_EX_IsSyncStart(MS_U32 u32Id) __vdec_weak;
349 __vdec_if MS_BOOL MDrv_HVD_EX_IsSyncReach(MS_U32 u32Id) __vdec_weak;
350 __vdec_if MS_BOOL MDrv_HVD_EX_IsLowDelay(MS_U32 u32Id) __vdec_weak;
351 __vdec_if MS_BOOL MDrv_HVD_EX_IsIFrmFound(MS_U32 u32Id) __vdec_weak;
352 __vdec_if MS_BOOL MDrv_HVD_EX_Is1stFrmRdy(MS_U32 u32Id) __vdec_weak;
353 __vdec_if MS_BOOL MDrv_HVD_EX_IsAllBufferEmpty(MS_U32 u32Id) __vdec_weak;
354 __vdec_if HVD_EX_Result MDrv_HVD_EX_IsAlive(MS_U32 u32Id) __vdec_weak;
355 
356 __vdec_if MS_U32 MDrv_HVD_EX_GetBBUVacancy(MS_U32 u32Id) __vdec_weak;
357 __vdec_if HVD_EX_Result MDrv_HVD_EX_GetDispInfo(MS_U32 u32Id, HVD_EX_DispInfo *pinfo) __vdec_weak;
358 __vdec_if MS_U32 MDrv_HVD_EX_GetPTS(MS_U32 u32Id) __vdec_weak;
359 __vdec_if MS_U32 MDrv_HVD_EX_GetDataErrCnt(MS_U32 u32Id) __vdec_weak;
360 __vdec_if MS_U32 MDrv_HVD_EX_GetDecErrCnt(MS_U32 u32Id) __vdec_weak;
361 __vdec_if MS_U32 MDrv_HVD_EX_GetESWritePtr(MS_U32 u32Id) __vdec_weak;
362 __vdec_if MS_U32 MDrv_HVD_EX_GetESReadPtr(MS_U32 u32Id) __vdec_weak;
363 __vdec_if MS_U32 MDrv_HVD_EX_GetESQuantity(MS_U32 u32Id) __vdec_weak;
364 __vdec_if MS_BOOL MDrv_HVD_EX_GetCaps(HVD_EX_Codec u32Type) __vdec_weak;
365 __vdec_if MS_U32 MDrv_HVD_EX_GetErrCode(MS_U32 u32Id) __vdec_weak;
366 __vdec_if MS_U32 MDrv_HVD_EX_GetPlayMode(MS_U32 u32Id, HVD_EX_GetModeStatus eMode) __vdec_weak;
367 __vdec_if HVD_EX_GetPlayState MDrv_HVD_EX_GetPlayState(MS_U32 u32Id) __vdec_weak;
368 __vdec_if MS_U32 MDrv_HVD_EX_GetDecodeCnt(MS_U32 u32Id) __vdec_weak;
369 __vdec_if MS_U8 MDrv_HVD_EX_GetActiveFormat(MS_U32 u32Id) __vdec_weak;
370 __vdec_if const HVD_EX_DrvInfo* MDrv_HVD_EX_GetInfo( void ) __vdec_weak;
371 __vdec_if HVD_EX_Result MDrv_HVD_EX_GetLibVer(const MSIF_Version **ppVersion) __vdec_weak;
372 __vdec_if MS_BOOL MDrv_HVD_EX_GetStatus(MS_U32 u32Id, HVD_EX_DrvStatus *pstatus) __vdec_weak;
373 __vdec_if HVD_EX_Result MDrv_HVD_EX_GetFrmInfo(MS_U32 u32Id, HVD_EX_GetFrmInfoType eType, HVD_EX_FrameInfo *pInfo) __vdec_weak;
374 __vdec_if MS_BOOL MDrv_HVD_EX_GetISRInfo(MS_U32 u32Id, MS_U32* eType) __vdec_weak;
375 __vdec_if MS_U32 MDrv_HVD_EX_CalLumaSum(MS_U32 u32Id, HVD_EX_GetFrmInfoType eType) __vdec_weak;
376 __vdec_if MS_U32 MDrv_HVD_EX_GetUserData_Wptr(MS_U32 u32Id) __vdec_weak;
377 __vdec_if MS_U32 MDrv_HVD_EX_GetUserData_Packet(MS_U32 u32Id, MS_U32 u32Idx , MS_U32* u32Size) __vdec_weak;
378 __vdec_if HVD_EX_Result MDrv_HVD_EX_GenPattern(MS_U32 u32Id, HVD_EX_PatternType eType, MS_U32 u32VAddr, MS_U32 *u32Size) __vdec_weak;
379 __vdec_if MS_U32 MDrv_HVD_EX_GetPatternInfo(MS_U32 u32Id, HVD_EX_PatternInfo eType) __vdec_weak;
380 __vdec_if MS_U32 MDrv_HVD_EX_GetDynamicScalingInfo(MS_U32 u32Id, HVD_EX_DynamicScalingInfo eType) __vdec_weak;
381 
382 __vdec_if MS_U32 MDrv_HVD_EX_GetData(MS_U32 u32Id, HVD_EX_GDataType eType) __vdec_weak;
383 __vdec_if MS_U32 MDrv_HVD_EX_GetMem_Dbg(MS_U32 u32Id, MS_VIRT u32Addr) __vdec_weak;
384 __vdec_if void MDrv_HVD_EX_DbgDumpStatus(MS_U32 u32Id, HVD_EX_DumpStatus eFlag) __vdec_weak;
385 __vdec_if void MDrv_HVD_EX_SetMem_Dbg(MS_U32 u32Id, MS_VIRT u32Addr, MS_U32 u32Arg) __vdec_weak;
386 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetCmd_Dbg(MS_U32 u32Id, MS_U32 u32Cmd, MS_U32 u32Arg) __vdec_weak;
387 __vdec_if HVD_EX_Result MDrv_HVD_EX_SetSettings_Pro(MS_U32 u32Id, HVD_EX_SSettingsType eType, MS_U32 u32Arg) __vdec_weak;
388 __vdec_if HVD_EX_Result MDrv_HVD_EX_DispOutsideMode(MS_U32 u32Id, MS_BOOL bEnable) __vdec_weak;
389 #endif
390 #endif // _API_VDEC_WEAK_H_
391