Source code of Windows XP (NT5)
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.

270 lines
8.1 KiB

  1. /******************************************************************************
  2. Copyright (C) Microsoft Corporation 1985-1991. All rights reserved.
  3. Title: drvproc.c - Multimedia Systems Media Control Interface
  4. driver for AVI.
  5. *****************************************************************************/
  6. #include <nt.h>
  7. #include <ntrtl.h>
  8. #include <nturtl.h> // for {struct _TEB} defintion
  9. #include "graphic.h"
  10. #include "cnfgdlg.h" // to get IDA_CONFIG
  11. #include "avitask.h" // to get mciaviTaskCleanup()
  12. #ifndef _WIN32 // Not used in 32 bit world
  13. void NEAR PASCAL AppExit(HTASK htask, BOOL fNormalExit);
  14. #endif
  15. #define CONFIG_ID 10000L // Use the hiword of dwDriverID to identify
  16. HANDLE ghModule;
  17. extern HWND ghwndConfig;
  18. extern const TCHAR szIni[];
  19. /* Link to DefDriverProc in MMSystem explicitly, so we don't get the
  20. ** one in USER by mistake.
  21. */
  22. #ifndef _WIN32
  23. extern DWORD FAR PASCAL mmDefDriverProc(DWORD, HANDLE, UINT, DWORD, DWORD);
  24. #else
  25. #define mmDefDriverProc DefDriverProc
  26. #endif
  27. #ifndef _WIN32
  28. BOOL FAR PASCAL LibMain (HANDLE hModule, int cbHeap, LPSTR lpchCmdLine)
  29. {
  30. ghModule = hModule;
  31. return TRUE;
  32. }
  33. #else
  34. #if 0
  35. // Get the module handle on DRV_LOAD
  36. BOOL DllInstanceInit(PVOID hModule, ULONG Reason, PCONTEXT pContext)
  37. {
  38. if (Reason == DLL_PROCESS_ATTACH) {
  39. ghModule = hModule; // All we need to save is our module handle...
  40. } else {
  41. if (Reason == DLL_PROCESS_DETACH) {
  42. }
  43. }
  44. return TRUE;
  45. }
  46. #endif
  47. #endif // WIN16
  48. /***************************************************************************
  49. *
  50. * @doc INTERNAL
  51. *
  52. * @api DWORD | DriverProc | The entry point for an installable driver.
  53. *
  54. * @parm DWORD | dwDriverId | For most messages, dwDriverId is the DWORD
  55. * value that the driver returns in response to a DRV_OPEN message.
  56. * Each time that the driver is opened, through the DrvOpen API,
  57. * the driver receives a DRV_OPEN message and can return an
  58. * arbitrary, non-zero, value. The installable driver interface
  59. * saves this value and returns a unique driver handle to the
  60. * application. Whenever the application sends a message to the
  61. * driver using the driver handle, the interface routes the message
  62. * to this entry point and passes the corresponding dwDriverId.
  63. *
  64. * This mechanism allows the driver to use the same or different
  65. * identifiers for multiple opens but ensures that driver handles
  66. * are unique at the application interface layer.
  67. *
  68. * The following messages are not related to a particular open
  69. * instance of the driver. For these messages, the dwDriverId
  70. * will always be ZERO.
  71. *
  72. * DRV_LOAD, DRV_FREE, DRV_ENABLE, DRV_DISABLE, DRV_OPEN
  73. *
  74. * @parm UINT | wMessage | The requested action to be performed. Message
  75. * values below DRV_RESERVED are used for globally defined messages.
  76. * Message values from DRV_RESERVED to DRV_USER are used for
  77. * defined driver portocols. Messages above DRV_USER are used
  78. * for driver specific messages.
  79. *
  80. * @parm DWORD | dwParam1 | Data for this message. Defined separately for
  81. * each message
  82. *
  83. * @parm DWORD | dwParam2 | Data for this message. Defined separately for
  84. * each message
  85. *
  86. * @rdesc Defined separately for each message.
  87. *
  88. ***************************************************************************/
  89. LRESULT FAR PASCAL _LOADDS DriverProc (DWORD_PTR dwDriverID, HANDLE hDriver, UINT wMessage,
  90. LPARAM dwParam1, LPARAM dwParam2)
  91. {
  92. DWORD_PTR dwRes = 0L;
  93. /*
  94. * critical sections are now per-device. This means they
  95. * cannot be held around the whole driver-proc, since until we open
  96. * the device, we don't have a critical section to hold.
  97. * The critical section is allocated in mciSpecial on opening. It is
  98. * also held in mciDriverEntry, in GraphicWndProc, and around
  99. * all worker thread draw functions.
  100. */
  101. switch (wMessage)
  102. {
  103. // Standard, globally used messages.
  104. case DRV_LOAD:
  105. {
  106. struct _TEB *pteb;
  107. BOOL bWow64;
  108. #ifdef _WIN32
  109. if (ghModule) {
  110. Assert(!"Did not expect ghModule to be non-NULL");
  111. }
  112. ghModule = GetDriverModuleHandle(hDriver); // Remember
  113. // The WOW guys say that the proper method of detecting
  114. // whether we're talking to a 16-bit app is to test
  115. // NtCurrentTeb()->WOW32Reserved; if it's nonzero, it's 16-bit.
  116. // In the (unlikely) event that we can't test that, default
  117. // to using the old detection method.
  118. // On 64-bit systems WOW32Reserved is used for something else.
  119. //
  120. if (!IsWow64Process(GetCurrentProcess(), &bWow64)) {
  121. break;
  122. }
  123. if (!bWow64) {
  124. if ((pteb = NtCurrentTeb()) != NULL) {
  125. runningInWow = (pteb->WOW32Reserved != 0) ? TRUE : FALSE;
  126. } else {
  127. #define GET_MAPPING_MODULE_NAME TEXT("wow32.dll")
  128. runningInWow = (GetModuleHandle(GET_MAPPING_MODULE_NAME) != NULL);
  129. }
  130. }
  131. #endif
  132. if (GraphicInit()) // Initialize graphic mgmt.
  133. dwRes = 1L;
  134. else
  135. dwRes = 0L;
  136. break;
  137. }
  138. case DRV_FREE:
  139. GraphicFree();
  140. dwRes = 1L;
  141. DPF(("Returning from DRV_FREE\n"));
  142. Assert(npMCIList == NULL);
  143. ghModule = NULL;
  144. break;
  145. case DRV_OPEN:
  146. if (!dwParam2)
  147. dwRes = CONFIG_ID;
  148. else
  149. dwRes = GraphicDrvOpen((LPMCI_OPEN_DRIVER_PARMS)dwParam2);
  150. break;
  151. case DRV_CLOSE:
  152. /* If we have a configure dialog up, fail the close.
  153. ** Otherwise, we'll be unloaded while we still have the
  154. ** configuration window up.
  155. */
  156. if (ghwndConfig)
  157. dwRes = 0L;
  158. else
  159. dwRes = 1L;
  160. break;
  161. case DRV_ENABLE:
  162. dwRes = 1L;
  163. break;
  164. case DRV_DISABLE:
  165. dwRes = 1L;
  166. break;
  167. case DRV_QUERYCONFIGURE:
  168. dwRes = 1L; /* Yes, we can be configured */
  169. break;
  170. case DRV_CONFIGURE:
  171. ConfigDialog((HWND)(UINT)dwParam1, NULL);
  172. dwRes = 1L;
  173. break;
  174. #ifndef _WIN32
  175. //
  176. // sent when a application is terminating
  177. //
  178. // lParam1:
  179. // DRVEA_ABNORMALEXIT
  180. // DRVEA_NORMALEXIT
  181. //
  182. case DRV_EXITAPPLICATION:
  183. AppExit(GetCurrentTask(), (BOOL)dwParam1 == DRVEA_NORMALEXIT);
  184. break;
  185. #endif
  186. default:
  187. if (!HIWORD(dwDriverID) &&
  188. wMessage >= DRV_MCI_FIRST &&
  189. wMessage <= DRV_MCI_LAST)
  190. dwRes = mciDriverEntry ((UINT) (UINT_PTR) dwDriverID,
  191. wMessage,
  192. (UINT) dwParam1,
  193. (LPMCI_GENERIC_PARMS)dwParam2);
  194. else
  195. dwRes = mmDefDriverProc(dwDriverID,
  196. hDriver,
  197. wMessage,
  198. dwParam1,
  199. dwParam2);
  200. break;
  201. }
  202. return dwRes;
  203. }
  204. #ifndef _WIN32
  205. /*****************************************************************************
  206. * @doc INTERNAL
  207. *
  208. * @func void | AppExit |
  209. * a application is exiting
  210. *
  211. ****************************************************************************/
  212. void NEAR PASCAL AppExit(HTASK htask, BOOL fNormalExit)
  213. {
  214. //
  215. // walk the list of open MCIAVI instances and see if
  216. // the dying task is the background task and do cleanup.
  217. //
  218. NPMCIGRAPHIC npMCI;
  219. // Note: we do not have EnterList/LeaveList macros here as this is
  220. // explicitly NOT Win32 code.
  221. for (npMCI=npMCIList; npMCI; npMCI = npMCI->npMCINext) {
  222. if (npMCI->hTask == htask) {
  223. DPF(("Calling mciaviTaskCleanup()\n"));
  224. mciaviTaskCleanup(npMCI);
  225. return;
  226. }
  227. }
  228. }
  229. #endif