2001-08-21 20:18:27 +00:00
|
|
|
/*
|
|
|
|
* COPYRIGHT: See COPYING in the top level directory
|
|
|
|
* PROJECT: ReactOS kernel
|
2010-01-21 13:43:49 +00:00
|
|
|
* FILE: hal/halx86/mp/mpsirql.c
|
2001-08-21 20:18:27 +00:00
|
|
|
* PURPOSE: Implements IRQLs for multiprocessor systems
|
|
|
|
* PROGRAMMERS: David Welch (welch@cwcom.net)
|
|
|
|
* Casper S. Hornstrup (chorns@users.sourceforge.net)
|
|
|
|
* UPDATE HISTORY:
|
|
|
|
* 12/04/2001 CSH Created
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* INCLUDES *****************************************************************/
|
|
|
|
|
2005-06-18 14:28:28 +00:00
|
|
|
#include <hal.h>
|
2005-06-19 22:53:49 +00:00
|
|
|
#define NDEBUG
|
|
|
|
#include <debug.h>
|
2001-08-21 20:18:27 +00:00
|
|
|
|
2009-08-20 06:54:44 +00:00
|
|
|
/* GLOBALS ******************************************************************/
|
2001-08-21 20:18:27 +00:00
|
|
|
|
|
|
|
|
2003-04-06 10:45:16 +00:00
|
|
|
/* FUNCTIONS ****************************************************************/
|
2001-08-21 20:18:27 +00:00
|
|
|
|
2005-04-15 10:52:29 +00:00
|
|
|
#undef KeGetCurrentIrql
|
2008-11-29 23:16:39 +00:00
|
|
|
KIRQL NTAPI KeGetCurrentIrql (VOID)
|
2001-08-21 20:18:27 +00:00
|
|
|
/*
|
2003-04-06 10:45:16 +00:00
|
|
|
* PURPOSE: Returns the current irq level
|
|
|
|
* RETURNS: The current irq level
|
2001-08-21 20:18:27 +00:00
|
|
|
*/
|
|
|
|
{
|
2004-11-01 19:01:25 +00:00
|
|
|
KIRQL irql;
|
2009-09-18 20:56:49 +00:00
|
|
|
ULONG Flags;
|
2004-11-01 19:01:25 +00:00
|
|
|
|
2009-09-18 20:56:49 +00:00
|
|
|
Flags = __readeflags();
|
2006-11-17 04:18:41 +00:00
|
|
|
_disable();
|
2004-11-01 19:01:25 +00:00
|
|
|
|
2006-11-17 04:18:41 +00:00
|
|
|
irql = __readfsbyte(FIELD_OFFSET(KPCR, Irql));
|
2004-11-01 19:01:25 +00:00
|
|
|
if (irql > HIGH_LEVEL)
|
2003-04-06 10:45:16 +00:00
|
|
|
{
|
2004-11-01 19:01:25 +00:00
|
|
|
DPRINT1 ("CurrentIrql %x\n", irql);
|
2008-08-24 15:48:05 +00:00
|
|
|
ASSERT(FALSE);
|
2004-11-28 01:30:02 +00:00
|
|
|
}
|
2006-05-10 17:47:44 +00:00
|
|
|
if (Flags & EFLAGS_INTERRUPT_MASK)
|
2004-11-28 01:30:02 +00:00
|
|
|
{
|
2006-11-17 04:18:41 +00:00
|
|
|
_enable();
|
2003-04-06 10:45:16 +00:00
|
|
|
}
|
2004-11-01 19:01:25 +00:00
|
|
|
return irql;
|
2001-08-21 20:18:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2005-04-15 10:52:29 +00:00
|
|
|
#undef KeSetCurrentIrql
|
2004-11-01 19:01:25 +00:00
|
|
|
VOID KeSetCurrentIrql (KIRQL NewIrql)
|
2001-08-21 20:18:27 +00:00
|
|
|
/*
|
2003-04-06 10:45:16 +00:00
|
|
|
* PURPOSE: Sets the current irq level without taking any action
|
2001-08-21 20:18:27 +00:00
|
|
|
*/
|
|
|
|
{
|
2009-09-18 20:56:49 +00:00
|
|
|
ULONG Flags;
|
2003-04-06 10:45:16 +00:00
|
|
|
if (NewIrql > HIGH_LEVEL)
|
2004-11-28 01:30:02 +00:00
|
|
|
{
|
|
|
|
DPRINT1 ("NewIrql %x\n", NewIrql);
|
2008-08-24 15:48:05 +00:00
|
|
|
ASSERT(FALSE);
|
2004-11-28 01:30:02 +00:00
|
|
|
}
|
2009-09-18 20:56:49 +00:00
|
|
|
Flags = __readeflags();
|
2006-11-17 04:18:41 +00:00
|
|
|
_disable();
|
|
|
|
__writefsbyte(FIELD_OFFSET(KPCR, Irql), NewIrql);
|
2006-05-10 17:47:44 +00:00
|
|
|
if (Flags & EFLAGS_INTERRUPT_MASK)
|
2004-11-28 01:30:02 +00:00
|
|
|
{
|
2006-11-17 04:18:41 +00:00
|
|
|
_enable();
|
2004-11-28 01:30:02 +00:00
|
|
|
}
|
2003-04-06 10:45:16 +00:00
|
|
|
}
|
|
|
|
|
[HAL/NDK]
- Make Vector parameter in HalEnableSystemInterrupt, HalDisableSystemInterrupt and HalBeginSystemInterrupt an ULONG, not an UCHAR
[NDK]
- 64bit fixes for HANDLE_TABLE, KPROCESS, SECTION_IMAGE_INFORMATION, MMADDRESS_LIST, MMVAD_FLAGS, MMVAD, MMVAD_LONG, MMVAD_SHORT, MEMORY_DESCRIPTOR, MEMORY_ALLOCATION_DESCRIPTOR, LdrVerifyMappedImageMatchesChecksum
- KDPC_DATA::DpcQueueDepth is signed on amd64, unsigned on x86
[NTOSKRNL]
- Fix hundreds of MSVC and amd64 warnings
- add a pragma message to FstubFixupEfiPartition, since it looks broken
- Move portable Ke constants from <arch>/cpu.c to krnlinit.c
- Fixed a bug in amd64 KiGeneralProtectionFaultHandler
svn path=/trunk/; revision=53734
2011-09-18 13:11:45 +00:00
|
|
|
VOID
|
2006-01-08 06:30:00 +00:00
|
|
|
HalpLowerIrql(KIRQL NewIrql, BOOLEAN FromHalEndSystemInterrupt)
|
2003-04-06 10:45:16 +00:00
|
|
|
{
|
2009-09-18 20:56:49 +00:00
|
|
|
ULONG Flags;
|
2005-11-22 00:34:46 +00:00
|
|
|
UCHAR DpcRequested;
|
2003-04-06 10:45:16 +00:00
|
|
|
if (NewIrql >= DISPATCH_LEVEL)
|
|
|
|
{
|
|
|
|
KeSetCurrentIrql (NewIrql);
|
2004-11-01 19:01:25 +00:00
|
|
|
APICWrite(APIC_TPR, IRQL2TPR (NewIrql) & APIC_TPR_PRI);
|
2003-04-06 10:45:16 +00:00
|
|
|
return;
|
|
|
|
}
|
2009-09-18 20:56:49 +00:00
|
|
|
Flags = __readeflags();
|
2004-11-01 19:01:25 +00:00
|
|
|
if (KeGetCurrentIrql() > APC_LEVEL)
|
2003-04-06 10:45:16 +00:00
|
|
|
{
|
2004-11-28 01:30:02 +00:00
|
|
|
KeSetCurrentIrql (DISPATCH_LEVEL);
|
|
|
|
APICWrite(APIC_TPR, IRQL2TPR (DISPATCH_LEVEL) & APIC_TPR_PRI);
|
2006-11-17 04:18:41 +00:00
|
|
|
DpcRequested = __readfsbyte(FIELD_OFFSET(KIPCR, HalReserved[HAL_DPC_REQUEST]));
|
2005-11-22 00:34:46 +00:00
|
|
|
if (FromHalEndSystemInterrupt || DpcRequested)
|
2004-11-28 01:30:02 +00:00
|
|
|
{
|
2006-11-17 04:18:41 +00:00
|
|
|
__writefsbyte(FIELD_OFFSET(KIPCR, HalReserved[HAL_DPC_REQUEST]), 0);
|
|
|
|
_enable();
|
2004-11-28 01:30:02 +00:00
|
|
|
KiDispatchInterrupt();
|
2006-05-10 17:47:44 +00:00
|
|
|
if (!(Flags & EFLAGS_INTERRUPT_MASK))
|
2004-11-28 01:30:02 +00:00
|
|
|
{
|
2006-11-17 04:18:41 +00:00
|
|
|
_disable();
|
2004-11-28 01:30:02 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
KeSetCurrentIrql (APC_LEVEL);
|
2003-04-06 10:45:16 +00:00
|
|
|
}
|
|
|
|
if (NewIrql == APC_LEVEL)
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
[HAL/NDK]
- Make Vector parameter in HalEnableSystemInterrupt, HalDisableSystemInterrupt and HalBeginSystemInterrupt an ULONG, not an UCHAR
[NDK]
- 64bit fixes for HANDLE_TABLE, KPROCESS, SECTION_IMAGE_INFORMATION, MMADDRESS_LIST, MMVAD_FLAGS, MMVAD, MMVAD_LONG, MMVAD_SHORT, MEMORY_DESCRIPTOR, MEMORY_ALLOCATION_DESCRIPTOR, LdrVerifyMappedImageMatchesChecksum
- KDPC_DATA::DpcQueueDepth is signed on amd64, unsigned on x86
[NTOSKRNL]
- Fix hundreds of MSVC and amd64 warnings
- add a pragma message to FstubFixupEfiPartition, since it looks broken
- Move portable Ke constants from <arch>/cpu.c to krnlinit.c
- Fixed a bug in amd64 KiGeneralProtectionFaultHandler
svn path=/trunk/; revision=53734
2011-09-18 13:11:45 +00:00
|
|
|
if (KeGetCurrentThread () != NULL &&
|
2003-04-06 10:45:16 +00:00
|
|
|
KeGetCurrentThread ()->ApcState.KernelApcPending)
|
|
|
|
{
|
2006-11-17 04:18:41 +00:00
|
|
|
_enable();
|
2004-11-28 01:30:02 +00:00
|
|
|
KiDeliverApc(KernelMode, NULL, NULL);
|
2006-05-10 17:47:44 +00:00
|
|
|
if (!(Flags & EFLAGS_INTERRUPT_MASK))
|
2004-11-28 01:30:02 +00:00
|
|
|
{
|
2006-11-17 04:18:41 +00:00
|
|
|
_disable();
|
2004-11-28 01:30:02 +00:00
|
|
|
}
|
2003-04-06 10:45:16 +00:00
|
|
|
}
|
|
|
|
KeSetCurrentIrql (PASSIVE_LEVEL);
|
2001-08-21 20:18:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**********************************************************************
|
|
|
|
* NAME EXPORTED
|
|
|
|
* KfLowerIrql
|
|
|
|
*
|
|
|
|
* DESCRIPTION
|
|
|
|
* Restores the irq level on the current processor
|
|
|
|
*
|
|
|
|
* ARGUMENTS
|
|
|
|
* NewIrql = Irql to lower to
|
|
|
|
*
|
|
|
|
* RETURN VALUE
|
|
|
|
* None
|
|
|
|
*
|
|
|
|
* NOTES
|
|
|
|
* Uses fastcall convention
|
|
|
|
*/
|
|
|
|
VOID FASTCALL
|
2003-04-06 10:45:16 +00:00
|
|
|
KfLowerIrql (KIRQL NewIrql)
|
2001-08-21 20:18:27 +00:00
|
|
|
{
|
2004-11-01 19:01:25 +00:00
|
|
|
KIRQL oldIrql = KeGetCurrentIrql();
|
|
|
|
if (NewIrql > oldIrql)
|
2001-08-21 20:18:27 +00:00
|
|
|
{
|
2004-11-01 19:01:25 +00:00
|
|
|
DPRINT1 ("NewIrql %x CurrentIrql %x\n", NewIrql, oldIrql);
|
2008-08-24 15:48:05 +00:00
|
|
|
ASSERT(FALSE);
|
2001-08-21 20:18:27 +00:00
|
|
|
}
|
2004-11-28 01:30:02 +00:00
|
|
|
HalpLowerIrql (NewIrql, FALSE);
|
2001-08-21 20:18:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**********************************************************************
|
|
|
|
* NAME EXPORTED
|
|
|
|
* KfRaiseIrql
|
|
|
|
*
|
|
|
|
* DESCRIPTION
|
|
|
|
* Raises the hardware priority (irql)
|
|
|
|
*
|
|
|
|
* ARGUMENTS
|
|
|
|
* NewIrql = Irql to raise to
|
|
|
|
*
|
|
|
|
* RETURN VALUE
|
|
|
|
* previous irq level
|
|
|
|
*
|
|
|
|
* NOTES
|
|
|
|
* Uses fastcall convention
|
|
|
|
*/
|
|
|
|
|
2003-04-06 10:45:16 +00:00
|
|
|
KIRQL FASTCALL
|
|
|
|
KfRaiseIrql (KIRQL NewIrql)
|
2001-08-21 20:18:27 +00:00
|
|
|
{
|
|
|
|
KIRQL OldIrql;
|
2009-09-18 20:56:49 +00:00
|
|
|
ULONG Flags;
|
[HAL/NDK]
- Make Vector parameter in HalEnableSystemInterrupt, HalDisableSystemInterrupt and HalBeginSystemInterrupt an ULONG, not an UCHAR
[NDK]
- 64bit fixes for HANDLE_TABLE, KPROCESS, SECTION_IMAGE_INFORMATION, MMADDRESS_LIST, MMVAD_FLAGS, MMVAD, MMVAD_LONG, MMVAD_SHORT, MEMORY_DESCRIPTOR, MEMORY_ALLOCATION_DESCRIPTOR, LdrVerifyMappedImageMatchesChecksum
- KDPC_DATA::DpcQueueDepth is signed on amd64, unsigned on x86
[NTOSKRNL]
- Fix hundreds of MSVC and amd64 warnings
- add a pragma message to FstubFixupEfiPartition, since it looks broken
- Move portable Ke constants from <arch>/cpu.c to krnlinit.c
- Fixed a bug in amd64 KiGeneralProtectionFaultHandler
svn path=/trunk/; revision=53734
2011-09-18 13:11:45 +00:00
|
|
|
|
2009-09-18 20:56:49 +00:00
|
|
|
Flags = __readeflags();
|
2006-11-17 04:18:41 +00:00
|
|
|
_disable();
|
2004-11-28 01:30:02 +00:00
|
|
|
|
|
|
|
OldIrql = KeGetCurrentIrql ();
|
|
|
|
|
|
|
|
if (NewIrql < OldIrql)
|
2003-04-06 10:45:16 +00:00
|
|
|
{
|
|
|
|
DPRINT1 ("CurrentIrql %x NewIrql %x\n", KeGetCurrentIrql (), NewIrql);
|
2008-08-24 15:48:05 +00:00
|
|
|
ASSERT(FALSE);
|
2003-04-06 10:45:16 +00:00
|
|
|
}
|
2004-11-28 01:30:02 +00:00
|
|
|
|
|
|
|
|
2004-11-01 19:01:25 +00:00
|
|
|
if (NewIrql > DISPATCH_LEVEL)
|
|
|
|
{
|
2004-11-28 01:30:02 +00:00
|
|
|
APICWrite (APIC_TPR, IRQL2TPR(NewIrql) & APIC_TPR_PRI);
|
2004-11-01 19:01:25 +00:00
|
|
|
}
|
2003-04-06 10:45:16 +00:00
|
|
|
KeSetCurrentIrql (NewIrql);
|
2006-05-10 17:47:44 +00:00
|
|
|
if (Flags & EFLAGS_INTERRUPT_MASK)
|
2004-11-28 01:30:02 +00:00
|
|
|
{
|
2006-11-17 04:18:41 +00:00
|
|
|
_enable();
|
2004-11-28 01:30:02 +00:00
|
|
|
}
|
|
|
|
|
2003-04-06 10:45:16 +00:00
|
|
|
return OldIrql;
|
2001-08-21 20:18:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**********************************************************************
|
|
|
|
* NAME EXPORTED
|
|
|
|
* KeRaiseIrqlToDpcLevel
|
|
|
|
*
|
|
|
|
* DESCRIPTION
|
|
|
|
* Raises the hardware priority (irql) to DISPATCH level
|
|
|
|
*
|
|
|
|
* ARGUMENTS
|
|
|
|
* None
|
|
|
|
*
|
|
|
|
* RETURN VALUE
|
|
|
|
* Previous irq level
|
|
|
|
*
|
|
|
|
* NOTES
|
|
|
|
* Calls KfRaiseIrql
|
|
|
|
*/
|
|
|
|
|
2008-11-29 23:16:39 +00:00
|
|
|
KIRQL NTAPI
|
2001-08-21 20:18:27 +00:00
|
|
|
KeRaiseIrqlToDpcLevel (VOID)
|
|
|
|
{
|
2003-04-06 10:45:16 +00:00
|
|
|
return KfRaiseIrql (DISPATCH_LEVEL);
|
2001-08-21 20:18:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**********************************************************************
|
|
|
|
* NAME EXPORTED
|
|
|
|
* KeRaiseIrqlToSynchLevel
|
|
|
|
*
|
|
|
|
* DESCRIPTION
|
|
|
|
* Raises the hardware priority (irql) to CLOCK2 level
|
|
|
|
*
|
|
|
|
* ARGUMENTS
|
|
|
|
* None
|
|
|
|
*
|
|
|
|
* RETURN VALUE
|
|
|
|
* Previous irq level
|
|
|
|
*
|
|
|
|
* NOTES
|
|
|
|
* Calls KfRaiseIrql
|
|
|
|
*/
|
|
|
|
|
2008-11-29 23:16:39 +00:00
|
|
|
KIRQL NTAPI
|
2001-08-21 20:18:27 +00:00
|
|
|
KeRaiseIrqlToSynchLevel (VOID)
|
|
|
|
{
|
2003-04-06 10:45:16 +00:00
|
|
|
return KfRaiseIrql (CLOCK2_LEVEL);
|
2001-08-21 20:18:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-11-29 23:16:39 +00:00
|
|
|
BOOLEAN NTAPI
|
2006-05-27 15:38:37 +00:00
|
|
|
HalBeginSystemInterrupt (KIRQL Irql,
|
[HAL/NDK]
- Make Vector parameter in HalEnableSystemInterrupt, HalDisableSystemInterrupt and HalBeginSystemInterrupt an ULONG, not an UCHAR
[NDK]
- 64bit fixes for HANDLE_TABLE, KPROCESS, SECTION_IMAGE_INFORMATION, MMADDRESS_LIST, MMVAD_FLAGS, MMVAD, MMVAD_LONG, MMVAD_SHORT, MEMORY_DESCRIPTOR, MEMORY_ALLOCATION_DESCRIPTOR, LdrVerifyMappedImageMatchesChecksum
- KDPC_DATA::DpcQueueDepth is signed on amd64, unsigned on x86
[NTOSKRNL]
- Fix hundreds of MSVC and amd64 warnings
- add a pragma message to FstubFixupEfiPartition, since it looks broken
- Move portable Ke constants from <arch>/cpu.c to krnlinit.c
- Fixed a bug in amd64 KiGeneralProtectionFaultHandler
svn path=/trunk/; revision=53734
2011-09-18 13:11:45 +00:00
|
|
|
ULONG Vector,
|
2004-11-01 19:01:25 +00:00
|
|
|
PKIRQL OldIrql)
|
2001-08-21 20:18:27 +00:00
|
|
|
{
|
2009-09-18 20:56:49 +00:00
|
|
|
ULONG Flags;
|
2003-04-06 10:45:16 +00:00
|
|
|
DPRINT("Vector (0x%X) Irql (0x%X)\n", Vector, Irql);
|
[HAL/NDK]
- Make Vector parameter in HalEnableSystemInterrupt, HalDisableSystemInterrupt and HalBeginSystemInterrupt an ULONG, not an UCHAR
[NDK]
- 64bit fixes for HANDLE_TABLE, KPROCESS, SECTION_IMAGE_INFORMATION, MMADDRESS_LIST, MMVAD_FLAGS, MMVAD, MMVAD_LONG, MMVAD_SHORT, MEMORY_DESCRIPTOR, MEMORY_ALLOCATION_DESCRIPTOR, LdrVerifyMappedImageMatchesChecksum
- KDPC_DATA::DpcQueueDepth is signed on amd64, unsigned on x86
[NTOSKRNL]
- Fix hundreds of MSVC and amd64 warnings
- add a pragma message to FstubFixupEfiPartition, since it looks broken
- Move portable Ke constants from <arch>/cpu.c to krnlinit.c
- Fixed a bug in amd64 KiGeneralProtectionFaultHandler
svn path=/trunk/; revision=53734
2011-09-18 13:11:45 +00:00
|
|
|
|
2004-11-01 19:01:25 +00:00
|
|
|
if (KeGetCurrentIrql () >= Irql)
|
|
|
|
{
|
2004-11-28 01:30:02 +00:00
|
|
|
DPRINT1("current irql %d, new irql %d\n", KeGetCurrentIrql(), Irql);
|
2008-08-24 15:48:05 +00:00
|
|
|
ASSERT(FALSE);
|
2001-08-21 20:18:27 +00:00
|
|
|
}
|
|
|
|
|
2009-09-18 20:56:49 +00:00
|
|
|
Flags = __readeflags();
|
2006-05-10 17:47:44 +00:00
|
|
|
if (Flags & EFLAGS_INTERRUPT_MASK)
|
2004-11-28 01:30:02 +00:00
|
|
|
{
|
|
|
|
DPRINT1("HalBeginSystemInterrupt was called with interrupt's enabled\n");
|
2008-08-24 15:48:05 +00:00
|
|
|
ASSERT(FALSE);
|
2004-11-28 01:30:02 +00:00
|
|
|
}
|
2004-11-01 19:01:25 +00:00
|
|
|
APICWrite (APIC_TPR, IRQL2TPR (Irql) & APIC_TPR_PRI);
|
2003-04-06 10:45:16 +00:00
|
|
|
*OldIrql = KeGetCurrentIrql ();
|
|
|
|
KeSetCurrentIrql (Irql);
|
|
|
|
return(TRUE);
|
2001-08-21 20:18:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-11-29 23:16:39 +00:00
|
|
|
VOID NTAPI
|
2003-04-06 10:45:16 +00:00
|
|
|
HalEndSystemInterrupt (KIRQL Irql,
|
2010-01-29 22:08:09 +00:00
|
|
|
IN PKTRAP_FRAME TrapFrame)
|
2003-04-06 10:45:16 +00:00
|
|
|
/*
|
|
|
|
* FUNCTION: Finish a system interrupt and restore the specified irq level.
|
|
|
|
*/
|
2001-08-21 20:18:27 +00:00
|
|
|
{
|
2009-09-18 20:56:49 +00:00
|
|
|
ULONG Flags;
|
|
|
|
Flags = __readeflags();
|
2004-11-28 01:30:02 +00:00
|
|
|
|
2006-05-10 17:47:44 +00:00
|
|
|
if (Flags & EFLAGS_INTERRUPT_MASK)
|
2004-11-28 01:30:02 +00:00
|
|
|
{
|
|
|
|
DPRINT1("HalEndSystemInterrupt was called with interrupt's enabled\n");
|
2008-08-24 15:48:05 +00:00
|
|
|
ASSERT(FALSE);
|
2004-11-28 01:30:02 +00:00
|
|
|
}
|
|
|
|
APICSendEOI();
|
|
|
|
HalpLowerIrql (Irql, TRUE);
|
2001-08-21 20:18:27 +00:00
|
|
|
}
|
[HAL/NDK]
- Make Vector parameter in HalEnableSystemInterrupt, HalDisableSystemInterrupt and HalBeginSystemInterrupt an ULONG, not an UCHAR
[NDK]
- 64bit fixes for HANDLE_TABLE, KPROCESS, SECTION_IMAGE_INFORMATION, MMADDRESS_LIST, MMVAD_FLAGS, MMVAD, MMVAD_LONG, MMVAD_SHORT, MEMORY_DESCRIPTOR, MEMORY_ALLOCATION_DESCRIPTOR, LdrVerifyMappedImageMatchesChecksum
- KDPC_DATA::DpcQueueDepth is signed on amd64, unsigned on x86
[NTOSKRNL]
- Fix hundreds of MSVC and amd64 warnings
- add a pragma message to FstubFixupEfiPartition, since it looks broken
- Move portable Ke constants from <arch>/cpu.c to krnlinit.c
- Fixed a bug in amd64 KiGeneralProtectionFaultHandler
svn path=/trunk/; revision=53734
2011-09-18 13:11:45 +00:00
|
|
|
|
2009-11-10 23:00:51 +00:00
|
|
|
VOID
|
|
|
|
NTAPI
|
[HAL/NDK]
- Make Vector parameter in HalEnableSystemInterrupt, HalDisableSystemInterrupt and HalBeginSystemInterrupt an ULONG, not an UCHAR
[NDK]
- 64bit fixes for HANDLE_TABLE, KPROCESS, SECTION_IMAGE_INFORMATION, MMADDRESS_LIST, MMVAD_FLAGS, MMVAD, MMVAD_LONG, MMVAD_SHORT, MEMORY_DESCRIPTOR, MEMORY_ALLOCATION_DESCRIPTOR, LdrVerifyMappedImageMatchesChecksum
- KDPC_DATA::DpcQueueDepth is signed on amd64, unsigned on x86
[NTOSKRNL]
- Fix hundreds of MSVC and amd64 warnings
- add a pragma message to FstubFixupEfiPartition, since it looks broken
- Move portable Ke constants from <arch>/cpu.c to krnlinit.c
- Fixed a bug in amd64 KiGeneralProtectionFaultHandler
svn path=/trunk/; revision=53734
2011-09-18 13:11:45 +00:00
|
|
|
HalDisableSystemInterrupt(ULONG Vector,
|
2010-01-23 21:57:15 +00:00
|
|
|
KIRQL Irql)
|
2001-08-21 20:18:27 +00:00
|
|
|
{
|
|
|
|
ULONG irq;
|
|
|
|
|
2003-04-06 10:45:16 +00:00
|
|
|
DPRINT ("Vector (0x%X)\n", Vector);
|
2001-08-21 20:18:27 +00:00
|
|
|
|
|
|
|
if (Vector < FIRST_DEVICE_VECTOR ||
|
[HAL/NDK]
- Make Vector parameter in HalEnableSystemInterrupt, HalDisableSystemInterrupt and HalBeginSystemInterrupt an ULONG, not an UCHAR
[NDK]
- 64bit fixes for HANDLE_TABLE, KPROCESS, SECTION_IMAGE_INFORMATION, MMADDRESS_LIST, MMVAD_FLAGS, MMVAD, MMVAD_LONG, MMVAD_SHORT, MEMORY_DESCRIPTOR, MEMORY_ALLOCATION_DESCRIPTOR, LdrVerifyMappedImageMatchesChecksum
- KDPC_DATA::DpcQueueDepth is signed on amd64, unsigned on x86
[NTOSKRNL]
- Fix hundreds of MSVC and amd64 warnings
- add a pragma message to FstubFixupEfiPartition, since it looks broken
- Move portable Ke constants from <arch>/cpu.c to krnlinit.c
- Fixed a bug in amd64 KiGeneralProtectionFaultHandler
svn path=/trunk/; revision=53734
2011-09-18 13:11:45 +00:00
|
|
|
Vector >= FIRST_DEVICE_VECTOR + NUMBER_DEVICE_VECTORS)
|
2004-11-01 19:01:25 +00:00
|
|
|
{
|
|
|
|
DPRINT1("Not a device interrupt, vector=%x\n", Vector);
|
2009-11-10 23:00:51 +00:00
|
|
|
ASSERT(FALSE);
|
|
|
|
return;
|
2001-08-21 20:18:27 +00:00
|
|
|
}
|
|
|
|
|
2003-04-06 10:45:16 +00:00
|
|
|
irq = VECTOR2IRQ (Vector);
|
2004-11-01 19:01:25 +00:00
|
|
|
IOAPICMaskIrq (irq);
|
2001-08-21 20:18:27 +00:00
|
|
|
|
[HAL/NDK]
- Make Vector parameter in HalEnableSystemInterrupt, HalDisableSystemInterrupt and HalBeginSystemInterrupt an ULONG, not an UCHAR
[NDK]
- 64bit fixes for HANDLE_TABLE, KPROCESS, SECTION_IMAGE_INFORMATION, MMADDRESS_LIST, MMVAD_FLAGS, MMVAD, MMVAD_LONG, MMVAD_SHORT, MEMORY_DESCRIPTOR, MEMORY_ALLOCATION_DESCRIPTOR, LdrVerifyMappedImageMatchesChecksum
- KDPC_DATA::DpcQueueDepth is signed on amd64, unsigned on x86
[NTOSKRNL]
- Fix hundreds of MSVC and amd64 warnings
- add a pragma message to FstubFixupEfiPartition, since it looks broken
- Move portable Ke constants from <arch>/cpu.c to krnlinit.c
- Fixed a bug in amd64 KiGeneralProtectionFaultHandler
svn path=/trunk/; revision=53734
2011-09-18 13:11:45 +00:00
|
|
|
return;
|
2001-08-21 20:18:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-11-29 23:16:39 +00:00
|
|
|
BOOLEAN NTAPI
|
[HAL/NDK]
- Make Vector parameter in HalEnableSystemInterrupt, HalDisableSystemInterrupt and HalBeginSystemInterrupt an ULONG, not an UCHAR
[NDK]
- 64bit fixes for HANDLE_TABLE, KPROCESS, SECTION_IMAGE_INFORMATION, MMADDRESS_LIST, MMVAD_FLAGS, MMVAD, MMVAD_LONG, MMVAD_SHORT, MEMORY_DESCRIPTOR, MEMORY_ALLOCATION_DESCRIPTOR, LdrVerifyMappedImageMatchesChecksum
- KDPC_DATA::DpcQueueDepth is signed on amd64, unsigned on x86
[NTOSKRNL]
- Fix hundreds of MSVC and amd64 warnings
- add a pragma message to FstubFixupEfiPartition, since it looks broken
- Move portable Ke constants from <arch>/cpu.c to krnlinit.c
- Fixed a bug in amd64 KiGeneralProtectionFaultHandler
svn path=/trunk/; revision=53734
2011-09-18 13:11:45 +00:00
|
|
|
HalEnableSystemInterrupt (ULONG Vector,
|
2004-11-01 19:01:25 +00:00
|
|
|
KIRQL Irql,
|
|
|
|
KINTERRUPT_MODE InterruptMode)
|
2001-08-21 20:18:27 +00:00
|
|
|
{
|
|
|
|
ULONG irq;
|
|
|
|
|
|
|
|
if (Vector < FIRST_DEVICE_VECTOR ||
|
[HAL/NDK]
- Make Vector parameter in HalEnableSystemInterrupt, HalDisableSystemInterrupt and HalBeginSystemInterrupt an ULONG, not an UCHAR
[NDK]
- 64bit fixes for HANDLE_TABLE, KPROCESS, SECTION_IMAGE_INFORMATION, MMADDRESS_LIST, MMVAD_FLAGS, MMVAD, MMVAD_LONG, MMVAD_SHORT, MEMORY_DESCRIPTOR, MEMORY_ALLOCATION_DESCRIPTOR, LdrVerifyMappedImageMatchesChecksum
- KDPC_DATA::DpcQueueDepth is signed on amd64, unsigned on x86
[NTOSKRNL]
- Fix hundreds of MSVC and amd64 warnings
- add a pragma message to FstubFixupEfiPartition, since it looks broken
- Move portable Ke constants from <arch>/cpu.c to krnlinit.c
- Fixed a bug in amd64 KiGeneralProtectionFaultHandler
svn path=/trunk/; revision=53734
2011-09-18 13:11:45 +00:00
|
|
|
Vector >= FIRST_DEVICE_VECTOR + NUMBER_DEVICE_VECTORS)
|
2004-11-01 19:01:25 +00:00
|
|
|
{
|
2001-08-21 20:18:27 +00:00
|
|
|
DPRINT("Not a device interrupt\n");
|
2004-11-01 19:01:25 +00:00
|
|
|
return FALSE;
|
2001-08-21 20:18:27 +00:00
|
|
|
}
|
|
|
|
|
2005-01-01 11:31:43 +00:00
|
|
|
/* FIXME: We must check if the requested and the assigned interrupt mode is the same */
|
|
|
|
|
2003-04-06 10:45:16 +00:00
|
|
|
irq = VECTOR2IRQ (Vector);
|
2004-11-01 19:01:25 +00:00
|
|
|
IOAPICUnmaskIrq (irq);
|
2001-08-21 20:18:27 +00:00
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
2004-07-10 21:58:35 +00:00
|
|
|
|
|
|
|
VOID FASTCALL
|
2004-11-01 19:01:25 +00:00
|
|
|
HalRequestSoftwareInterrupt(IN KIRQL Request)
|
2004-07-10 21:58:35 +00:00
|
|
|
{
|
|
|
|
switch (Request)
|
|
|
|
{
|
|
|
|
case APC_LEVEL:
|
2006-11-17 04:18:41 +00:00
|
|
|
__writefsbyte(FIELD_OFFSET(KIPCR, HalReserved[HAL_APC_REQUEST]), 1);
|
2004-07-10 21:58:35 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case DISPATCH_LEVEL:
|
2006-11-17 04:18:41 +00:00
|
|
|
__writefsbyte(FIELD_OFFSET(KIPCR, HalReserved[HAL_DPC_REQUEST]), 1);
|
2004-07-10 21:58:35 +00:00
|
|
|
break;
|
[HAL/NDK]
- Make Vector parameter in HalEnableSystemInterrupt, HalDisableSystemInterrupt and HalBeginSystemInterrupt an ULONG, not an UCHAR
[NDK]
- 64bit fixes for HANDLE_TABLE, KPROCESS, SECTION_IMAGE_INFORMATION, MMADDRESS_LIST, MMVAD_FLAGS, MMVAD, MMVAD_LONG, MMVAD_SHORT, MEMORY_DESCRIPTOR, MEMORY_ALLOCATION_DESCRIPTOR, LdrVerifyMappedImageMatchesChecksum
- KDPC_DATA::DpcQueueDepth is signed on amd64, unsigned on x86
[NTOSKRNL]
- Fix hundreds of MSVC and amd64 warnings
- add a pragma message to FstubFixupEfiPartition, since it looks broken
- Move portable Ke constants from <arch>/cpu.c to krnlinit.c
- Fixed a bug in amd64 KiGeneralProtectionFaultHandler
svn path=/trunk/; revision=53734
2011-09-18 13:11:45 +00:00
|
|
|
|
2004-07-10 21:58:35 +00:00
|
|
|
default:
|
2008-08-24 15:48:05 +00:00
|
|
|
ASSERT(FALSE);
|
2004-07-10 21:58:35 +00:00
|
|
|
}
|
|
|
|
}
|
2006-09-11 14:35:46 +00:00
|
|
|
|
|
|
|
VOID FASTCALL
|
|
|
|
HalClearSoftwareInterrupt(
|
|
|
|
IN KIRQL Request)
|
|
|
|
{
|
|
|
|
UNIMPLEMENTED;
|
|
|
|
}
|