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.

818 lines
25 KiB

  1. /*++
  2. Copyright (c) 1993-2000 Microsoft Corporation
  3. Module Name:
  4. infload.h
  5. Abstract:
  6. Private header file for internal inf routines.
  7. Author:
  8. Ted Miller (tedm) 19-Jan-1995
  9. Revision History:
  10. Gabe Schaffer (t-gabes) 19-Jul-1998
  11. Added LogContext to LOADED_INF
  12. --*/
  13. //
  14. // Define maximum string sizes allowed in INFs.
  15. //
  16. #define MAX_STRING_LENGTH 511 // this is the maximum size of an unsubstituted string
  17. #define MAX_SECT_NAME_LEN 255
  18. #if MAX_SECT_NAME_LEN > MAX_STRING_LENGTH
  19. #error MAX_SECT_NAME_LEN is too large!
  20. #endif
  21. #define MAX_LOGCONFKEYSTR_LEN 15
  22. #include "pshpack1.h"
  23. //
  24. // Make absolutely sure that these structures are DWORD aligned
  25. // because we turn alignment off, to make sure sdtructures are
  26. // packed as tightly as possible into memory blocks.
  27. //
  28. //
  29. // Internal representation of a section in an inf file
  30. //
  31. typedef struct _INF_LINE {
  32. //
  33. // Number of values on the line
  34. // This includes the key if Flags has INF_LINE_HASKEY
  35. // (In that case the first two entries in the Values array
  36. // contain the key--the first one in case-insensitive form used
  37. // for lookup, and the second in case-sensitive form for display.
  38. // INF lines with a single value (no key) are treated the same way.)
  39. // Otherwise the first entry in the Values array is the first
  40. // value on the line
  41. //
  42. WORD ValueCount;
  43. WORD Flags;
  44. //
  45. // String IDs for the values on the line.
  46. // The values are stored in the value block,
  47. // one after another.
  48. //
  49. // The value is the offset within the value block as opposed to
  50. // an actual pointer. We do this because the value block gets
  51. // reallocated as the inf file is loaded.
  52. //
  53. UINT Values;
  54. } INF_LINE, *PINF_LINE;
  55. //
  56. // INF_LINE.Flags
  57. //
  58. #define INF_LINE_HASKEY 0x0000001
  59. #define INF_LINE_SEARCHABLE 0x0000002
  60. #define HASKEY(Line) ((Line)->Flags & INF_LINE_HASKEY)
  61. #define ISSEARCHABLE(Line) ((Line)->Flags & INF_LINE_SEARCHABLE)
  62. //
  63. // INF section
  64. // This guy is kept separate and has a pointer to the actual data
  65. // to make sorting the sections a little easier
  66. //
  67. typedef struct _INF_SECTION {
  68. //
  69. // String Table ID of the name of the section
  70. //
  71. LONG SectionName;
  72. //
  73. // Number of lines in this section
  74. //
  75. DWORD LineCount;
  76. //
  77. // The section's lines. The line structures are stored packed
  78. // in the line block, one after another.
  79. //
  80. // The value is the offset within the line block as opposed to
  81. // an actual pointer. We do it this way because the line block
  82. // gets reallocated as the inf file is loaded.
  83. //
  84. UINT Lines;
  85. } INF_SECTION, *PINF_SECTION;
  86. //
  87. // Params for section enumeration
  88. //
  89. typedef struct {
  90. PTSTR Buffer;
  91. UINT Size;
  92. UINT SizeNeeded;
  93. PTSTR End;
  94. } SECTION_ENUM_PARAMS, *PSECTION_ENUM_PARAMS;
  95. #include "poppack.h"
  96. //
  97. // Define structures for user-defined DIRID storage.
  98. //
  99. typedef struct _USERDIRID {
  100. UINT Id;
  101. TCHAR Directory[MAX_PATH];
  102. } USERDIRID, *PUSERDIRID;
  103. typedef struct _USERDIRID_LIST {
  104. PUSERDIRID UserDirIds; // may be NULL
  105. UINT UserDirIdCount;
  106. } USERDIRID_LIST, *PUSERDIRID_LIST;
  107. typedef struct _STRINGSUBST_NODE {
  108. UINT ValueOffset;
  109. LONG TemplateStringId;
  110. BOOL CaseSensitive;
  111. } STRINGSUBST_NODE, *PSTRINGSUBST_NODE;
  112. //
  113. // Any system DIRID (i.e., >0x8000) that has bit 0x4000 set is a 'volatile'
  114. // DIRID (these DIRIDs are volatile in the sense that, while they're not in the
  115. // user-definable range, they're treated as if they were, and string replacement
  116. // is done on-the-fly each time the PNF is loaded. The shell special folders
  117. // (CSIDL_* defines in sdk\inc\shlobj.h), for example, are in this range. In
  118. // the case of shell special folders, the actual CSIDL value (i.e., as is
  119. // passed into SHGetSpecialFolderPath) can be obtained by simply masking out
  120. // the volatile DIRID bit.
  121. //
  122. // Define the bitmask used to determine whether a system DIRID is volatile.
  123. //
  124. #define VOLATILE_DIRID_FLAG 0x4000
  125. //
  126. // Version block structure that is stored (packed) in the opaque
  127. // VersionData buffer of a caller-supplied SP_INF_INFORMATION structure.
  128. //
  129. typedef struct _INF_VERSION_BLOCK {
  130. UINT NextOffset;
  131. FILETIME LastWriteTime;
  132. WORD DatumCount;
  133. WORD OffsetToData; // offset (in bytes) from beginning of Filename buffer.
  134. UINT DataSize; // DataSize and TotalSize are both byte counts.
  135. UINT TotalSize;
  136. TCHAR Filename[ANYSIZE_ARRAY];
  137. //
  138. // Data follows Filename in the buffer
  139. //
  140. } INF_VERSION_BLOCK, *PINF_VERSION_BLOCK;
  141. //
  142. // Internal version block node.
  143. //
  144. typedef struct _INF_VERSION_NODE {
  145. FILETIME LastWriteTime;
  146. UINT FilenameSize;
  147. CONST TCHAR *DataBlock;
  148. UINT DataSize;
  149. WORD DatumCount;
  150. TCHAR Filename[MAX_PATH];
  151. } INF_VERSION_NODE, *PINF_VERSION_NODE;
  152. //
  153. // Internal representation of an inf file.
  154. //
  155. typedef struct _LOADED_INF {
  156. DWORD Signature;
  157. //
  158. // The following 3 fields are used for precompiled INFs (PNF).
  159. // If FileHandle is not INVALID_HANDLE_VALUE, then this is a PNF,
  160. // and the MappingHandle and ViewAddress fields are also valid.
  161. // Otherwise, this is a plain old in-memory INF.
  162. //
  163. HANDLE FileHandle;
  164. HANDLE MappingHandle;
  165. PVOID ViewAddress;
  166. PVOID StringTable;
  167. DWORD SectionCount;
  168. PINF_SECTION SectionBlock;
  169. PINF_LINE LineBlock;
  170. PLONG ValueBlock;
  171. INF_VERSION_NODE VersionBlock;
  172. BOOL HasStrings;
  173. //
  174. // If this INF contains any DIRID references to the system partition, then
  175. // store the OsLoader path that was used when compiling this INF here. (This
  176. // value will always be correct when the INF is loaded. However, if drive letters
  177. // are subsequently reassigned, then it will be incorrect until the INF is unloaded
  178. // and re-loaded.)
  179. //
  180. PCTSTR OsLoaderPath; // may be NULL
  181. //
  182. // Remember the location where this INF originally came from (may be a directory
  183. // path or a URL).
  184. //
  185. DWORD InfSourceMediaType; // SPOST_PATH or SPOST_URL
  186. PCTSTR InfSourcePath; // may be NULL
  187. //
  188. // Remember the INF's original filename, before it was installed into
  189. // %windir%\Inf (i.e., automatically via device installation or explicitly
  190. // via SetupCopyOEMInf).
  191. //
  192. PCTSTR OriginalInfName; // may be NULL
  193. //
  194. // Maintain a list of value offsets that require string substitution at
  195. // run-time.
  196. //
  197. PSTRINGSUBST_NODE SubstValueList; // may be NULL
  198. WORD SubstValueCount;
  199. //
  200. // Place the style WORD here (immediately following another WORD field),
  201. // to fill a single DWORD.
  202. //
  203. WORD Style; // INF_STYLE_OLDNT, INF_STYLE_WIN4
  204. //
  205. // Sizes in bytes of various buffers
  206. //
  207. UINT SectionBlockSizeBytes;
  208. UINT LineBlockSizeBytes;
  209. UINT ValueBlockSizeBytes;
  210. //
  211. // Track what language was used when loading this INF.
  212. //
  213. DWORD LanguageId;
  214. //
  215. // Embedded structure containing information about the current user-defined
  216. // DIRID values.
  217. //
  218. USERDIRID_LIST UserDirIdList;
  219. //
  220. // Synchronization.
  221. //
  222. MYLOCK Lock;
  223. //
  224. // Log context for error logging
  225. //
  226. PSETUP_LOG_CONTEXT LogContext;
  227. //
  228. // Other flags
  229. //
  230. DWORD Flags;
  231. //
  232. // INFs are append-loaded via a doubly-linked list of LOADED_INFs.
  233. // (list is not circular--Prev of head is NULL, Next of tail is NULL)
  234. //
  235. struct _LOADED_INF *Prev;
  236. struct _LOADED_INF *Next;
  237. } LOADED_INF, *PLOADED_INF;
  238. #define LOADED_INF_SIG 0x24666e49 // Inf$
  239. #define LockInf(Inf) BeginSynchronizedAccess(&(Inf)->Lock)
  240. #define UnlockInf(Inf) EndSynchronizedAccess(&(Inf)->Lock)
  241. //
  242. // Define values for LOADED_INF.Flags field
  243. //
  244. //
  245. // WARNING: The LIF_INF_DIGITALLY_SIGNED flag does not guarantee that the INF
  246. // is currently digitally signed. When creating the PNF we verify that the INF
  247. // is correctly digitally signed and then set this bit in the PNF. Currently we
  248. // only use this flag to determine whether we should use the DriverVer date
  249. // or not.
  250. //
  251. #define LIF_HAS_VOLATILE_DIRIDS (0x00000001)
  252. #define LIF_INF_DIGITALLY_SIGNED (0x00000002)
  253. #define LIF_OEM_F6_INF (0x00000004)
  254. //
  255. // Helper define
  256. //
  257. #define INF_STYLE_ALL (INF_STYLE_WIN4 | INF_STYLE_OLDNT)
  258. //
  259. // Define file header structure for precompiled INF (.PNF).
  260. //
  261. typedef struct _PNF_HEADER {
  262. WORD Version; // HiByte - Major Ver#, LoByte - Minor Ver#
  263. WORD InfStyle;
  264. DWORD Flags;
  265. DWORD InfSubstValueListOffset;
  266. WORD InfSubstValueCount;
  267. WORD InfVersionDatumCount;
  268. DWORD InfVersionDataSize;
  269. DWORD InfVersionDataOffset;
  270. FILETIME InfVersionLastWriteTime;
  271. DWORD StringTableBlockOffset;
  272. DWORD StringTableBlockSize;
  273. DWORD InfSectionCount;
  274. DWORD InfSectionBlockOffset;
  275. DWORD InfSectionBlockSize;
  276. DWORD InfLineBlockOffset;
  277. DWORD InfLineBlockSize;
  278. DWORD InfValueBlockOffset;
  279. DWORD InfValueBlockSize;
  280. DWORD WinDirPathOffset;
  281. DWORD OsLoaderPathOffset;
  282. WORD StringTableHashBucketCount;
  283. WORD LanguageId;
  284. DWORD InfSourcePathOffset; // may be 0
  285. DWORD OriginalInfNameOffset; // may be 0
  286. } PNF_HEADER, *PPNF_HEADER;
  287. //
  288. // Define Major and Minor versions of the PNF format (currently 1.1)
  289. //
  290. #define PNF_MAJOR_VERSION (0x01)
  291. #define PNF_MINOR_VERSION (0x01)
  292. //
  293. // Define flag values for the PNF header's Flags field.
  294. //
  295. // WARNING: The PNF_FLAG_INF_DIGITALLY_SIGNED flag does not guarantee that the INF
  296. // is currently digitally signed. When creating the PNF we verify that the INF
  297. // is correctly digitally signed and then set this bit in the PNF. Currently we
  298. // only use this flag to determine whether we should use the DriverVer date
  299. // or not.
  300. #define PNF_FLAG_IS_UNICODE (0x00000001)
  301. #define PNF_FLAG_HAS_STRINGS (0x00000002)
  302. #define PNF_FLAG_SRCPATH_IS_URL (0x00000004)
  303. #define PNF_FLAG_HAS_VOLATILE_DIRIDS (0x00000008)
  304. #define PNF_FLAG_RESERVED1 (0x00000010) // was PNF_FLAG_INF_VERIFIED for Win2k
  305. #define PNF_FLAG_INF_DIGITALLY_SIGNED (0x00000020)
  306. #define PNF_FLAG_OEM_F6_INF (0x00000040)
  307. #define PNF_FLAG_16BIT_SUITE (0x00000080) // if set, lower 16 bits of suite
  308. // is in upper 16 bits of flags
  309. #define PNF_FLAG_INF_VERIFIED (0x00000100)
  310. //
  311. // Public inf functions in infload.c. All other routines are private to
  312. // the inf handler package.
  313. //
  314. DWORD
  315. DetermineInfStyle(
  316. IN PCTSTR Filename,
  317. IN LPWIN32_FIND_DATA FindData
  318. );
  319. //
  320. // Flags for LoadInfFile.
  321. //
  322. #define LDINF_FLAG_MATCH_CLASS_GUID (0x00000001)
  323. #define LDINF_FLAG_ALWAYS_TRY_PNF (0x00000002)
  324. #define LDINF_FLAG_IGNORE_VOLATILE_DIRIDS (0x00000004) // includes system partition
  325. #define LDINF_FLAG_IGNORE_LANGUAGE (0x00000008)
  326. #define LDINF_FLAG_REGENERATE_PNF (0x00000010)
  327. #define LDINF_FLAG_SRCPATH_IS_URL (0x00000020)
  328. #define LDINF_FLAG_ALWAYS_GET_SRCPATH (0x00000040) // used to work around TZ change in FAT
  329. #define LDINF_FLAG_OEM_F6_INF (0x00000080)
  330. #define LDINF_FLAG_ALLOW_PNF_SHARING_LOCK (0x00000100) // don't fail if PNF locked
  331. DWORD
  332. LoadInfFile(
  333. IN PCTSTR Filename,
  334. IN LPWIN32_FIND_DATA FileData,
  335. IN DWORD Style,
  336. IN DWORD Flags,
  337. IN PCTSTR ClassGuidString, OPTIONAL
  338. IN PCTSTR InfSourcePath, OPTIONAL
  339. IN PCTSTR OriginalInfName, OPTIONAL
  340. IN PLOADED_INF AppendInf, OPTIONAL
  341. IN PSETUP_LOG_CONTEXT LogContext, OPTIONAL
  342. OUT PLOADED_INF *LoadedInf,
  343. OUT UINT *ErrorLineNumber,
  344. OUT BOOL *PnfWasUsed OPTIONAL
  345. );
  346. VOID
  347. FreeInfFile(
  348. IN PLOADED_INF LoadedInf
  349. );
  350. //
  351. // Global strings used throughout the inf loaders/runtime stuff. Sizes are
  352. // included so that we can do sizeof() instead of lstrlen() to determine string
  353. // length.
  354. //
  355. // The content of the following strings is defined in infstr.h:
  356. //
  357. extern CONST TCHAR pszSignature[SIZECHARS(INFSTR_KEY_SIGNATURE)],
  358. pszVersion[SIZECHARS(INFSTR_SECT_VERSION)],
  359. pszClass[SIZECHARS(INFSTR_KEY_HARDWARE_CLASS)],
  360. pszClassGuid[SIZECHARS(INFSTR_KEY_HARDWARE_CLASSGUID)],
  361. pszProvider[SIZECHARS(INFSTR_KEY_PROVIDER)],
  362. pszStrings[SIZECHARS(SZ_KEY_STRINGS)],
  363. pszLayoutFile[SIZECHARS(SZ_KEY_LAYOUT_FILE)],
  364. pszManufacturer[SIZECHARS(INFSTR_SECT_MFG)],
  365. pszControlFlags[SIZECHARS(INFSTR_CONTROLFLAGS_SECTION)],
  366. pszSourceDisksNames[SIZECHARS(SZ_KEY_SRCDISKNAMES)],
  367. pszSourceDisksFiles[SIZECHARS(SZ_KEY_SRCDISKFILES)],
  368. pszDestinationDirs[SIZECHARS(SZ_KEY_DESTDIRS)],
  369. pszDefaultDestDir[SIZECHARS(SZ_KEY_DEFDESTDIR)],
  370. pszReboot[SIZECHARS(INFSTR_REBOOT)],
  371. pszRestart[SIZECHARS(INFSTR_RESTART)],
  372. pszClassInstall32[SIZECHARS(INFSTR_SECT_CLASS_INSTALL_32)],
  373. pszAddInterface[SIZECHARS(SZ_KEY_ADDINTERFACE)],
  374. pszInterfaceInstall32[SIZECHARS(INFSTR_SECT_INTERFACE_INSTALL_32)],
  375. pszAddService[SIZECHARS(SZ_KEY_ADDSERVICE)],
  376. pszDelService[SIZECHARS(SZ_KEY_DELSERVICE)],
  377. pszCatalogFile[SIZECHARS(INFSTR_KEY_CATALOGFILE)],
  378. pszMemConfig[SIZECHARS(INFSTR_KEY_MEMCONFIG)],
  379. pszIOConfig[SIZECHARS(INFSTR_KEY_IOCONFIG)],
  380. pszIRQConfig[SIZECHARS(INFSTR_KEY_IRQCONFIG)],
  381. pszDMAConfig[SIZECHARS(INFSTR_KEY_DMACONFIG)],
  382. pszPcCardConfig[SIZECHARS(INFSTR_KEY_PCCARDCONFIG)],
  383. pszMfCardConfig[SIZECHARS(INFSTR_KEY_MFCARDCONFIG)],
  384. pszConfigPriority[SIZECHARS(INFSTR_KEY_CONFIGPRIORITY)],
  385. pszDriverVer[SIZECHARS(INFSTR_DRIVERVERSION_SECTION)];
  386. //
  387. // Other misc. global strings:
  388. //
  389. #define DISTR_INF_DRVDESCFMT (TEXT("%s.") INFSTR_STRKEY_DRVDESC)
  390. #define DISTR_INF_HWSECTIONFMT (TEXT("%s.") INFSTR_SUBKEY_HW)
  391. #define DISTR_INF_CHICAGOSIG (TEXT("$Chicago$"))
  392. #define DISTR_INF_WINNTSIG (TEXT("$Windows NT$"))
  393. #define DISTR_INF_WIN95SIG (TEXT("$Windows 95$"))
  394. #define DISTR_INF_WIN_SUFFIX (TEXT(".") INFSTR_PLATFORM_WIN)
  395. #define DISTR_INF_NT_SUFFIX (TEXT(".") INFSTR_PLATFORM_NT)
  396. #define DISTR_INF_PNF_SUFFIX (TEXT(".PNF"))
  397. #define DISTR_INF_INF_SUFFIX (TEXT(".INF"))
  398. #define DISTR_INF_CAT_SUFFIX (TEXT(".CAT"))
  399. #define DISTR_INF_SERVICES_SUFFIX (TEXT(".") INFSTR_SUBKEY_SERVICES)
  400. #define DISTR_INF_INTERFACES_SUFFIX (TEXT(".") INFSTR_SUBKEY_INTERFACES)
  401. #define DISTR_INF_COINSTALLERS_SUFFIX (TEXT(".") INFSTR_SUBKEY_COINSTALLERS)
  402. #define DISTR_INF_LOGCONFIGOVERRIDE_SUFFIX (TEXT(".") INFSTR_SUBKEY_LOGCONFIGOVERRIDE)
  403. //
  404. // Define all platform-specific suffix strings for which we support non-native
  405. // digital signature verification...
  406. //
  407. #define DISTR_INF_NTALPHA_SUFFIX (TEXT(".") INFSTR_PLATFORM_NTALPHA)
  408. #define DISTR_INF_NTX86_SUFFIX (TEXT(".") INFSTR_PLATFORM_NTX86)
  409. #define DISTR_INF_NTIA64_SUFFIX (TEXT(".") INFSTR_PLATFORM_NTIA64)
  410. #define DISTR_INF_NTAXP64_SUFFIX (TEXT(".") INFSTR_PLATFORM_NTAXP64)
  411. #define DISTR_INF_NTAMD64_SUFFIX (TEXT(".") INFSTR_PLATFORM_NTAMD64)
  412. //
  413. // Define platform decoration strings for use on [SourceDisksNames] and
  414. // [SourceDisksFiles] sections.
  415. //
  416. #define DISTR_INF_SRCDISK_SUFFIX_ALPHA (TEXT("Alpha"))
  417. #define DISTR_INF_SRCDISK_SUFFIX_X86 (TEXT("x86"))
  418. #define DISTR_INF_SRCDISK_SUFFIX_IA64 (TEXT("ia64"))
  419. #define DISTR_INF_SRCDISK_SUFFIX_AXP64 (TEXT("axp64"))
  420. #define DISTR_INF_SRCDISK_SUFFIX_AMD64 (TEXT("amd64"))
  421. //
  422. // (Sizes are included for all strings that we define privately. This
  423. // is done so that we can do sizeof() instead of lstrlen() to determine
  424. // string length. Keep in sync with definitions in infload.c!)
  425. //
  426. extern CONST TCHAR pszDrvDescFormat[SIZECHARS(DISTR_INF_DRVDESCFMT)],
  427. pszHwSectionFormat[SIZECHARS(DISTR_INF_HWSECTIONFMT)],
  428. pszChicagoSig[SIZECHARS(DISTR_INF_CHICAGOSIG)],
  429. pszWindowsNTSig[SIZECHARS(DISTR_INF_WINNTSIG)],
  430. pszWindows95Sig[SIZECHARS(DISTR_INF_WIN95SIG)],
  431. pszWinSuffix[SIZECHARS(DISTR_INF_WIN_SUFFIX)],
  432. pszNtSuffix[SIZECHARS(DISTR_INF_NT_SUFFIX)],
  433. pszNtAlphaSuffix[SIZECHARS(DISTR_INF_NTALPHA_SUFFIX)],
  434. pszNtX86Suffix[SIZECHARS(DISTR_INF_NTX86_SUFFIX)],
  435. pszNtIA64Suffix[SIZECHARS(DISTR_INF_NTIA64_SUFFIX)],
  436. pszNtAXP64Suffix[SIZECHARS(DISTR_INF_NTAXP64_SUFFIX)],
  437. pszNtAMD64Suffix[SIZECHARS(DISTR_INF_NTAMD64_SUFFIX)],
  438. pszPnfSuffix[SIZECHARS(DISTR_INF_PNF_SUFFIX)],
  439. pszInfSuffix[SIZECHARS(DISTR_INF_INF_SUFFIX)],
  440. pszCatSuffix[SIZECHARS(DISTR_INF_CAT_SUFFIX)],
  441. pszServicesSectionSuffix[SIZECHARS(DISTR_INF_SERVICES_SUFFIX)],
  442. pszInterfacesSectionSuffix[SIZECHARS(DISTR_INF_INTERFACES_SUFFIX)],
  443. pszCoInstallersSectionSuffix[SIZECHARS(DISTR_INF_COINSTALLERS_SUFFIX)],
  444. pszLogConfigOverrideSectionSuffix[SIZECHARS(DISTR_INF_LOGCONFIGOVERRIDE_SUFFIX)],
  445. pszAlphaSrcDiskSuffix[SIZECHARS(DISTR_INF_SRCDISK_SUFFIX_ALPHA)],
  446. pszX86SrcDiskSuffix[SIZECHARS(DISTR_INF_SRCDISK_SUFFIX_X86)],
  447. pszIa64SrcDiskSuffix[SIZECHARS(DISTR_INF_SRCDISK_SUFFIX_IA64)],
  448. pszAxp64SrcDiskSuffix[SIZECHARS(DISTR_INF_SRCDISK_SUFFIX_AXP64)],
  449. pszAmd64SrcDiskSuffix[SIZECHARS(DISTR_INF_SRCDISK_SUFFIX_AMD64)];
  450. //
  451. // Define constants that equate to native architecture suffixes...
  452. //
  453. #if defined(_ALPHA_)
  454. #define pszNtPlatformSuffix pszNtAlphaSuffix
  455. #define pszPlatformSrcDiskSuffix pszAlphaSrcDiskSuffix
  456. #elif defined(_X86_)
  457. #define pszNtPlatformSuffix pszNtX86Suffix
  458. #define pszPlatformSrcDiskSuffix pszX86SrcDiskSuffix
  459. #elif defined(_IA64_)
  460. #define pszNtPlatformSuffix pszNtIA64Suffix
  461. #define pszPlatformSrcDiskSuffix pszIa64SrcDiskSuffix
  462. #elif defined(_AXP64_)
  463. #define pszNtPlatformSuffix pszNtAXP64Suffix
  464. #define pszPlatformSrcDiskSuffix pszAxp64SrcDiskSuffix
  465. #elif defined(_AMD64_)
  466. #define pszNtPlatformSuffix pszNtAMD64Suffix
  467. #define pszPlatformSrcDiskSuffix pszAmd64SrcDiskSuffix
  468. #else
  469. #error Unknown processor type
  470. #endif
  471. //
  472. // for now, platform name is same as pszPlatformSrcDiskSuffix (Alpha, x86, ia64, axp64, amd64)
  473. //
  474. #define pszPlatformName pszPlatformSrcDiskSuffix
  475. //
  476. // Define a (non-CONST) array of strings that specifies what lines to look for
  477. // in an INF's [ControlFlags] section when determining whether a particular device
  478. // ID should be excluded. This is filled in during process attach for speed
  479. // reasons.
  480. //
  481. // The max string length (including NULL) is 32, and there can be a maximum of 3
  482. // such strings. E.g.: ExcludeFromSelect, ExcludeFromSelect.NT, ExcludeFromSelect.NTAlpha
  483. //
  484. extern TCHAR pszExcludeFromSelectList[3][32];
  485. extern DWORD ExcludeFromSelectListUb; // contains the number of strings in the above list (2 or 3).
  486. //
  487. // Routine to determine whether a character is whitespace.
  488. //
  489. BOOL
  490. IsWhitespace(
  491. IN PCTSTR pc
  492. );
  493. //
  494. // Routine to skip whitespace (but not newlines)
  495. //
  496. VOID
  497. SkipWhitespace(
  498. IN OUT PCTSTR *Location,
  499. IN PCTSTR BufferEnd
  500. );
  501. PINF_SECTION
  502. InfLocateSection(
  503. IN PLOADED_INF Inf,
  504. IN PCTSTR SectionName,
  505. OUT PUINT SectionNumber OPTIONAL
  506. );
  507. BOOL
  508. InfLocateLine(
  509. IN PLOADED_INF Inf,
  510. IN PINF_SECTION Section,
  511. IN PCTSTR Key, OPTIONAL
  512. IN OUT PUINT LineNumber,
  513. OUT PINF_LINE *Line
  514. );
  515. PTSTR
  516. InfGetKeyOrValue(
  517. IN PLOADED_INF Inf,
  518. IN PCTSTR SectionName,
  519. IN PCTSTR LineKey, OPTIONAL
  520. IN UINT LineNumber, OPTIONAL
  521. IN UINT ValueNumber,
  522. OUT PLONG StringId OPTIONAL
  523. );
  524. PTSTR
  525. InfGetField(
  526. IN PLOADED_INF Inf,
  527. IN PINF_LINE InfLine,
  528. IN UINT ValueNumber,
  529. OUT PLONG StringId OPTIONAL
  530. );
  531. PINF_LINE
  532. InfLineFromContext(
  533. IN PINFCONTEXT Context
  534. );
  535. //
  536. // Define a macro to retrieve the case-insensitive (i.e., searchable) string ID
  537. // for an INF line's key, or -1 if there is no key.
  538. // NOTE: INF lock must have been acquired before calling this macro!
  539. //
  540. // LONG
  541. // pInfGetLineKeyId(
  542. // IN PLOADED_INF Inf,
  543. // IN PINF_LINE InfLine
  544. // )
  545. //
  546. #define pInfGetLineKeyId(Inf,InfLine) (ISSEARCHABLE(InfLine) ? (Inf)->ValueBlock[(InfLine)->Values] : -1)
  547. //
  548. // Routine to allocate and initialize a loaded inf descriptor.
  549. //
  550. PLOADED_INF
  551. AllocateLoadedInfDescriptor(
  552. IN DWORD SectionBlockSize,
  553. IN DWORD LineBlockSize,
  554. IN DWORD ValueBlockSize,
  555. IN PSETUP_LOG_CONTEXT LogContext OPTIONAL
  556. );
  557. VOID
  558. FreeInfOrPnfStructures(
  559. IN PLOADED_INF Inf
  560. );
  561. //
  562. // Define a macro to free all memory blocks associated with a loaded INF or PNF,
  563. // and then free the memory for the loaded INF structure itself
  564. //
  565. // VOID
  566. // FreeLoadedInfDescriptor(
  567. // IN PLOADED_INF Inf
  568. // );
  569. //
  570. #define FreeLoadedInfDescriptor(Inf) { \
  571. FreeInfOrPnfStructures(Inf); \
  572. MyTaggedFree(Inf,MEMTAG_INF); \
  573. }
  574. BOOL
  575. AddDatumToVersionBlock(
  576. IN OUT PINF_VERSION_NODE VersionNode,
  577. IN PCTSTR DatumName,
  578. IN PCTSTR DatumValue
  579. );
  580. //
  581. // Old inf manipulation routines, called by new inf loader
  582. //
  583. DWORD
  584. ParseOldInf(
  585. IN PCTSTR FileImage,
  586. IN DWORD FileImageSize,
  587. IN PSETUP_LOG_CONTEXT LogContext, OPTIONAL
  588. OUT PLOADED_INF *Inf,
  589. OUT UINT *ErrorLineNumber
  590. );
  591. DWORD
  592. ProcessOldInfVersionBlock(
  593. IN PLOADED_INF Inf
  594. );
  595. //
  596. // Run-time helper routines.
  597. //
  598. PCTSTR
  599. pSetupFilenameFromLine(
  600. IN PINFCONTEXT Context,
  601. IN BOOL GetSourceName
  602. );
  603. //
  604. // Logical configuration stuff, inflogcf.c
  605. //
  606. DWORD
  607. pSetupInstallLogConfig(
  608. IN HINF Inf,
  609. IN PCTSTR SectionName,
  610. IN DEVINST DevInst,
  611. IN DWORD Flags,
  612. IN HMACHINE hMachine
  613. );
  614. //
  615. // INF Version information retrieval
  616. //
  617. PCTSTR
  618. pSetupGetVersionDatum(
  619. IN PINF_VERSION_NODE VersionNode,
  620. IN PCTSTR DatumName
  621. );
  622. BOOL
  623. pSetupGetCatalogFileValue(
  624. IN PINF_VERSION_NODE InfVersionNode,
  625. OUT LPTSTR Buffer,
  626. IN DWORD BufferSize,
  627. IN PSP_ALTPLATFORM_INFO_V2 AltPlatformInfo OPTIONAL
  628. );
  629. VOID
  630. pSetupGetPhysicalInfFilepath(
  631. IN PINFCONTEXT LineContext,
  632. OUT LPTSTR Buffer,
  633. IN DWORD BufferSize
  634. );
  635. //
  636. // Private installation routines.
  637. //
  638. //
  639. // Private Flags & context for _SetupInstallFromInfSection.
  640. // passed onto pSetupInstallRegistry
  641. //
  642. typedef struct _REGMOD_CONTEXT {
  643. DWORD Flags; // indicates what fields are filled in
  644. HKEY UserRootKey; // HKR
  645. LPGUID ClassGuid; // INF_PFLAG_CLASSPROP
  646. HMACHINE hMachine; // INF_PFLAG_CLASSPROP
  647. DWORD DevInst; // INF_PFLAG_DEVPROP
  648. } REGMOD_CONTEXT, *PREGMOD_CONTEXT;
  649. #define INF_PFLAG_CLASSPROP (0x00000001) // set if called for a ClassInstall32 section
  650. #define INF_PFLAG_DEVPROP (0x00000002) // set if called for registry properties
  651. #define INF_PFLAG_HKR (0x00000004) // indicates override _SetupInstallFromInfSection RelativeKeyRoot
  652. BOOL
  653. _SetupInstallFromInfSection(
  654. IN HWND Owner, OPTIONAL
  655. IN HINF InfHandle,
  656. IN PCTSTR SectionName,
  657. IN UINT Flags,
  658. IN HKEY RelativeKeyRoot, OPTIONAL
  659. IN PCTSTR SourceRootPath, OPTIONAL
  660. IN UINT CopyFlags,
  661. IN PVOID MsgHandler,
  662. IN PVOID Context, OPTIONAL
  663. IN HDEVINFO DeviceInfoSet, OPTIONAL
  664. IN PSP_DEVINFO_DATA DeviceInfoData, OPTIONAL
  665. IN BOOL IsMsgHandlerNativeCharWidth,
  666. IN PREGMOD_CONTEXT RegContext OPTIONAL
  667. );
  668. DWORD
  669. pSetupInstallFiles(
  670. IN HINF Inf,
  671. IN HINF LayoutInf, OPTIONAL
  672. IN PCTSTR SectionName,
  673. IN PCTSTR SourceRootPath, OPTIONAL
  674. IN PSP_FILE_CALLBACK MsgHandler, OPTIONAL
  675. IN PVOID Context, OPTIONAL
  676. IN UINT CopyStyle,
  677. IN HWND Owner, OPTIONAL
  678. IN HSPFILEQ UserFileQ, OPTIONAL
  679. IN BOOL IsMsgHandlerNativeCharWidth
  680. );
  681. DWORD
  682. pSetupInstallRegistry(
  683. IN HINF Inf,
  684. IN PCTSTR SectionName,
  685. IN PREGMOD_CONTEXT RegContext OPTIONAL
  686. );
  687. DWORD
  688. _AppendStringToMultiSz(
  689. IN PCTSTR SubKeyName, OPTIONAL
  690. IN PCTSTR ValueName, OPTIONAL
  691. IN PCTSTR String,
  692. IN BOOL AllowDuplicates,
  693. IN PREGMOD_CONTEXT RegContext, OPTIONAL
  694. IN UINT Flags OPTIONAL
  695. );
  696. DWORD
  697. _DeleteStringFromMultiSz(
  698. IN PCTSTR SubKeyName, OPTIONAL
  699. IN PCTSTR ValueName, OPTIONAL
  700. IN PCTSTR String,
  701. IN UINT Flags,
  702. IN PREGMOD_CONTEXT RegContext OPTIONAL
  703. );