Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1026 lines
35 KiB

  1. /* *************************************************************************
  2. ** INTEL Corporation Proprietary Information
  3. **
  4. ** This listing is supplied under the terms of a license
  5. ** agreement with INTEL Corporation and may not be copied
  6. ** nor disclosed except in accordance with the terms of
  7. ** that agreement.
  8. **
  9. ** Copyright (c) 1995,1996 Intel Corporation.
  10. ** All Rights Reserved.
  11. **
  12. ** *************************************************************************
  13. */
  14. //
  15. // This module is based on drvmain.c, Rev 1.24, 28 Apr 1995, from the
  16. // MRV video codec driver.
  17. //
  18. // $Author: JMCVEIGH $
  19. // $Date: 17 Apr 1997 17:04:04 $
  20. // $Archive: S:\h26x\src\common\cdrvproc.cpv $
  21. // $Header: S:\h26x\src\common\cdrvproc.cpv 1.39 17 Apr 1997 17:04:04 JMCVEIGH $
  22. //
  23. ////////////////////////////////////////////////////////////////////////////
  24. #include "precomp.h"
  25. #include <oprahcom.h>
  26. // #define TIMING 1
  27. // Timing process - for decode turn on in
  28. // CDRVPROC.CPP and D1DEC.CPP
  29. #if TIMING
  30. char szTMsg[80];
  31. unsigned long tmr_time = 0L;
  32. unsigned long tmr_frms = 0L;
  33. #endif
  34. HINSTANCE hDriverModule; // the instance-handle of this driver set in LibMain
  35. #if defined(H263P)
  36. extern BOOL MMX_Enabled;
  37. BOOL MMXDecoder_Enabled;
  38. #define _PENTIUM_PROCESSOR 1
  39. #define _PENTIUM_PRO_PROCESSOR 2
  40. #define _PENTIUM_MMX_PROCESSOR 3
  41. #define _PENTIUM_PRO_MMX_PROCESSOR 4
  42. #endif
  43. /* load free handshake */
  44. static int Loaded = 0; /* 0 prior to first DRV_LOAD and after DRV_FREE */
  45. #ifdef DEBUG
  46. HDBGZONE ghDbgZoneH261 = NULL;
  47. static PTCHAR _rgZonesH261[] = {
  48. TEXT("M261"),
  49. TEXT("Bitrate Control"),
  50. TEXT("Bitrate Control Details")
  51. };
  52. int WINAPI H261DbgPrintf(LPTSTR lpszFormat, ... )
  53. {
  54. va_list v1;
  55. va_start(v1, lpszFormat);
  56. DbgPrintf("M261", lpszFormat, v1);
  57. va_end(v1);
  58. return TRUE;
  59. }
  60. #endif /* DEBUG */
  61. #if (defined(H261) || defined(H263))
  62. /* Suppress FP thunking for now, for H261 and H263.
  63. Thunking currently has the side effect of masking floating point exceptions,
  64. which can cause exceptions like divide by zero to go undetected.
  65. */
  66. #define FPThunking 0
  67. #else
  68. #define FPThunking 1
  69. #endif
  70. #if FPThunking
  71. ////////////////////////////////////////////////////////////////////////////
  72. // These two routines are necessary to permit a 16 bit application call //
  73. // a 32 bit codec under Windows /95. The Windows /95 thunk doesn't save //
  74. // or restore the Floating Point State. -Ben- 07/12/96 //
  75. // //
  76. U16 ThnkFPSetup(void) //
  77. { //
  78. U16 wOldFPState; //
  79. U16 wNewFPState = 0x027f; //
  80. //
  81. __asm //
  82. { //
  83. fnstcw WORD PTR [wOldFPState] //
  84. fldcw WORD PTR [wNewFPState] //
  85. } //
  86. //
  87. return(wOldFPState); //
  88. } //
  89. //
  90. void ThnkFPRestore(U16 wFPState) //
  91. { //
  92. __asm //
  93. { //
  94. fldcw WORD PTR [wFPState] //
  95. } //
  96. //
  97. return; //
  98. } //
  99. ////////////////////////////////////////////////////////////////////////////
  100. #endif /* FPThunking */
  101. ;////////////////////////////////////////////////////////////////////////////
  102. ;// Function: LRESULT WINAPI _loadds DriverProc(DWORD, HDRVR, UINT, LPARAM, LPARAM);
  103. ;//
  104. ;// Description: Added Header.
  105. ;//
  106. ;// History: 02/18/94 -BEN-
  107. ;////////////////////////////////////////////////////////////////////////////
  108. LRESULT WINAPI DriverProc(
  109. DWORD dwDriverID,
  110. HDRVR hDriver,
  111. UINT uiMessage,
  112. LPARAM lParam1,
  113. LPARAM lParam2
  114. )
  115. {
  116. SYSTEM_INFO sysinfo;
  117. LRESULT rval = 0;
  118. LPINST pi;
  119. ICDECOMPRESSEX ICDecExSt;
  120. ICDECOMPRESSEX DefaultICDecExSt = {
  121. 0,
  122. NULL, NULL,
  123. NULL, NULL,
  124. 0, 0, 0, 0,
  125. 0, 0, 0, 0
  126. };
  127. int nOn486;
  128. #if FPThunking
  129. U16 u16FPState = ThnkFPSetup();
  130. #endif
  131. try
  132. {
  133. pi = (LPINST)dwDriverID;
  134. switch(uiMessage)
  135. {
  136. case DRV_LOAD:
  137. DBOUT("DRV_LOAD");
  138. /*
  139. Sent to the driver when it is loaded. Always the first
  140. message received by a driver.
  141. dwDriverID is 0L.
  142. lParam1 is 0L.
  143. lParam2 is 0L.
  144. Return 0L to fail the load.
  145. */
  146. // put global initialization here...
  147. if(Loaded) {
  148. /* We used to return an undefined value here. It's unclear
  149. * whether this load should succeed, and if so, how or if
  150. * we need to modify our memory usage to be truly reentrant.
  151. * For now, let's explicitly fail this load attempt.
  152. */
  153. rval = 0;
  154. break;
  155. }
  156. Loaded = 1;
  157. if(!DrvLoad())
  158. {
  159. rval = 0;
  160. Loaded = 0;
  161. break;
  162. }
  163. rval = (LRESULT)TRUE;
  164. break;
  165. case DRV_FREE:
  166. DBOUT("DRV_FREE");
  167. /*
  168. Sent to the driver when it is about to be discarded. This
  169. will always be the last message received by a driver before
  170. it is freed.
  171. dwDriverID is 0L.
  172. lParam1 is 0L.
  173. lParam2 is 0L.
  174. Return value is ignored.
  175. */
  176. // put global de-initialization here...
  177. if(!Loaded)
  178. break;
  179. Loaded = 0;
  180. DrvFree();
  181. rval = (LRESULT)TRUE;
  182. break;
  183. /*********************************************************************
  184. * standard driver messages
  185. *********************************************************************/
  186. case DRV_DISABLE:
  187. case DRV_ENABLE:
  188. DBOUT("DRV_ENABLE / DRV_DISABLE");
  189. rval = (LRESULT)1L;
  190. break;
  191. case DRV_INSTALL:
  192. case DRV_REMOVE:
  193. DBOUT("DRV_INSTALL / DRV_REMOVE");
  194. rval = (LRESULT)DRV_OK;
  195. break;
  196. case DRV_OPEN:
  197. DBOUT("DRV_OPEN");
  198. /*
  199. Sent to the driver when it is opened.
  200. dwDriverID is 0L.
  201. lParam1 is a far pointer to a zero-terminated string
  202. containing the name used to open the driver.
  203. lParam2 is passed through from the drvOpen call. It is
  204. NULL if this open is from the Drivers Applet in control.exe
  205. It is a far pointer to an ICOPEN data structure otherwise.
  206. Return 0L to fail the open. Otherwise return a value that the
  207. system will use for dwDriverID in subsequent messages. In our
  208. case, we return a pointer to our INSTINFO data structure.
  209. */
  210. if (lParam2 == 0)
  211. { /* indicate we do process DRV_OPEN */
  212. rval = 0xFFFF0000;
  213. break;
  214. }
  215. /* if asked to draw, fail */
  216. if(((ICOPEN FAR *)lParam2)->dwFlags & ICMODE_DRAW)
  217. {
  218. DBOUT("DrvOpen wants ICMODE_DRAW");
  219. rval = 0L;
  220. break;
  221. }
  222. if((pi = DrvOpen((ICOPEN FAR *) lParam2)) == NULL)
  223. {
  224. DBOUT("DrvOpen failed ICERR_MEMORY");
  225. // We must return NULL on failure. We used to return
  226. // ICERR_MEMORY = -3, which implies a driver was opened
  227. rval = (LRESULT)0L;
  228. break;
  229. }
  230. rval = (LRESULT)pi;
  231. break;
  232. case DRV_CLOSE:
  233. DBOUT("DRV_CLOSE");
  234. if(pi != (tagINSTINFO*)0 && pi != (tagINSTINFO*)0xFFFF0000)
  235. DrvClose(pi);
  236. rval = (LRESULT)1L;
  237. break;
  238. //**************************
  239. // state messages
  240. //**************************
  241. case DRV_QUERYCONFIGURE:// configuration from drivers applet
  242. DBOUT("DRV_QUERYCONFIGURE");
  243. // this is a GLOBAL query configure
  244. rval = (LRESULT)0L;
  245. break;
  246. case DRV_CONFIGURE:
  247. DBOUT("DRV_CONFIGURE");
  248. rval = DrvConfigure((HWND)lParam1);
  249. break;
  250. case ICM_CONFIGURE:
  251. DBOUT("ICM_CONFIGURE");
  252. //#ifndef H261
  253. // This message is used to add extensions to the encode dialog box.
  254. // rval = Configure((HWND)lParam1);
  255. // #else
  256. rval = ICERR_UNSUPPORTED;
  257. // #endif
  258. break;
  259. case ICM_ABOUT:
  260. DBOUT("ICM_ABOUT");
  261. rval = About((HWND)lParam1);
  262. break;
  263. case ICM_GETSTATE:
  264. DBOUT("ICM_GETSTATE");
  265. rval = DrvGetState(pi, (LPVOID)lParam1, (DWORD)lParam2);
  266. break;
  267. case ICM_SETSTATE:
  268. DBOUT("ICM_SETSTATE");
  269. rval = DrvSetState(pi, (LPVOID)lParam1, (DWORD)lParam2);
  270. break;
  271. case ICM_GETINFO:
  272. DBOUT("ICM_GETINFO");
  273. rval = DrvGetInfo(pi, (ICINFO FAR *)lParam1, (DWORD)lParam2);
  274. break;
  275. //***************************
  276. // compression messages
  277. //***************************
  278. case ICM_COMPRESS_QUERY:
  279. DBOUT("ICM_COMPRESS_QUERY");
  280. #ifdef ENCODER_DISABLED
  281. // This disables the encoder, as the debug message states.
  282. DBOUT("ENCODER DISABLED");
  283. rval = ICERR_UNSUPPORTED;
  284. #else
  285. if(pi && pi->enabled && (pi->fccHandler == FOURCC_H263))
  286. rval = CompressQuery(pi->CompPtr, (LPBITMAPINFOHEADER)lParam1, (LPBITMAPINFOHEADER)lParam2 );
  287. else
  288. rval = ICERR_UNSUPPORTED;
  289. #endif
  290. break;
  291. /*
  292. * ICM Compress Frames Info Structure
  293. */
  294. case ICM_COMPRESS_FRAMES_INFO:
  295. DBOUT("ICM_COMPRESS_FRAMES_INFO");
  296. if (pi)
  297. rval = CompressFramesInfo((LPCODINST) pi->CompPtr, (ICCOMPRESSFRAMES *) lParam1, (int) lParam2);
  298. else
  299. rval = ICERR_UNSUPPORTED;
  300. break;
  301. /*
  302. * ICM messages in support of quality.
  303. */
  304. case ICM_GETDEFAULTQUALITY:
  305. DBOUT("ICM_GETDEFAULTQUALITY");
  306. rval = ICERR_UNSUPPORTED;
  307. break;
  308. case ICM_GETQUALITY:
  309. DBOUT("ICM_GETQUALITY");
  310. rval = ICERR_UNSUPPORTED;
  311. break;
  312. case ICM_SETQUALITY:
  313. DBOUT("ICM_SETQUALITY");
  314. rval = ICERR_UNSUPPORTED;
  315. break;
  316. case ICM_COMPRESS_BEGIN:
  317. /*
  318. * Notify driver to prepare to compress data by allocating and
  319. * initializing any memory it needs for compressing. Note that
  320. * ICM_COMPRESS_BEGIN and ICM_COMPRESS_END do not nest.
  321. *
  322. * Should return ICERR_OK if the specified compression is supported
  323. * or ICERR_BADFORMAT if the input or output format is not supported.
  324. */
  325. DBOUT("ICM_COMPRESS_BEGIN");
  326. if (pi && pi->enabled)
  327. rval = CompressBegin(pi->CompPtr, (LPBITMAPINFOHEADER)lParam1, (LPBITMAPINFOHEADER)lParam2 );
  328. else
  329. rval = ICERR_UNSUPPORTED;
  330. break;
  331. case ICM_COMPRESS_GET_FORMAT:
  332. DBOUT("ICM_COMPRESS_GET_FORMAT");
  333. if (pi)
  334. rval = CompressGetFormat(pi->CompPtr, (LPBITMAPINFOHEADER)lParam1, (LPBITMAPINFOHEADER)lParam2 );
  335. else
  336. rval = ICERR_UNSUPPORTED;
  337. break;
  338. case ICM_COMPRESS_GET_SIZE:
  339. DBOUT("ICM_COMPRESS_GET_SIZE");
  340. if (pi && lParam1)
  341. rval = CompressGetSize(pi->CompPtr, (LPBITMAPINFOHEADER)lParam1, (LPBITMAPINFOHEADER)lParam2 );
  342. else
  343. rval = ICERR_UNSUPPORTED;
  344. break;
  345. case ICM_COMPRESS:
  346. /*
  347. * Returns ICERR_OK if successful or an error code otherwise.
  348. */
  349. DBOUT("ICM_COMPRESS");
  350. if (pi && pi->enabled)
  351. rval = Compress(
  352. pi->CompPtr, // ptr to Compressor instance information.
  353. (ICCOMPRESS FAR *)lParam1, // ptr to ICCOMPRESS structure.
  354. (DWORD)lParam2 // size in bytes of the ICCOMPRESS structure.
  355. );
  356. else
  357. rval = ICERR_UNSUPPORTED;
  358. break;
  359. case ICM_COMPRESS_END:
  360. DBOUT("ICM_COMPRESS_END");
  361. if (pi && pi->enabled)
  362. rval = CompressEnd(pi->CompPtr);
  363. else
  364. rval = ICERR_UNSUPPORTED;
  365. break;
  366. //***************************
  367. // decompress messages
  368. //***************************
  369. case ICM_DECOMPRESS_QUERY:
  370. DBOUT("ICM_DECOMPRESS_QUERY");
  371. ICDecExSt = DefaultICDecExSt;
  372. ICDecExSt.lpbiSrc = (LPBITMAPINFOHEADER)lParam1;
  373. ICDecExSt.lpbiDst = (LPBITMAPINFOHEADER)lParam2;
  374. if (pi)
  375. rval = DecompressQuery(pi->DecompPtr, (ICDECOMPRESSEX FAR *)&ICDecExSt, FALSE);
  376. else
  377. rval = ICERR_UNSUPPORTED;
  378. break;
  379. case ICM_DECOMPRESS_BEGIN:
  380. DBOUT("ICM_DECOMPRESS_BEGIN");
  381. ICDecExSt = DefaultICDecExSt;
  382. ICDecExSt.lpbiSrc = (LPBITMAPINFOHEADER)lParam1;
  383. ICDecExSt.lpbiDst = (LPBITMAPINFOHEADER)lParam2;
  384. if (pi)
  385. rval = DecompressBegin(pi->DecompPtr, (ICDECOMPRESSEX FAR *)&ICDecExSt, FALSE);
  386. else
  387. rval = ICERR_UNSUPPORTED;
  388. break;
  389. case ICM_DECOMPRESS_GET_FORMAT:
  390. DBOUT("ICM_DECOMPRESS_GET_FORMAT");
  391. if (pi)
  392. rval = DecompressGetFormat(pi->DecompPtr, (LPBITMAPINFOHEADER)lParam1, (LPBITMAPINFOHEADER)lParam2);
  393. else
  394. rval = ICERR_UNSUPPORTED;
  395. break;
  396. case ICM_DECOMPRESS_GET_PALETTE:
  397. DBOUT("ICM_DECOMPRESS_GET_PALETTE");
  398. if (pi)
  399. rval = DecompressGetPalette(pi->DecompPtr, (LPBITMAPINFOHEADER)lParam1, (LPBITMAPINFOHEADER)lParam2);
  400. else
  401. rval = ICERR_UNSUPPORTED;
  402. break;
  403. case ICM_DECOMPRESS_SET_PALETTE:
  404. DBOUT("ICM_DECOMPRESS_SET_PALETTE : not supported");
  405. rval = ICERR_UNSUPPORTED;
  406. // rval = DecompressSetPalette(pi->DecompPtr, (LPBITMAPINFOHEADER)lParam1, (LPBITMAPINFOHEADER)lParam2);
  407. break;
  408. case ICM_DECOMPRESS:
  409. DBOUT("ICM_DECOMPRESS");
  410. if (pi && (pi->enabled || (((ICDECOMPRESS FAR *)lParam1)->lpbiInput->biCompression == FOURCC_YUV12) || (((ICDECOMPRESS FAR *)lParam1)->lpbiInput->biCompression == FOURCC_IYUV)))
  411. {
  412. ICDecExSt = DefaultICDecExSt;
  413. ICDecExSt.dwFlags = ((ICDECOMPRESS FAR *)lParam1)->dwFlags;
  414. ICDecExSt.lpbiSrc = ((ICDECOMPRESS FAR *)lParam1)->lpbiInput;
  415. ICDecExSt.lpSrc = ((ICDECOMPRESS FAR *)lParam1)->lpInput;
  416. ICDecExSt.lpbiDst = ((ICDECOMPRESS FAR *)lParam1)->lpbiOutput;
  417. ICDecExSt.lpDst = ((ICDECOMPRESS FAR *)lParam1)->lpOutput;
  418. rval = Decompress(pi->DecompPtr, (ICDECOMPRESSEX FAR *)&ICDecExSt, (DWORD)lParam2, FALSE);
  419. #if TIMING // Output Timing Results in VC++ 2.0 Debug Window
  420. wsprintf(szTMsg, "Total Decode Time = %ld ms", tmr_time);
  421. TOUT(szTMsg);
  422. wsprintf(szTMsg, "Total Frames = %ld", tmr_frms);
  423. TOUT(szTMsg);
  424. wsprintf(szTMsg, "Average Frame Decode = %ld.%ld ms",
  425. tmr_time / tmr_frms,
  426. ((tmr_time % tmr_frms) * 1000) / tmr_frms);
  427. TOUT(szTMsg);
  428. #endif
  429. }
  430. else
  431. rval = ICERR_UNSUPPORTED;
  432. break;
  433. case ICM_DECOMPRESS_END:
  434. case ICM_DECOMPRESSEX_END:
  435. DBOUT("ICM_DECOMPRESS_END / ICM_DECOMPRESSEX_END");
  436. if (pi)
  437. rval = DecompressEnd(pi->DecompPtr);
  438. else
  439. rval = ICERR_UNSUPPORTED;
  440. break;
  441. //***************************
  442. // decompress X messages
  443. //***************************
  444. case ICM_DECOMPRESSEX:
  445. DBOUT("ICM_DECOMPRESSEX");
  446. if (pi && (pi->enabled || (((ICDECOMPRESS FAR *)lParam1)->lpbiInput->biCompression == FOURCC_YUV12) || (((ICDECOMPRESS FAR *)lParam1)->lpbiInput->biCompression == FOURCC_IYUV)))
  447. rval = Decompress(pi->DecompPtr, (ICDECOMPRESSEX FAR *)lParam1, (DWORD)lParam2, TRUE);
  448. else
  449. rval = ICERR_UNSUPPORTED;
  450. break;
  451. case ICM_DECOMPRESSEX_BEGIN:
  452. DBOUT("ICM_DECOMPRESSEX_BEGIN");
  453. if (pi)
  454. rval = DecompressBegin(pi->DecompPtr, (ICDECOMPRESSEX FAR *)lParam1, TRUE);
  455. else
  456. rval = ICERR_UNSUPPORTED;
  457. break;
  458. case ICM_DECOMPRESSEX_QUERY:
  459. DBOUT("ICM_DECOMPRESSEX_QUERY");
  460. #ifdef TURN_OFF_DECOMPRESSEX
  461. rval = ICERR_UNSUPPORTED;
  462. #else
  463. if (pi)
  464. rval = DecompressQuery(pi->DecompPtr, (ICDECOMPRESSEX FAR *)lParam1, TRUE);
  465. else
  466. rval = ICERR_UNSUPPORTED;
  467. #endif
  468. break;
  469. // *********************************************************************
  470. // custom driver messages for bright/cont/sat
  471. // *********************************************************************
  472. case CODEC_CUSTOM_VIDEO_EFFECTS:
  473. DBOUT("CODEC_CUSTOM_VIDEO_EFFECTS");
  474. if(LOWORD(lParam1) == VE_HUE) {
  475. DBOUT(" VE_HUE : Unsupported");
  476. rval = ICERR_UNSUPPORTED;
  477. break;
  478. }
  479. switch(HIWORD(lParam1))
  480. {
  481. case VE_GET_FACTORY_DEFAULT:
  482. DBOUT(" VE_GET_FACTORY_DEFAULT");
  483. *((WORD FAR *)lParam2) = 128;
  484. rval = ICERR_OK;
  485. break;
  486. case VE_GET_FACTORY_LIMITS:
  487. DBOUT(" VE_GET_FACTORY_LIMITS");
  488. *((DWORD FAR *)lParam2) = 0x00FF0000;
  489. rval = ICERR_OK;
  490. break;
  491. case VE_SET_CURRENT:
  492. DBOUT(" VE_SET_CURRENT");
  493. if(LOWORD(lParam1) == VE_BRIGHTNESS)
  494. {
  495. DBOUT(" CustomChangeBrightness()");
  496. rval = CustomChangeBrightness(pi->DecompPtr, (BYTE)(lParam2 & 0x000000FF));
  497. }
  498. if(LOWORD(lParam1) == VE_SATURATION)
  499. {
  500. DBOUT(" CustomChangeSaturation()");
  501. rval = CustomChangeSaturation(pi->DecompPtr, (BYTE)(lParam2 & 0x000000FF));
  502. }
  503. if(LOWORD(lParam1) == VE_CONTRAST)
  504. {
  505. DBOUT(" CustomChangeContrast()");
  506. rval = CustomChangeContrast(pi->DecompPtr, (BYTE)(lParam2 & 0x000000FF));
  507. }
  508. break;
  509. case VE_RESET_CURRENT:
  510. DBOUT(" VE_RESET_CURRENT");
  511. if(LOWORD(lParam1) == VE_BRIGHTNESS)
  512. {
  513. DBOUT(" CustomResetBrightness()");
  514. rval = CustomResetBrightness(pi->DecompPtr);
  515. }
  516. if(LOWORD(lParam1) == VE_CONTRAST)
  517. {
  518. DBOUT(" CustomResetContrast()");
  519. rval = CustomResetContrast(pi->DecompPtr);
  520. }
  521. if(LOWORD(lParam1) == VE_SATURATION)
  522. {
  523. DBOUT(" CustomResetSaturation()");
  524. rval = CustomResetSaturation(pi->DecompPtr);
  525. }
  526. break;
  527. default:
  528. rval = ICERR_UNSUPPORTED;
  529. break;
  530. }
  531. break;
  532. case CODEC_CUSTOM_ENCODER_CONTROL:
  533. DBOUT("CODEC_CUSTOM_ENCODER_CONTROL");
  534. switch(HIWORD(lParam1))
  535. {
  536. case EC_GET_FACTORY_DEFAULT:
  537. DBOUT(" EC_GET_FACTORY_DEFAULT");
  538. rval = ICERR_OK;
  539. switch(LOWORD(lParam1))
  540. {
  541. case EC_RTP_HEADER:
  542. *((DWORD FAR *)lParam2) = 0L; // 1 == On, 0 == Off
  543. break;
  544. case EC_RESILIENCY:
  545. *((DWORD FAR *)lParam2) = 0L; // 1 == On, 0 == Off
  546. break;
  547. case EC_BITRATE_CONTROL:
  548. *((DWORD FAR *)lParam2) = 0L; // 1 == On, 0 == Off
  549. break;
  550. case EC_PACKET_SIZE:
  551. *((DWORD FAR *)lParam2) = 512L;
  552. break;
  553. case EC_PACKET_LOSS:
  554. *((DWORD FAR *)lParam2) = 10L;
  555. break;
  556. case EC_BITRATE:
  557. *((DWORD FAR *)lParam2) = 1664L;
  558. break;
  559. default:
  560. rval = ICERR_UNSUPPORTED;
  561. }
  562. break;
  563. case EC_RESET_TO_FACTORY_DEFAULTS:
  564. DBOUT("EC_RESET_TO_FACTORY_DEFAULTS");
  565. rval = CustomResetToFactoryDefaults(pi->CompPtr);
  566. break;
  567. case EC_GET_FACTORY_LIMITS:
  568. DBOUT(" EC_GET_FACTORY_LIMITS");
  569. rval = ICERR_OK;
  570. switch(LOWORD(lParam1))
  571. {
  572. case EC_PACKET_SIZE:
  573. *((DWORD FAR *)lParam2) = 0x05DC0100;
  574. break;
  575. case EC_PACKET_LOSS:
  576. *((DWORD FAR *)lParam2) = 0x00640000;
  577. break;
  578. case EC_BITRATE: /* Bit rate limits are returned as */
  579. *((DWORD FAR *)lParam2) = 0x34000400; /* the number of bytes per second */
  580. break;
  581. default:
  582. rval = ICERR_UNSUPPORTED;
  583. }
  584. break;
  585. case EC_GET_CURRENT:
  586. DBOUT(" EC_GET_CURRENT");
  587. switch(LOWORD(lParam1))
  588. {
  589. case EC_RTP_HEADER:
  590. rval = CustomGetRTPHeaderState(pi->CompPtr, (DWORD FAR *)lParam2);
  591. break;
  592. case EC_RESILIENCY:
  593. rval = CustomGetResiliencyState(pi->CompPtr, (DWORD FAR *)lParam2);
  594. break;
  595. case EC_BITRATE_CONTROL:
  596. rval = CustomGetBitRateState(pi->CompPtr, (DWORD FAR *)lParam2);
  597. break;
  598. case EC_PACKET_SIZE:
  599. rval = CustomGetPacketSize(pi->CompPtr, (DWORD FAR *)lParam2);
  600. break;
  601. case EC_PACKET_LOSS:
  602. rval = CustomGetPacketLoss(pi->CompPtr, (DWORD FAR *)lParam2);
  603. break;
  604. case EC_BITRATE: /* Bit rate is returned in bits per second */
  605. rval = CustomGetBitRate(pi->CompPtr, (DWORD FAR *)lParam2);
  606. break;
  607. #ifdef H263P
  608. case EC_H263_PLUS:
  609. rval = CustomGetH263PlusState(pi->CompPtr, (DWORD FAR *)lParam2);
  610. break;
  611. case EC_IMPROVED_PB_FRAMES:
  612. rval = CustomGetImprovedPBState(pi->CompPtr, (DWORD FAR *)lParam2);
  613. break;
  614. case EC_DEBLOCKING_FILTER:
  615. rval = CustomGetDeblockingFilterState(pi->CompPtr, (DWORD FAR *)lParam2);
  616. break;
  617. case EC_MACHINE_TYPE:
  618. // Return the machine type in (reference param) lParam2
  619. // This message should not be invoked until after CompressBegin
  620. // since this is where GetEncoderOptions is called, and the
  621. // MMX version is properly set (via init file check).
  622. rval = ICERR_OK;
  623. if (ProcessorVersionInitialized) {
  624. if (MMX_Enabled) {
  625. if (P6Version) {
  626. *(int *)lParam2 = _PENTIUM_PRO_MMX_PROCESSOR;
  627. } else {
  628. *(int *)lParam2 = _PENTIUM_MMX_PROCESSOR;
  629. }
  630. } else {
  631. if (P6Version) {
  632. *(int *)lParam2 = _PENTIUM_PRO_PROCESSOR;
  633. } else {
  634. *(int *)lParam2 = _PENTIUM_PROCESSOR;
  635. }
  636. }
  637. } else {
  638. rval = ICERR_UNSUPPORTED;
  639. }
  640. break;
  641. #endif
  642. default:
  643. rval = ICERR_UNSUPPORTED;
  644. }
  645. break;
  646. case EC_SET_CURRENT:
  647. DBOUT(" EC_SET_CURRENT");
  648. switch(LOWORD(lParam1))
  649. {
  650. case EC_RTP_HEADER:
  651. DBOUT(" EC_RTP_HEADER");
  652. rval = CustomSetRTPHeaderState(pi->CompPtr, (DWORD)lParam2);
  653. break;
  654. case EC_RESILIENCY:
  655. DBOUT(" EC_RESILIENCY");
  656. rval = CustomSetResiliencyState(pi->CompPtr, (DWORD)lParam2);
  657. break;
  658. case EC_BITRATE_CONTROL:
  659. DBOUT(" EC_BITRATE_CONTROL");
  660. rval = CustomSetBitRateState(pi->CompPtr, (DWORD)lParam2);
  661. break;
  662. case EC_PACKET_SIZE:
  663. DBOUT(" EC_PACKET_SIZE");
  664. rval = CustomSetPacketSize(pi->CompPtr, (DWORD)lParam2);
  665. break;
  666. case EC_PACKET_LOSS:
  667. DBOUT(" EC_PACKET_LOSS");
  668. rval = CustomSetPacketLoss(pi->CompPtr, (DWORD)lParam2);
  669. break;
  670. case EC_BITRATE: /* Bit rate is set in bits per second */
  671. DBOUT(" EC_BITRATE");
  672. rval = CustomSetBitRate(pi->CompPtr, (DWORD)lParam2);
  673. break;
  674. #ifdef H263P
  675. case EC_H263_PLUS:
  676. rval = CustomSetH263PlusState(pi->CompPtr, (DWORD)lParam2);
  677. break;
  678. case EC_IMPROVED_PB_FRAMES:
  679. rval = CustomSetImprovedPBState(pi->CompPtr, (DWORD)lParam2);
  680. break;
  681. case EC_DEBLOCKING_FILTER:
  682. rval = CustomSetDeblockingFilterState(pi->CompPtr, (DWORD)lParam2);
  683. break;
  684. #endif
  685. default:
  686. rval = ICERR_UNSUPPORTED;
  687. }
  688. break;
  689. default:
  690. rval = ICERR_UNSUPPORTED;
  691. break;
  692. }
  693. break;
  694. // custom decoder control
  695. case CODEC_CUSTOM_DECODER_CONTROL:
  696. DBOUT("CODEC_CUSTOM_DECODER_CONTROL");
  697. switch (HIWORD(lParam1))
  698. {
  699. case DC_SET_CURRENT:
  700. switch (LOWORD(lParam1))
  701. {
  702. case DC_BLOCK_EDGE_FILTER:
  703. rval = CustomSetBlockEdgeFilter(pi->DecompPtr,(DWORD)lParam2);
  704. break;
  705. default:
  706. rval = ICERR_UNSUPPORTED;
  707. break;
  708. }
  709. break;
  710. #if defined(H263P)
  711. case DC_GET_CURRENT:
  712. switch (LOWORD(lParam1))
  713. {
  714. case DC_MACHINE_TYPE:
  715. // Return the machine type in (reference param) lParam2
  716. // This message should not be invoked until after DecompressBegin
  717. // since this is where GetDecoderOptions is called, and the
  718. // MMX version is properly set (via init file check). Note
  719. // that the DecoderContext flag is not used here. GetDecoderOptions has
  720. // been modified to supply the MMX flag in both DC->bMMXDecoder
  721. // and MMX_Enabled.
  722. rval = ICERR_OK;
  723. if (ProcessorVersionInitialized) {
  724. if (MMXDecoder_Enabled) {
  725. if (P6Version) {
  726. *(int *)lParam2 = _PENTIUM_PRO_MMX_PROCESSOR;
  727. } else {
  728. *(int *)lParam2 = _PENTIUM_MMX_PROCESSOR;
  729. }
  730. } else {
  731. if (P6Version) {
  732. *(int *)lParam2 = _PENTIUM_PRO_PROCESSOR;
  733. } else {
  734. *(int *)lParam2 = _PENTIUM_PROCESSOR;
  735. }
  736. }
  737. }
  738. break;
  739. default:
  740. rval = ICERR_UNSUPPORTED;
  741. break;
  742. }
  743. break;
  744. #endif
  745. default:
  746. rval = ICERR_UNSUPPORTED;
  747. break;
  748. }
  749. break;
  750. case PLAYBACK_CUSTOM_CHANGE_BRIGHTNESS:
  751. DBOUT("PLAYBACK_CUSTOM_CHANGE_BRIGHTNESS");
  752. rval = CustomChangeBrightness(pi->DecompPtr, (BYTE)(lParam1 & 0x000000FF));
  753. break;
  754. case PLAYBACK_CUSTOM_CHANGE_CONTRAST:
  755. DBOUT("PLAYBACK_CUSTOM_CHANGE_CONTRAST");
  756. rval = CustomChangeContrast(pi->DecompPtr, (BYTE)(lParam1 & 0x000000FF));
  757. break;
  758. case PLAYBACK_CUSTOM_CHANGE_SATURATION:
  759. DBOUT("PLAYBACK_CUSTOM_CHANGE_SATURATION");
  760. rval = CustomChangeSaturation(pi->DecompPtr, (BYTE)(lParam1 & 0x000000FF));
  761. break;
  762. case PLAYBACK_CUSTOM_RESET_BRIGHTNESS:
  763. DBOUT("PLAYBACK_CUSTOM_RESET_BRIGHTNESS");
  764. rval = CustomResetBrightness(pi->DecompPtr);
  765. rval |= CustomResetContrast(pi->DecompPtr);
  766. break;
  767. case PLAYBACK_CUSTOM_RESET_SATURATION:
  768. DBOUT("PLAYBACK_CUSTOM_RESET_SATURATION");
  769. rval = CustomResetSaturation(pi->DecompPtr);
  770. break;
  771. // *********************************************************************
  772. // custom application identification message
  773. // *********************************************************************
  774. case APPLICATION_IDENTIFICATION_CODE:
  775. DBOUT("APPLICATION_IDENTIFICATION_CODE");
  776. rval = ICERR_OK;
  777. break;
  778. case CUSTOM_ENABLE_CODEC:
  779. DBOUT("CUSTOM_ENABLE_CODEC");
  780. if (pi)
  781. {
  782. if (lParam1 == G723MAGICWORD1 && lParam2 == G723MAGICWORD2)
  783. pi->enabled = TRUE;
  784. else
  785. pi->enabled = FALSE;
  786. }
  787. rval = ICERR_OK;
  788. break;
  789. default:
  790. if (uiMessage < DRV_USER)
  791. {
  792. if(dwDriverID == 0)
  793. rval = ICERR_UNSUPPORTED;
  794. else
  795. rval = DefDriverProc(dwDriverID, hDriver, uiMessage,
  796. lParam1, lParam2);
  797. }
  798. else
  799. rval = ICERR_UNSUPPORTED;
  800. }
  801. }
  802. catch (...)
  803. {
  804. #if defined(DEBUG) || defined(_DEBUG)
  805. // For a DEBUG build, display a message and pass the exception up.
  806. DBOUT("Exception during DriverProc!!!");
  807. throw;
  808. #else
  809. // For a release build, stop the exception here and return an error
  810. // code. This gives upstream code a chance to gracefully recover.
  811. // We also need to clear the floating point status word, otherwise
  812. // the upstream code may incur an exception the next time it tries
  813. // a floating point operation (presuming this exception was due
  814. // to a floating point problem).
  815. _clearfp();
  816. rval = (DWORD) ICERR_INTERNAL;
  817. #endif
  818. }
  819. #if FPThunking
  820. ThnkFPRestore(u16FPState);
  821. #endif
  822. return(rval);
  823. }
  824. #ifdef WIN32
  825. #ifndef QUARTZ
  826. /****************************************************************************
  827. * @doc INTERNAL
  828. *
  829. * @api BOOL | DllMain | Library initialization & exit code.
  830. *
  831. * @parm HANDLE | hModule | Our module handle.
  832. *
  833. * @parm DWORD | dwReason | The function being requested.
  834. *
  835. * @parm LPVOID | lpReserved | Unused at this time.
  836. *
  837. * @rdesc Returns 1 if the initialization was successful and 0 otherwise.
  838. ***************************************************************************/
  839. BOOL APIENTRY DllMain(HINSTANCE hModule, DWORD dwReason, LPVOID lpReserved)
  840. {
  841. BOOL rval = TRUE;
  842. /* DO NOT INSTALL PROFILE PROBES HERE. IT IS CALLED PRIOR TO THE LOAD message */
  843. switch(dwReason)
  844. {
  845. case DLL_PROCESS_ATTACH:
  846. /*======================================================*\
  847. /* A new instance is being invoked.
  848. /* Allocate data to be used by this instance, 1st thread
  849. /* lpReserved = NULL for dynamic loads, !NULL for static
  850. /* Use TlsAlloc() to create a TlsIndex for this instance
  851. /* The TlsIndex can be stored in a simple global variable
  852. /* as data allocated to each process is unique.
  853. /* Return TRUE upon success, FALSE otherwise.
  854. /*======================================================*/
  855. hDriverModule = hModule;
  856. #if defined DEBUG
  857. if (DebugH26x)OutputDebugString(TEXT("\n MRV DllMain Process Attach"));
  858. #endif /* DEBUG */
  859. DBGINIT(&ghDbgZoneH261, _rgZonesH261);
  860. DBG_INIT_MEMORY_TRACKING(hModule);
  861. break;
  862. case DLL_PROCESS_DETACH:
  863. /*======================================================*\
  864. /* An instance is being terminated.
  865. /* Deallocate memory used by all threads in this instance
  866. /* lpReserved = NULL if called by FreeLibrary()
  867. /* !NULL if called at process termination
  868. /* Use TlsFree() to return TlsIndex to the pool.
  869. /* Clean up all known threads.
  870. /* May match many DLL_THREAD_ATTACHes.
  871. /* Return value is ignored.
  872. /*======================================================*/
  873. #if defined DEBUG
  874. if (DebugH26x)OutputDebugString(TEXT("\nMRV DllMain Process Detach"));
  875. #endif /* DEBUG */
  876. DBG_CHECK_MEMORY_TRACKING(hModule);
  877. DBGDEINIT(&ghDbgZoneH261);
  878. break;
  879. case DLL_THREAD_ATTACH:
  880. /*======================================================*\
  881. /* A new thread within the specified instance is being invoked.
  882. /* Allocate data to be used by this thread.
  883. /* Use the TlsIndex to access instance data.
  884. /* Return value is ignored.
  885. /*======================================================*/
  886. #if defined DEBUG
  887. if (DebugH26x)OutputDebugString(TEXT("\nMRV DllMain Thread Attach"));
  888. #endif /* DEBUG */
  889. break;
  890. case DLL_THREAD_DETACH:
  891. /*======================================================*\
  892. /* A thread within the specified instance is being terminated.
  893. /* Deallocate memory used by this thread.
  894. /* Use the TlsIndex to access instance data.
  895. /* May match DLL_PROCESS_ATTACH instead of DLL_THREAD_ATTACH
  896. /* Will be called even if DLL_THREAD_ATTACH failed or wasn't called
  897. /* Return value is ignored.
  898. /*======================================================*/
  899. #if defined DEBUG
  900. if (DebugH26x)OutputDebugString(TEXT("\n MRV DllMain Thread Detach"));
  901. #endif /* DEBUG */
  902. break;
  903. default:
  904. /*======================================================*\
  905. /* Don't know the reason the DLL Entry Point was called.
  906. /* Return FALSE to be safe.
  907. /*======================================================*/
  908. #if defined DEBUG
  909. if (DebugH26x)OutputDebugString(TEXT("\n MRV DllMain Reason Unknown"));
  910. #endif /* DEBUG */
  911. rval = FALSE; /* indicate failure with 0 as
  912. * (NULL can't be used in WIN32
  913. */
  914. }
  915. return(rval);
  916. }
  917. #endif /* end #ifndef QUARTZ */
  918. #else /* else not #ifdef WIN32 */
  919. ;////////////////////////////////////////////////////////////////////////////
  920. ;// Function: int NEAR PASCAL LibMain(HANDLE, WORD, LPSTR);
  921. ;//
  922. ;// Description: Added header.
  923. ;//
  924. ;// History: 02/18/94 -BEN-
  925. ;////////////////////////////////////////////////////////////////////////////
  926. INT WINAPI LibMain(HANDLE hModule, WORD wHeapSize, LPSTR lpCmdLine)
  927. {
  928. hDriverModule = hModule;
  929. return 1;
  930. }
  931. #endif