377 lines
6.9 KiB
C
377 lines
6.9 KiB
C
/*++
|
||
|
||
Copyright (c) 1993 Microsoft Corporation
|
||
|
||
Module Name:
|
||
|
||
sphw.h
|
||
|
||
Abstract:
|
||
|
||
Header file for hardware detection and
|
||
confirmation routines for text setup.
|
||
|
||
Author:
|
||
|
||
Ted Miller (tedm) 1-October-1993
|
||
|
||
Revision History:
|
||
|
||
--*/
|
||
|
||
|
||
#ifndef _SPHW_DEFN_
|
||
#define _SPHW_DEFN_
|
||
|
||
VOID
|
||
SpConfirmScsiMiniports(
|
||
IN PVOID SifHandle,
|
||
IN PWSTR SourceDevicePath,
|
||
IN PWSTR DirectoryOnSourceDevice
|
||
);
|
||
|
||
VOID
|
||
SpConfirmHardware(
|
||
IN PVOID SifHandle
|
||
);
|
||
|
||
VOID
|
||
SpInitializePreinstallList(
|
||
IN HANDLE MasterSifHandle,
|
||
IN PWSTR SetupSourceDevicePath,
|
||
IN PWSTR OemPreinstallSourcePath
|
||
);
|
||
|
||
|
||
//
|
||
// In splddrv.c
|
||
//
|
||
VOID
|
||
SpLoadScsiClassDrivers(
|
||
IN PVOID SifHandle,
|
||
IN PWSTR SourceDevicePath,
|
||
IN PWSTR DirectoryOnBootDevice
|
||
);
|
||
|
||
VOID
|
||
SpLoadCdRomDrivers(
|
||
IN PVOID SifHandle,
|
||
IN PWSTR SourceDevicePath,
|
||
IN PWSTR DirectoryOnBootDevice
|
||
);
|
||
|
||
VOID
|
||
SpLoadDiskDrivers(
|
||
IN PVOID SifHandle,
|
||
IN PWSTR SourceDevicePath,
|
||
IN PWSTR DirectoryOnBootDevice
|
||
);
|
||
|
||
BOOLEAN
|
||
SpInstallingMp(
|
||
VOID
|
||
);
|
||
|
||
BOOLEAN
|
||
SpSelectSectionItem(
|
||
IN PVOID SifHandle,
|
||
IN PWSTR SectionName,
|
||
IN ULONG SelectScreenId,
|
||
IN ULONG DefaultSelection OPTIONAL,
|
||
OUT PULONG SelectedOption
|
||
);
|
||
|
||
//
|
||
// enum to represent flopy disk drive types.
|
||
//
|
||
typedef enum {
|
||
FloppyTypeNone,
|
||
FloppyType525Low,
|
||
FloppyType525High,
|
||
FloppyType35Low,
|
||
FloppyType35High,
|
||
FloppyType35High120MB
|
||
} FloppyDriveType;
|
||
|
||
FloppyDriveType
|
||
SpGetFloppyDriveType(
|
||
IN ULONG FloppyOrdinal
|
||
);
|
||
|
||
#define IS_525_DRIVE(x) (((x)==FloppyType525Low) || ((x)==FloppyType525High))
|
||
#define IS_35_DRIVE(x) (((x)==FloppyType35Low) || ((x)==FloppyType35High))
|
||
|
||
|
||
typedef struct _HARDWARE_COMPONENT_REGISTRY {
|
||
|
||
struct _HARDWARE_COMPONENT_REGISTRY *Next;
|
||
|
||
//
|
||
// The name of the key. The empty string means the key in the
|
||
// services key itself.
|
||
//
|
||
|
||
PWSTR KeyName;
|
||
|
||
//
|
||
// The name of the value within the registry key
|
||
//
|
||
|
||
PWSTR ValueName;
|
||
|
||
//
|
||
// The data type for the value (ie, REG_DWORD, etc)
|
||
//
|
||
|
||
ULONG ValueType;
|
||
|
||
//
|
||
// The buffer containing the data to be placed into the value
|
||
//
|
||
|
||
PVOID Buffer;
|
||
|
||
//
|
||
// The size of the buffer in bytes
|
||
//
|
||
|
||
ULONG BufferSize;
|
||
|
||
|
||
} HARDWARE_COMPONENT_REGISTRY, *PHARDWARE_COMPONENT_REGISTRY;
|
||
|
||
|
||
//
|
||
// One of these will be created for each file to be copied for a
|
||
// third party device.
|
||
//
|
||
typedef struct _HARDWARE_COMPONENT_FILE {
|
||
|
||
struct _HARDWARE_COMPONENT_FILE *Next;
|
||
|
||
//
|
||
// Filename of the file.
|
||
//
|
||
|
||
PWSTR Filename;
|
||
|
||
//
|
||
// type of the file (hal, port, class, etc).
|
||
//
|
||
|
||
HwFileType FileType;
|
||
|
||
//
|
||
// Part of name of the section in txtsetup.oem [Config.<ConfigName>]
|
||
// that contains registry options. If this is NULL, then no registry
|
||
// information is associated with this file.
|
||
//
|
||
PWSTR ConfigName;
|
||
|
||
//
|
||
// Registry values for the node in the services list in the registry.
|
||
//
|
||
|
||
PHARDWARE_COMPONENT_REGISTRY RegistryValueList;
|
||
|
||
//
|
||
// These two fields are used when prompting for the diskette
|
||
// containing the third-party-supplied driver's files.
|
||
//
|
||
|
||
PWSTR DiskDescription;
|
||
PWSTR DiskTagFile;
|
||
|
||
//
|
||
// Directory where files are to be found on the disk.
|
||
//
|
||
PWSTR Directory;
|
||
|
||
//
|
||
// Arc name of the device from which the file was copied
|
||
//
|
||
PWSTR ArcDeviceName;
|
||
|
||
} HARDWARE_COMPONENT_FILE, *PHARDWARE_COMPONENT_FILE;
|
||
|
||
|
||
|
||
//
|
||
// structure for storing information about a driver we have located and
|
||
// will install.
|
||
//
|
||
|
||
typedef struct _HARDWARE_COMPONENT {
|
||
|
||
struct _HARDWARE_COMPONENT *Next;
|
||
|
||
//
|
||
// String used as a key into the relevent section (like [Display],
|
||
// [Mouse], etc).
|
||
//
|
||
|
||
PWSTR IdString;
|
||
|
||
//
|
||
// String that describes the hardware.
|
||
//
|
||
|
||
PWSTR Description;
|
||
|
||
//
|
||
// If this is TRUE, then there is an OEM option selected for this
|
||
// hardware.
|
||
//
|
||
|
||
BOOLEAN ThirdPartyOptionSelected;
|
||
|
||
//
|
||
// Bits to be set if a third party option is selected, indicating
|
||
// which type of files are specified in the oem inf file.
|
||
//
|
||
|
||
ULONG FileTypeBits;
|
||
|
||
//
|
||
// Files for a third party option.
|
||
//
|
||
|
||
PHARDWARE_COMPONENT_FILE Files;
|
||
|
||
//
|
||
// For some components this is the name of a device driver file.
|
||
//
|
||
PWSTR BaseDllName;
|
||
|
||
//
|
||
// If this is TRUE, then the driver for this device was migrated from an
|
||
// existing NT system.
|
||
//
|
||
|
||
BOOLEAN MigratedDriver;
|
||
|
||
} HARDWARE_COMPONENT, *PHARDWARE_COMPONENT;
|
||
|
||
|
||
PHARDWARE_COMPONENT
|
||
SpSetupldrHwToHwDevice(
|
||
IN PDETECTED_DEVICE SetupldrHw
|
||
);
|
||
|
||
extern PHARDWARE_COMPONENT HardwareComponents[HwComponentMax];
|
||
extern PHARDWARE_COMPONENT ScsiHardware;
|
||
extern PHARDWARE_COMPONENT BootBusExtenders;
|
||
extern PHARDWARE_COMPONENT BusExtenders;
|
||
extern PHARDWARE_COMPONENT InputDevicesSupport;
|
||
extern PHARDWARE_COMPONENT PreinstallHardwareComponents[HwComponentMax];
|
||
extern PHARDWARE_COMPONENT PreinstallScsiHardware;
|
||
extern PHARDWARE_COMPONENT UnsupportedScsiHardwareToDisable;
|
||
|
||
#ifdef _ALPHA_
|
||
|
||
extern PWSTR OemPalFilename, OemPalDiskDescription;
|
||
|
||
#endif _ALPHA_
|
||
|
||
VOID
|
||
SpFreeHwComponent(
|
||
IN OUT PHARDWARE_COMPONENT *HwComp,
|
||
IN BOOLEAN FreeAllInList
|
||
);
|
||
|
||
|
||
//
|
||
// These are the names of the components. This is array is not localized
|
||
// because it is used only to index hardware-related sections in the
|
||
// setup information file.
|
||
//
|
||
extern PWSTR NonlocalizedComponentNames[HwComponentMax];
|
||
|
||
extern PWSTR ScsiSectionName;
|
||
|
||
extern ULONG LoadedScsiMiniportCount;
|
||
|
||
|
||
//
|
||
// structure for storing the PNP database.
|
||
//
|
||
|
||
typedef struct _SETUP_PNP_HARDWARE_ID {
|
||
|
||
struct _SETUP_PNP_HARDWARE_ID *Next;
|
||
|
||
//
|
||
// String that represents the hardware id of a PNP device.
|
||
//
|
||
|
||
PWSTR Id;
|
||
|
||
//
|
||
// Driver for the device
|
||
//
|
||
|
||
PWSTR DriverName;
|
||
|
||
//
|
||
// Class GUID for this device, if any
|
||
//
|
||
|
||
PWSTR ClassGuid;
|
||
|
||
|
||
} SETUP_PNP_HARDWARE_ID, *PSETUP_PNP_HARDWARE_ID;
|
||
|
||
|
||
PSETUP_PNP_HARDWARE_ID
|
||
SpSetupldrPnpDatabaseToSetupPnpDatabase(
|
||
IN PPNP_HARDWARE_ID HardwareIdDatabase
|
||
);
|
||
|
||
//
|
||
// OEM Virtual Source Device abstraction
|
||
//
|
||
typedef struct _VIRTUAL_OEM_SOURCE_DEVICE {
|
||
//
|
||
// Next device
|
||
//
|
||
struct _VIRTUAL_OEM_SOURCE_DEVICE *Next;
|
||
|
||
//
|
||
// Device Id (for ARC name mapping)
|
||
//
|
||
ULONG DeviceId;
|
||
|
||
//
|
||
// Arc device name
|
||
//
|
||
PWSTR ArcDeviceName;
|
||
|
||
//
|
||
// Memory address where the device image is copied
|
||
// by the loader
|
||
//
|
||
PVOID ImageBase;
|
||
|
||
//
|
||
// Image size
|
||
//
|
||
ULONGLONG ImageSize;
|
||
|
||
} VIRTUAL_OEM_SOURCE_DEVICE, *PVIRTUAL_OEM_SOURCE_DEVICE;
|
||
|
||
#define MS_RAMDISK_DRIVER_PARAM L"Disk"
|
||
|
||
//
|
||
// Virtual OEM source devices (accessible through RAM driver)
|
||
//
|
||
extern PVIRTUAL_OEM_SOURCE_DEVICE VirtualOemSourceDevices;
|
||
|
||
NTSTATUS
|
||
SpInitVirtualOemDevices(
|
||
IN PSETUP_LOADER_BLOCK SetupLoaderBlock,
|
||
OUT PVIRTUAL_OEM_SOURCE_DEVICE *SourceDevices
|
||
);
|
||
|
||
#endif // ndef _SPHW_DEFN_
|
||
|