|
|
/*++
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_
|