2006-11-08 11:47:44 +00:00
|
|
|
/*
|
|
|
|
* PROJECT: ReactOS Kernel
|
|
|
|
* LICENSE: GPL - See COPYING in the top level directory
|
2015-10-04 11:54:25 +00:00
|
|
|
* FILE: ntoskrnl/include/internal/hal.h
|
2006-11-08 11:47:44 +00:00
|
|
|
* PURPOSE: Internal header for the I/O HAL Functions (Fstub)
|
|
|
|
* PROGRAMMERS: Alex Ionescu (alex.ionescu@reactos.org)
|
[NTOSKRNL]
Revert r51017 that was reverting r51016.
In fact, it seems that cmlib assert error, whatever that eats randomly doesn't come from software issue inside ReactOS, but from a build issue.
Indeed, as you may see in the different tests I performed it shows that the same build produces the same failure, again and again. But, new build shows that there is no assert anylonger with that commit.
Don't ask me why or how it happens, I just don't get it.
But most of the time, it works, no one knows why ("as usual" (tm)). But it's cool.
Someone from BE team and/or buildslaves managers should take a serious look at this issue.
Just in case: if that commit re-hits cmlib assert, don't blame it immediatly, just commit something else, and see whether trunk is still broken.
But, as you can see in testman, we have now test results for r51016 ;-)
svn path=/trunk/; revision=51025
2011-03-12 12:56:36 +00:00
|
|
|
* Pierre Schweitzer (pierre.schweitzer@reactos.org)
|
2006-11-08 11:47:44 +00:00
|
|
|
*/
|
2010-02-26 11:43:19 +00:00
|
|
|
|
|
|
|
#pragma once
|
2006-11-08 11:47:44 +00:00
|
|
|
|
2007-12-14 11:32:18 +00:00
|
|
|
//
|
|
|
|
// Default implementations of HAL dispatch table
|
|
|
|
//
|
|
|
|
VOID
|
|
|
|
FASTCALL
|
|
|
|
xHalExamineMBR(IN PDEVICE_OBJECT DeviceObject,
|
|
|
|
IN ULONG SectorSize,
|
|
|
|
IN ULONG MbrTypeIdentifier,
|
|
|
|
OUT PVOID *MbrBuffer);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
FASTCALL
|
|
|
|
xHalIoAssignDriveLetters(IN PLOADER_PARAMETER_BLOCK LoaderBlock,
|
|
|
|
IN PSTRING NtDeviceName,
|
|
|
|
OUT PUCHAR NtSystemPath,
|
|
|
|
OUT PSTRING NtSystemPathString);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
FASTCALL
|
|
|
|
xHalIoReadPartitionTable(IN PDEVICE_OBJECT DeviceObject,
|
|
|
|
IN ULONG SectorSize,
|
|
|
|
IN BOOLEAN ReturnRecognizedPartitions,
|
|
|
|
IN OUT PDRIVE_LAYOUT_INFORMATION *PartitionBuffer);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
FASTCALL
|
|
|
|
xHalIoSetPartitionInformation(IN PDEVICE_OBJECT DeviceObject,
|
|
|
|
IN ULONG SectorSize,
|
|
|
|
IN ULONG PartitionNumber,
|
|
|
|
IN ULONG PartitionType);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
FASTCALL
|
|
|
|
xHalIoWritePartitionTable(IN PDEVICE_OBJECT DeviceObject,
|
|
|
|
IN ULONG SectorSize,
|
|
|
|
IN ULONG SectorsPerTrack,
|
|
|
|
IN ULONG NumberOfHeads,
|
|
|
|
IN PDRIVE_LAYOUT_INFORMATION PartitionBuffer);
|
|
|
|
|
- Stub out DbgKdWriteVirtualMemoryApi, DbgKdReadPhysicalMemoryApi, DbgKdWritePhysicalMemoryApi, DbgKdWriteBreakPointExApi, DbgKdRestoreBreakPointExApi, DbgKdSearchMemoryApi and DbgKdFillMemoryApi cases more properly.
- Fail on physical memory write like we do for read too.
- Don't handle OldVlm1/2 as they appear to be deprecated and unhandled in Windows.
- Implement HalHaltSystem to halt execution in a portable way. Default to xHalHaltSystem, a simple infinite loop, if we get called before HAL has initialized. Use this in KiBugCheckDebugBreak and the system shutdown handler instead of x86/AMD64/ARM intrinsics.
- Don't try to halt the CPU if KeBugCheck has been called 3 times or more -- if this happens, something has gone very wrong, and we shouldn't try to do anything special. Just loop infinitely.
- Fix KiBugCheckDebugBreak -- it shouldn't halt execution when called for the first chance as bugcheck callbacks have not been invoked at this point (nor has the BSOD been displayed). Use SEH to protect against a crash instead of checking KdDebuggerNotPresent as the debugger, if it is present, *could* disconnect while the trap is being handled. Also, don't halt execution if the debugger handled the breakpoint, just break again.
- Don't call MmMapIoSpace from HalpReboot! The reboot might take place at elevated IRQL (as high as HIGH_LEVEL if called from KeBugCheck), and thus can't use any Mm support routines. Use a PTE from the reserved HAL region and map it ourselves instead as done in the BIOS call code.
- Acquire the display ownership in HalReturnToFirmware in case the caller hasn't done so (as done in the KD reboot routine, for example).
- Just include ntndk.h in hal.h instead of including 6 NDK headers (which turns into more than half of the NDK anyway since those headers include other NDK headers).
- Crashing and rebooting from KD now works properly.
svn path=/trunk/; revision=43380
2009-10-11 20:16:45 +00:00
|
|
|
VOID
|
|
|
|
NTAPI
|
|
|
|
xHalHaltSystem(
|
|
|
|
VOID
|
|
|
|
);
|
|
|
|
|
2010-03-08 20:37:24 +00:00
|
|
|
VOID
|
|
|
|
NTAPI
|
|
|
|
xHalEndOfBoot(
|
|
|
|
VOID
|
|
|
|
);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
NTAPI
|
|
|
|
xHalSetWakeEnable(
|
|
|
|
IN BOOLEAN Enable
|
|
|
|
);
|
|
|
|
|
2009-10-29 19:58:41 +00:00
|
|
|
UCHAR
|
|
|
|
NTAPI
|
|
|
|
xHalVectorToIDTEntry(
|
|
|
|
IN ULONG Vector
|
|
|
|
);
|
|
|
|
|
2011-03-10 21:02:21 +00:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
[NTOSKRNL]
Revert r51017 that was reverting r51016.
In fact, it seems that cmlib assert error, whatever that eats randomly doesn't come from software issue inside ReactOS, but from a build issue.
Indeed, as you may see in the different tests I performed it shows that the same build produces the same failure, again and again. But, new build shows that there is no assert anylonger with that commit.
Don't ask me why or how it happens, I just don't get it.
But most of the time, it works, no one knows why ("as usual" (tm)). But it's cool.
Someone from BE team and/or buildslaves managers should take a serious look at this issue.
Just in case: if that commit re-hits cmlib assert, don't blame it immediatly, just commit something else, and see whether trunk is still broken.
But, as you can see in testman, we have now test results for r51016 ;-)
svn path=/trunk/; revision=51025
2011-03-12 12:56:36 +00:00
|
|
|
xHalGetInterruptTranslator(
|
|
|
|
IN INTERFACE_TYPE ParentInterfaceType,
|
|
|
|
IN ULONG ParentBusNumber,
|
|
|
|
IN INTERFACE_TYPE BridgeInterfaceType,
|
|
|
|
IN USHORT Size,
|
|
|
|
IN USHORT Version,
|
|
|
|
OUT PTRANSLATOR_INTERFACE Translator,
|
|
|
|
OUT PULONG BridgeBusNumber
|
|
|
|
);
|
|
|
|
|
|
|
|
PBUS_HANDLER
|
|
|
|
FASTCALL
|
|
|
|
xHalHandlerForBus(
|
|
|
|
IN INTERFACE_TYPE InterfaceType,
|
|
|
|
IN ULONG BusNumber
|
|
|
|
);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
FASTCALL
|
|
|
|
xHalReferenceHandler(
|
|
|
|
IN PBUS_HANDLER BusHandler
|
|
|
|
);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
xHalInitPnpDriver(
|
|
|
|
VOID
|
|
|
|
);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
xHalInitPowerManagement(
|
|
|
|
IN PPM_DISPATCH_TABLE PmDriverDispatchTable,
|
|
|
|
OUT PPM_DISPATCH_TABLE *PmHalDispatchTable
|
|
|
|
);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
xHalStartMirroring(
|
|
|
|
VOID
|
|
|
|
);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
xHalEndMirroring(
|
|
|
|
IN ULONG PassNumber
|
|
|
|
);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
xHalMirrorPhysicalMemory(
|
|
|
|
IN PHYSICAL_ADDRESS PhysicalAddress,
|
|
|
|
IN LARGE_INTEGER NumberOfBytes
|
|
|
|
);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
xHalQueryBusSlots(
|
|
|
|
IN PBUS_HANDLER BusHandler,
|
|
|
|
IN ULONG BufferSize,
|
|
|
|
OUT PULONG SlotNumbers,
|
|
|
|
OUT PULONG ReturnedLength
|
|
|
|
);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
xHalSetSystemInformation(
|
|
|
|
IN HAL_SET_INFORMATION_CLASS InformationClass,
|
|
|
|
IN ULONG BufferSize,
|
|
|
|
IN PVOID Buffer
|
|
|
|
);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
xHalQuerySystemInformation(
|
|
|
|
IN HAL_QUERY_INFORMATION_CLASS InformationClass,
|
|
|
|
IN ULONG BufferSize,
|
|
|
|
IN OUT PVOID Buffer,
|
|
|
|
OUT PULONG ReturnedLength
|
|
|
|
);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
NTAPI
|
|
|
|
xHalLocateHiberRanges(
|
|
|
|
IN PVOID MemoryMap
|
|
|
|
);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
xHalRegisterBusHandler(
|
|
|
|
IN INTERFACE_TYPE InterfaceType,
|
|
|
|
IN BUS_DATA_TYPE ConfigSpace,
|
|
|
|
IN ULONG BusNumber,
|
|
|
|
IN INTERFACE_TYPE ParentInterfaceType,
|
|
|
|
IN ULONG ParentBusNumber,
|
|
|
|
IN ULONG ContextSize,
|
|
|
|
IN PINSTALL_BUS_HANDLER InstallCallback,
|
|
|
|
OUT PBUS_HANDLER *BusHandler
|
|
|
|
);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
NTAPI
|
|
|
|
xHalSetWakeAlarm(
|
|
|
|
IN ULONGLONG AlartTime,
|
|
|
|
IN PTIME_FIELDS TimeFields
|
|
|
|
);
|
|
|
|
|
|
|
|
BOOLEAN
|
|
|
|
NTAPI
|
|
|
|
xHalTranslateBusAddress(
|
|
|
|
IN INTERFACE_TYPE InterfaceType,
|
|
|
|
IN ULONG BusNumber,
|
|
|
|
IN PHYSICAL_ADDRESS BusAddress,
|
|
|
|
IN OUT PULONG AddressSpace,
|
|
|
|
OUT PPHYSICAL_ADDRESS TranslatedAddress
|
|
|
|
);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
xHalAllocateMapRegisters(
|
|
|
|
IN PADAPTER_OBJECT AdapterObject,
|
|
|
|
IN ULONG Unknown,
|
|
|
|
IN ULONG Unknown2,
|
|
|
|
PMAP_REGISTER_ENTRY Registers
|
|
|
|
);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
xKdSetupPciDeviceForDebugging(
|
|
|
|
IN PVOID LoaderBlock OPTIONAL,
|
|
|
|
IN OUT PDEBUG_DEVICE_DESCRIPTOR PciDevice
|
|
|
|
);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
xKdReleasePciDeviceForDebugging(
|
|
|
|
IN OUT PDEBUG_DEVICE_DESCRIPTOR PciDevice
|
|
|
|
);
|
|
|
|
|
|
|
|
PVOID
|
|
|
|
NTAPI
|
|
|
|
xKdGetAcpiTablePhase(
|
|
|
|
IN struct _LOADER_PARAMETER_BLOCK *LoaderBlock,
|
|
|
|
IN ULONG Signature
|
|
|
|
);
|
|
|
|
|
|
|
|
PVOID
|
|
|
|
NTAPI
|
|
|
|
MatchAll(
|
|
|
|
IN PHYSICAL_ADDRESS PhysicalAddress,
|
|
|
|
IN ULONG NumberPages,
|
|
|
|
IN BOOLEAN FlushCurrentTLB
|
|
|
|
);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
NTAPI
|
|
|
|
xKdUnmapVirtualAddress(
|
|
|
|
IN PVOID VirtualAddress,
|
|
|
|
IN ULONG NumberPages,
|
|
|
|
IN BOOLEAN FlushCurrentTLB
|
|
|
|
);
|
2011-03-10 21:02:21 +00:00
|
|
|
|
- Stub out DbgKdWriteVirtualMemoryApi, DbgKdReadPhysicalMemoryApi, DbgKdWritePhysicalMemoryApi, DbgKdWriteBreakPointExApi, DbgKdRestoreBreakPointExApi, DbgKdSearchMemoryApi and DbgKdFillMemoryApi cases more properly.
- Fail on physical memory write like we do for read too.
- Don't handle OldVlm1/2 as they appear to be deprecated and unhandled in Windows.
- Implement HalHaltSystem to halt execution in a portable way. Default to xHalHaltSystem, a simple infinite loop, if we get called before HAL has initialized. Use this in KiBugCheckDebugBreak and the system shutdown handler instead of x86/AMD64/ARM intrinsics.
- Don't try to halt the CPU if KeBugCheck has been called 3 times or more -- if this happens, something has gone very wrong, and we shouldn't try to do anything special. Just loop infinitely.
- Fix KiBugCheckDebugBreak -- it shouldn't halt execution when called for the first chance as bugcheck callbacks have not been invoked at this point (nor has the BSOD been displayed). Use SEH to protect against a crash instead of checking KdDebuggerNotPresent as the debugger, if it is present, *could* disconnect while the trap is being handled. Also, don't halt execution if the debugger handled the breakpoint, just break again.
- Don't call MmMapIoSpace from HalpReboot! The reboot might take place at elevated IRQL (as high as HIGH_LEVEL if called from KeBugCheck), and thus can't use any Mm support routines. Use a PTE from the reserved HAL region and map it ourselves instead as done in the BIOS call code.
- Acquire the display ownership in HalReturnToFirmware in case the caller hasn't done so (as done in the KD reboot routine, for example).
- Just include ntndk.h in hal.h instead of including 6 NDK headers (which turns into more than half of the NDK anyway since those headers include other NDK headers).
- Crashing and rebooting from KD now works properly.
svn path=/trunk/; revision=43380
2009-10-11 20:16:45 +00:00
|
|
|
|
2006-11-08 11:47:44 +00:00
|
|
|
//
|
|
|
|
// Various offsets in the boot record
|
|
|
|
//
|
2020-12-07 11:43:34 +00:00
|
|
|
#define DISK_SIGNATURE_OFFSET 0x1B8
|
|
|
|
#define PARTITION_TABLE_OFFSET 0x1BE
|
2020-12-07 16:50:51 +00:00
|
|
|
#define BOOT_SIGNATURE_OFFSET (0x200 - 2)
|
2020-12-07 11:43:34 +00:00
|
|
|
|
2006-11-08 11:47:44 +00:00
|
|
|
#define BOOT_RECORD_SIGNATURE 0xAA55
|
|
|
|
#define NUM_PARTITION_TABLE_ENTRIES 4
|
|
|
|
|
|
|
|
//
|
|
|
|
// Helper Macros
|
|
|
|
//
|
|
|
|
#define GET_STARTING_SECTOR(p) \
|
|
|
|
((ULONG)(p->StartingSectorLsb0) + \
|
|
|
|
(ULONG)(p->StartingSectorLsb1 << 8 ) + \
|
|
|
|
(ULONG)(p->StartingSectorMsb0 << 16) + \
|
|
|
|
(ULONG)(p->StartingSectorMsb1 << 24))
|
|
|
|
|
|
|
|
#define GET_ENDING_S_OF_CHS(p) \
|
|
|
|
((UCHAR)(p->EndingCylinderLsb & 0x3F))
|
|
|
|
|
|
|
|
#define GET_PARTITION_LENGTH(p) \
|
|
|
|
((ULONG)(p->PartitionLengthLsb0) + \
|
|
|
|
(ULONG)(p->PartitionLengthLsb1 << 8) + \
|
|
|
|
(ULONG)(p->PartitionLengthMsb0 << 16) + \
|
|
|
|
(ULONG)(p->PartitionLengthMsb1 << 24))
|
|
|
|
|
2011-09-21 09:11:42 +00:00
|
|
|
#define SET_PARTITION_LENGTH(p, l) \
|
|
|
|
p->PartitionLengthLsb0 = l & 0xFF; \
|
|
|
|
p->PartitionLengthLsb1 = (l >> 8) & 0xFF; \
|
|
|
|
p->PartitionLengthMsb0 = (l >> 16) & 0xFF; \
|
|
|
|
p->PartitionLengthMsb1 = (l >> 24) & 0xFF
|
|
|
|
|
2006-11-08 11:47:44 +00:00
|
|
|
//
|
|
|
|
// Structure describing a partition
|
|
|
|
//
|
|
|
|
typedef struct _PARTITION_DESCRIPTOR
|
|
|
|
{
|
|
|
|
UCHAR ActiveFlag;
|
|
|
|
UCHAR StartingTrack;
|
|
|
|
UCHAR StartingCylinderLsb;
|
|
|
|
UCHAR StartingCylinderMsb;
|
|
|
|
UCHAR PartitionType;
|
|
|
|
UCHAR EndingTrack;
|
|
|
|
UCHAR EndingCylinderLsb;
|
|
|
|
UCHAR EndingCylinderMsb;
|
|
|
|
UCHAR StartingSectorLsb0;
|
|
|
|
UCHAR StartingSectorLsb1;
|
|
|
|
UCHAR StartingSectorMsb0;
|
|
|
|
UCHAR StartingSectorMsb1;
|
|
|
|
UCHAR PartitionLengthLsb0;
|
|
|
|
UCHAR PartitionLengthLsb1;
|
|
|
|
UCHAR PartitionLengthMsb0;
|
|
|
|
UCHAR PartitionLengthMsb1;
|
|
|
|
} PARTITION_DESCRIPTOR, *PPARTITION_DESCRIPTOR;
|
|
|
|
|
|
|
|
//
|
|
|
|
// Structure describing a boot sector
|
|
|
|
//
|
|
|
|
typedef struct _BOOT_SECTOR_INFO
|
|
|
|
{
|
|
|
|
UCHAR JumpByte[1];
|
|
|
|
UCHAR Ignore1[2];
|
|
|
|
UCHAR OemData[8];
|
|
|
|
UCHAR BytesPerSector[2];
|
|
|
|
UCHAR Ignore2[6];
|
|
|
|
UCHAR NumberOfSectors[2];
|
|
|
|
UCHAR MediaByte[1];
|
|
|
|
UCHAR Ignore3[2];
|
|
|
|
UCHAR SectorsPerTrack[2];
|
|
|
|
UCHAR NumberOfHeads[2];
|
|
|
|
} BOOT_SECTOR_INFO, *PBOOT_SECTOR_INFO;
|
|
|
|
|
|
|
|
//
|
|
|
|
// Partition Table and Disk Layout
|
|
|
|
//
|
|
|
|
typedef struct _PARTITION_TABLE
|
|
|
|
{
|
|
|
|
PARTITION_INFORMATION PartitionEntry[4];
|
|
|
|
} PARTITION_TABLE, *PPARTITION_TABLE;
|
|
|
|
|
|
|
|
typedef struct _DISK_LAYOUT
|
|
|
|
{
|
|
|
|
ULONG TableCount;
|
|
|
|
ULONG Signature;
|
|
|
|
PARTITION_TABLE PartitionTable[1];
|
|
|
|
} DISK_LAYOUT, *PDISK_LAYOUT;
|
|
|
|
|
|
|
|
//
|
|
|
|
// Partition Table Entry
|
|
|
|
//
|
|
|
|
typedef struct _PTE
|
|
|
|
{
|
|
|
|
UCHAR ActiveFlag;
|
|
|
|
UCHAR StartingTrack;
|
|
|
|
USHORT StartingCylinder;
|
|
|
|
UCHAR PartitionType;
|
|
|
|
UCHAR EndingTrack;
|
|
|
|
USHORT EndingCylinder;
|
|
|
|
ULONG StartingSector;
|
|
|
|
ULONG PartitionLength;
|
|
|
|
} PTE, *PPTE;
|