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.

354 lines
9.1 KiB

  1. /*++
  2. Copyright (c) 1996-1999 Microsoft Corporation
  3. Module Name:
  4. main.c
  5. Abstract:
  6. Implementation of OEMGetInfo and OEMDevMode.
  7. Shared by all Unidrv OEM test dll's.
  8. Environment:
  9. Windows NT Unidrv driver
  10. Revision History:
  11. 04/07/97 -zhanw-
  12. Created it.
  13. --*/
  14. // NTRAID#NTBUG9-576661-2002/03/14-yasuho-: Remove the dead codes
  15. #include "pdev.h" // defined in sub-directory such as DDICMDCB, FONTCB, etc.
  16. DWORD gdwDrvMemPoolTag = 'meoD'; // lib.h requires this global var, for debugging
  17. ////////////////////////////////////////////////////////
  18. // INTERNAL PROTOTYPES
  19. ////////////////////////////////////////////////////////
  20. static BOOL BInitOEMExtraData(POEMUD_EXTRADATA pOEMExtra);
  21. static BOOL BMergeOEMExtraData(POEMUD_EXTRADATA pdmIn, POEMUD_EXTRADATA pdmOut);
  22. static BOOL BIsValidOEMDevModeParam(DWORD dwMode, POEMDMPARAM pOEMDevModeParam);
  23. static void VDumpOEMDevModeParam(POEMDMPARAM pOEMDevModeParam);
  24. BOOL APIENTRY OEMGetInfo(DWORD dwInfo, PVOID pBuffer, DWORD cbSize, PDWORD pcbNeeded)
  25. {
  26. LPCSTR OEM_INFO[] = { "Bad Index",
  27. "OEMGI_GETSIGNATURE",
  28. "OEMGI_GETINTERFACEVERSION",
  29. "OEMGI_GETVERSION",
  30. };
  31. VERBOSE((DLLTEXT("OEMGetInfo(%s) entry.\n"), OEM_INFO[dwInfo]));
  32. // Validate parameters.
  33. if( ( (OEMGI_GETSIGNATURE != dwInfo) &&
  34. (OEMGI_GETINTERFACEVERSION != dwInfo) &&
  35. (OEMGI_GETVERSION != dwInfo) ) ||
  36. (NULL == pcbNeeded)
  37. )
  38. {
  39. VERBOSE((ERRORTEXT("OEMGetInfo() ERROR_INVALID_PARAMETER.\n")));
  40. // Did not write any bytes.
  41. if(NULL != pcbNeeded)
  42. *pcbNeeded = 0;
  43. return FALSE;
  44. }
  45. // Need/wrote 4 bytes.
  46. *pcbNeeded = 4;
  47. // Validate buffer size. Minimum size is four bytes.
  48. if( (NULL == pBuffer) || (4 > cbSize) )
  49. {
  50. VERBOSE((ERRORTEXT("OEMGetInfo() ERROR_INSUFFICIENT_BUFFER.\n")));
  51. return FALSE;
  52. }
  53. // Write information to buffer.
  54. switch(dwInfo)
  55. {
  56. case OEMGI_GETSIGNATURE:
  57. *(LPDWORD)pBuffer = OEM_SIGNATURE;
  58. break;
  59. case OEMGI_GETINTERFACEVERSION:
  60. *(LPDWORD)pBuffer = PRINTER_OEMINTF_VERSION;
  61. break;
  62. case OEMGI_GETVERSION:
  63. *(LPDWORD)pBuffer = OEM_VERSION;
  64. break;
  65. }
  66. return TRUE;
  67. }
  68. BOOL APIENTRY OEMDevMode(
  69. DWORD dwMode,
  70. POEMDMPARAM pOEMDevModeParam)
  71. {
  72. LPCSTR OEMDevMode_fMode[] = { "NULL",
  73. "OEMDM_SIZE",
  74. "OEMDM_DEFAULT",
  75. "OEMDM_CONVERT",
  76. "OEMDM_MERGE",
  77. };
  78. VERBOSE((DLLTEXT("OEMDevMode(), dwMode=%d\n"), dwMode));
  79. // VERBOSE((DLLTEXT("OEMDevMode(%s) entry.\n"), OEMDevMode_fMode[dwMode]));
  80. // Validate parameters.
  81. if(!BIsValidOEMDevModeParam(dwMode, pOEMDevModeParam))
  82. {
  83. VERBOSE((ERRORTEXT("OEMDevMode() ERROR_INVALID_PARAMETER.\n")));
  84. VDumpOEMDevModeParam(pOEMDevModeParam);
  85. return FALSE;
  86. }
  87. // Verify OEM extra data size.
  88. if( (dwMode != OEMDM_SIZE) &&
  89. sizeof(OEMUD_EXTRADATA) > pOEMDevModeParam->cbBufSize )
  90. {
  91. VERBOSE((ERRORTEXT("OEMDevMode() ERROR_INSUFFICIENT_BUFFER.\n")));
  92. return FALSE;
  93. }
  94. // Handle dwMode.
  95. switch(dwMode)
  96. {
  97. case OEMDM_SIZE:
  98. pOEMDevModeParam->cbBufSize = sizeof(OEMUD_EXTRADATA);
  99. break;
  100. case OEMDM_DEFAULT:
  101. return BInitOEMExtraData((POEMUD_EXTRADATA)pOEMDevModeParam->pOEMDMOut);
  102. case OEMDM_CONVERT:
  103. // nothing to convert for this private devmode. So just initialize it.
  104. return BInitOEMExtraData((POEMUD_EXTRADATA)pOEMDevModeParam->pOEMDMOut);
  105. case OEMDM_MERGE:
  106. if(!BMergeOEMExtraData((POEMUD_EXTRADATA)pOEMDevModeParam->pOEMDMIn,
  107. (POEMUD_EXTRADATA)pOEMDevModeParam->pOEMDMOut) )
  108. {
  109. VERBOSE(("OEMUD OEMDevMode(): not valid OEM Extra Data.\n"));
  110. return FALSE;
  111. }
  112. break;
  113. }
  114. return TRUE;
  115. }
  116. //////////////////////////////////////////////////////////////////////////
  117. // Function: BInitOEMExtraData
  118. //
  119. // Description: Initializes OEM Extra data.
  120. //
  121. //
  122. // Parameters:
  123. //
  124. // pOEMExtra Pointer to a OEM Extra data.
  125. //
  126. // dwSize Size of OEM extra data.
  127. //
  128. //
  129. // Returns: TRUE if successful; FALSE otherwise.
  130. //
  131. //
  132. // Comments:
  133. //
  134. //
  135. // History:
  136. // 02/11/97 APresley Created.
  137. //
  138. //////////////////////////////////////////////////////////////////////////
  139. static BOOL BInitOEMExtraData(POEMUD_EXTRADATA pOEMExtra)
  140. {
  141. // Initialize OEM Extra data.
  142. pOEMExtra->dmExtraHdr.dwSize = sizeof(OEMUD_EXTRADATA);
  143. pOEMExtra->dmExtraHdr.dwSignature = OEM_SIGNATURE;
  144. pOEMExtra->dmExtraHdr.dwVersion = OEM_VERSION;
  145. return TRUE;
  146. }
  147. //////////////////////////////////////////////////////////////////////////
  148. // Function: BMergeOEMExtraData
  149. //
  150. // Description: Validates and merges OEM Extra data.
  151. //
  152. //
  153. // Parameters:
  154. //
  155. // pdmIn pointer to an input OEM private devmode containing the settings
  156. // to be validated and merged. Its size is current.
  157. //
  158. // pdmOut pointer to the output OEM private devmode containing the
  159. // default settings.
  160. //
  161. //
  162. // Returns: TRUE if valid; FALSE otherwise.
  163. //
  164. //
  165. // Comments:
  166. //
  167. //
  168. // History:
  169. // 02/11/97 APresley Created.
  170. // 04/08/97 ZhanW Modified the interface
  171. //
  172. //////////////////////////////////////////////////////////////////////////
  173. static BOOL BMergeOEMExtraData(
  174. POEMUD_EXTRADATA pdmIn,
  175. POEMUD_EXTRADATA pdmOut
  176. )
  177. {
  178. if(pdmIn)
  179. {
  180. //
  181. // copy over the private fields, if they are valid
  182. //
  183. }
  184. return TRUE;
  185. }
  186. //////////////////////////////////////////////////////////////////////////
  187. // Function: BIsValidOEMDevModeParam
  188. //
  189. // Description: Validates OEM_DEVMODEPARAM structure.
  190. //
  191. //
  192. // Parameters:
  193. //
  194. // dwMode calling mode
  195. // pOEMDevModeParam Pointer to a OEMDEVMODEPARAM structure.
  196. //
  197. //
  198. // Returns: TRUE if valid; FALSE otherwise.
  199. //
  200. //
  201. // Comments:
  202. //
  203. //
  204. // History:
  205. // 02/11/97 APresley Created.
  206. //
  207. //////////////////////////////////////////////////////////////////////////
  208. static BOOL BIsValidOEMDevModeParam(
  209. DWORD dwMode,
  210. POEMDMPARAM pOEMDevModeParam)
  211. {
  212. BOOL bValid = TRUE;
  213. if(NULL == pOEMDevModeParam)
  214. {
  215. VERBOSE(("OEMUD IsValidOEMDevModeParam(): pOEMDevModeParam is NULL.\n"));
  216. return FALSE;
  217. }
  218. if(sizeof(OEMDMPARAM) > pOEMDevModeParam->cbSize)
  219. {
  220. VERBOSE(("OEMUD IsValidOEMDevModeParam(): cbSize is smaller than sizeof(OEM_DEVMODEPARAM).\n"));
  221. bValid = FALSE;
  222. }
  223. if(NULL == pOEMDevModeParam->hPrinter)
  224. {
  225. VERBOSE(("OEMUD IsValidOEMDevModeParam(): hPrinter is NULL.\n"));
  226. bValid = FALSE;
  227. }
  228. if(NULL == pOEMDevModeParam->hModule)
  229. {
  230. VERBOSE(("OEMUD IsValidOEMDevModeParam(): hModule is NULL.\n"));
  231. bValid = FALSE;
  232. }
  233. if( (0 != pOEMDevModeParam->cbBufSize) &&
  234. (NULL == pOEMDevModeParam->pOEMDMOut)
  235. )
  236. {
  237. VERBOSE(("OEMUD IsValidOEMDevModeParam(): pOEMDMOut is NULL when it should not be.\n"));
  238. bValid = FALSE;
  239. }
  240. if( (OEMDM_MERGE == dwMode) && (NULL == pOEMDevModeParam->pOEMDMIn) )
  241. {
  242. VERBOSE(("OEMUD IsValidOEMDevModeParam(): pOEMDMIn is NULL when it should not be.\n"));
  243. bValid = FALSE;
  244. }
  245. return bValid;
  246. }
  247. //////////////////////////////////////////////////////////////////////////
  248. // Function: VDumpOEMDevModeParam
  249. //
  250. // Description: Debug dump of OEM_DEVMODEPARAM structure.
  251. //
  252. //
  253. // Parameters:
  254. //
  255. // pOEMDevModeParam Pointer to an OEM DevMode param structure.
  256. //
  257. //
  258. // Returns: N/A.
  259. //
  260. //
  261. // Comments:
  262. //
  263. //
  264. // History:
  265. // 02/18/97 APresley Created.
  266. //
  267. //////////////////////////////////////////////////////////////////////////
  268. static void VDumpOEMDevModeParam(POEMDMPARAM pOEMDevModeParam)
  269. {
  270. // Can't dump if pOEMDevModeParam NULL.
  271. if(NULL != pOEMDevModeParam)
  272. {
  273. VERBOSE(("\n\tOEM_DEVMODEPARAM dump:\n\n"));
  274. VERBOSE((("\tcbSize = %d.\n"), pOEMDevModeParam->cbSize));
  275. VERBOSE((("\thPrinter = %#lx.\n"), pOEMDevModeParam->hPrinter));
  276. VERBOSE((("\thModule = %#lx.\n"), pOEMDevModeParam->hModule));
  277. VERBOSE((("\tpPublicDMIn = %#lx.\n"), pOEMDevModeParam->pPublicDMIn));
  278. VERBOSE((("\tpPublicDMOut = %#lx.\n"), pOEMDevModeParam->pPublicDMOut));
  279. VERBOSE((("\tpOEMDMIn = %#lx.\n"), pOEMDevModeParam->pOEMDMIn));
  280. VERBOSE((("\tpOEMDMOut = %#lx.\n"), pOEMDevModeParam->pOEMDMOut));
  281. VERBOSE((("\tcbBufSize = %d.\n"), pOEMDevModeParam->cbBufSize));
  282. }
  283. }