mirror of
https://github.com/reactos/reactos.git
synced 2024-12-28 10:04:49 +00:00
services/fs/cdfs/.cvsignore: Added .cvsignore file
ntoskrnl/ex/fmutex.c: ExAcquireFastMutex: Added an check for recursively acquiring a FAST_MUTEX. ntoskrnl/include/internal/mm.h: ADDRESS_SPACE: Changed lock from a KMUTEX to a FAST_MUTEX. ntoskrnl/mm/aspace: MmLockAddressSpace, MmUnlockAddressSpace, MmInitializeAddressSpace: Changed lock from a KMUTEX to a FAST_MUTEX ntoskrnl/mm/mdl.c: MmInitializeMdlImplementation, MmMapLockedPages, MmUnmapLockedPages: Use a special region that doesn't need the address space lock for mapping MDLs. ntoskrnl/mm/mminit.c: MmInit2: Call MDL initialization routine. ntoskrnl/mm/section.c: MmMapViewOfSegment: Changed to a static function, don't lock the address space since it is done by the caller. ntoskrnl/ps/thread.c: PsDumpThreads: Fixed garbage prints in stack dump. svn path=/trunk/; revision=2968
This commit is contained in:
parent
aec0b9bcfc
commit
daad760238
8 changed files with 169 additions and 94 deletions
6
reactos/drivers/fs/cdfs/.cvsignore
Normal file
6
reactos/drivers/fs/cdfs/.cvsignore
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
base.tmp
|
||||||
|
junk.tmp
|
||||||
|
temp.exp
|
||||||
|
cdfs.coff
|
||||||
|
cdfs.sys.unstripped
|
||||||
|
*.d
|
|
@ -16,7 +16,7 @@
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, write to the Free Software
|
||||||
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||||
*/
|
*/
|
||||||
/* $Id: fmutex.c,v 1.12 2001/12/27 23:56:42 dwelch Exp $
|
/* $Id: fmutex.c,v 1.13 2002/05/17 23:01:56 dwelch Exp $
|
||||||
*
|
*
|
||||||
* PROJECT: ReactOS kernel
|
* PROJECT: ReactOS kernel
|
||||||
* FILE: ntoskrnl/ex/fmutex.c
|
* FILE: ntoskrnl/ex/fmutex.c
|
||||||
|
@ -33,12 +33,12 @@
|
||||||
|
|
||||||
#include <internal/debug.h>
|
#include <internal/debug.h>
|
||||||
|
|
||||||
|
|
||||||
/* FUNCTIONS *****************************************************************/
|
/* FUNCTIONS *****************************************************************/
|
||||||
|
|
||||||
VOID FASTCALL
|
VOID FASTCALL
|
||||||
ExAcquireFastMutexUnsafe(PFAST_MUTEX FastMutex)
|
ExAcquireFastMutexUnsafe(PFAST_MUTEX FastMutex)
|
||||||
{
|
{
|
||||||
|
assert(FastMutex->Owner != KeGetCurrentThread());
|
||||||
InterlockedIncrement(&FastMutex->Contention);
|
InterlockedIncrement(&FastMutex->Contention);
|
||||||
while (InterlockedExchange(&FastMutex->Count, 0) == 0)
|
while (InterlockedExchange(&FastMutex->Count, 0) == 0)
|
||||||
{
|
{
|
||||||
|
|
|
@ -146,7 +146,7 @@ typedef struct
|
||||||
typedef struct _MADDRESS_SPACE
|
typedef struct _MADDRESS_SPACE
|
||||||
{
|
{
|
||||||
LIST_ENTRY MAreaListHead;
|
LIST_ENTRY MAreaListHead;
|
||||||
KMUTEX Lock;
|
FAST_MUTEX Lock;
|
||||||
ULONG LowestAddress;
|
ULONG LowestAddress;
|
||||||
struct _EPROCESS* Process;
|
struct _EPROCESS* Process;
|
||||||
PUSHORT PageTableRefCountTable;
|
PUSHORT PageTableRefCountTable;
|
||||||
|
@ -509,5 +509,7 @@ BOOLEAN MmIsPageSwapEntry(PEPROCESS Process, PVOID Address);
|
||||||
VOID
|
VOID
|
||||||
MmTransferOwnershipPage(PVOID PhysicalAddress, ULONG NewConsumer);
|
MmTransferOwnershipPage(PVOID PhysicalAddress, ULONG NewConsumer);
|
||||||
VOID MmSetDirtyPage(PEPROCESS Process, PVOID Address);
|
VOID MmSetDirtyPage(PEPROCESS Process, PVOID Address);
|
||||||
|
VOID
|
||||||
|
MmInitializeMdlImplementation(VOID);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* $Id: aspace.c,v 1.10 2002/05/14 21:19:18 dwelch Exp $
|
/* $Id: aspace.c,v 1.11 2002/05/17 23:01:56 dwelch Exp $
|
||||||
*
|
*
|
||||||
* COPYRIGHT: See COPYING in the top level directory
|
* COPYRIGHT: See COPYING in the top level directory
|
||||||
* PROJECT: ReactOS kernel
|
* PROJECT: ReactOS kernel
|
||||||
|
@ -36,11 +36,7 @@ MmLockAddressSpace(PMADDRESS_SPACE AddressSpace)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
(VOID)KeWaitForMutexObject(&AddressSpace->Lock,
|
ExAcquireFastMutex(&AddressSpace->Lock);
|
||||||
0,
|
|
||||||
KernelMode,
|
|
||||||
FALSE,
|
|
||||||
NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
VOID
|
VOID
|
||||||
|
@ -53,7 +49,7 @@ MmUnlockAddressSpace(PMADDRESS_SPACE AddressSpace)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
KeReleaseMutex(&AddressSpace->Lock, FALSE);
|
ExReleaseFastMutex(&AddressSpace->Lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
VOID
|
VOID
|
||||||
|
@ -77,7 +73,7 @@ MmInitializeAddressSpace(PEPROCESS Process,
|
||||||
PMADDRESS_SPACE AddressSpace)
|
PMADDRESS_SPACE AddressSpace)
|
||||||
{
|
{
|
||||||
InitializeListHead(&AddressSpace->MAreaListHead);
|
InitializeListHead(&AddressSpace->MAreaListHead);
|
||||||
KeInitializeMutex(&AddressSpace->Lock, 1);
|
ExInitializeFastMutex(&AddressSpace->Lock);
|
||||||
if (Process != NULL)
|
if (Process != NULL)
|
||||||
{
|
{
|
||||||
AddressSpace->LowestAddress = MM_LOWEST_USER_ADDRESS;
|
AddressSpace->LowestAddress = MM_LOWEST_USER_ADDRESS;
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* $Id: mdl.c,v 1.39 2002/05/14 21:19:19 dwelch Exp $
|
/* $Id: mdl.c,v 1.40 2002/05/17 23:01:56 dwelch Exp $
|
||||||
*
|
*
|
||||||
* COPYRIGHT: See COPYING in the top level directory
|
* COPYRIGHT: See COPYING in the top level directory
|
||||||
* PROJECT: ReactOS kernel
|
* PROJECT: ReactOS kernel
|
||||||
|
@ -23,8 +23,46 @@
|
||||||
|
|
||||||
#define TAG_MDL TAG('M', 'M', 'D', 'L')
|
#define TAG_MDL TAG('M', 'M', 'D', 'L')
|
||||||
|
|
||||||
|
#define MI_MDL_MAPPING_REGION_SIZE (256*1024*1024)
|
||||||
|
|
||||||
|
static PVOID MiMdlMappingRegionBase = NULL;
|
||||||
|
static PULONG MiMdlMappingRegionAllocMap = NULL;
|
||||||
|
static ULONG MiMdlMappingRegionHighWaterMark = 0;
|
||||||
|
static KSPIN_LOCK MiMdlMappingRegionLock;
|
||||||
|
|
||||||
/* FUNCTIONS *****************************************************************/
|
/* FUNCTIONS *****************************************************************/
|
||||||
|
|
||||||
|
VOID
|
||||||
|
MmInitializeMdlImplementation(VOID)
|
||||||
|
{
|
||||||
|
MEMORY_AREA* Result;
|
||||||
|
NTSTATUS Status;
|
||||||
|
|
||||||
|
MiMdlMappingRegionBase = NULL;
|
||||||
|
|
||||||
|
MmLockAddressSpace(MmGetKernelAddressSpace());
|
||||||
|
Status = MmCreateMemoryArea(NULL,
|
||||||
|
MmGetKernelAddressSpace(),
|
||||||
|
MEMORY_AREA_MDL_MAPPING,
|
||||||
|
&MiMdlMappingRegionBase,
|
||||||
|
MI_MDL_MAPPING_REGION_SIZE,
|
||||||
|
0,
|
||||||
|
&Result,
|
||||||
|
FALSE);
|
||||||
|
if (!NT_SUCCESS(Status))
|
||||||
|
{
|
||||||
|
MmUnlockAddressSpace(MmGetKernelAddressSpace());
|
||||||
|
KeBugCheck(0);
|
||||||
|
}
|
||||||
|
MmUnlockAddressSpace(MmGetKernelAddressSpace());
|
||||||
|
|
||||||
|
MiMdlMappingRegionAllocMap =
|
||||||
|
ExAllocatePool(NonPagedPool,
|
||||||
|
MI_MDL_MAPPING_REGION_SIZE / (PAGESIZE * 32));
|
||||||
|
MiMdlMappingRegionHighWaterMark = 0;
|
||||||
|
KeInitializeSpinLock(&MiMdlMappingRegionLock);
|
||||||
|
}
|
||||||
|
|
||||||
PVOID
|
PVOID
|
||||||
MmGetMdlPageAddress(PMDL Mdl, PVOID Offset)
|
MmGetMdlPageAddress(PMDL Mdl, PVOID Offset)
|
||||||
{
|
{
|
||||||
|
@ -75,22 +113,23 @@ MmUnlockPages(PMDL Mdl)
|
||||||
Mdl->MdlFlags = Mdl->MdlFlags & (~MDL_PAGES_LOCKED);
|
Mdl->MdlFlags = Mdl->MdlFlags & (~MDL_PAGES_LOCKED);
|
||||||
}
|
}
|
||||||
|
|
||||||
PVOID STDCALL MmMapLockedPages(PMDL Mdl, KPROCESSOR_MODE AccessMode)
|
PVOID STDCALL
|
||||||
|
MmMapLockedPages(PMDL Mdl, KPROCESSOR_MODE AccessMode)
|
||||||
/*
|
/*
|
||||||
* FUNCTION: Maps the physical pages described by a given MDL
|
* FUNCTION: Maps the physical pages described by a given MDL
|
||||||
* ARGUMENTS:
|
* ARGUMENTS:
|
||||||
* Mdl = Points to an MDL updated by MmProbeAndLockPages
|
* Mdl = Points to an MDL updated by MmProbeAndLockPages
|
||||||
* AccessMode = Specifies the access mode in which to map the MDL
|
* AccessMode = Specifies the portion of the address space to map the
|
||||||
|
* pages.
|
||||||
* RETURNS: The base virtual address that maps the locked pages for the
|
* RETURNS: The base virtual address that maps the locked pages for the
|
||||||
* range described by the MDL
|
* range described by the MDL
|
||||||
* FIXME: What does AccessMode do?
|
|
||||||
*/
|
*/
|
||||||
{
|
{
|
||||||
PVOID Base;
|
PVOID Base;
|
||||||
ULONG i;
|
ULONG i;
|
||||||
PULONG MdlPages;
|
PULONG MdlPages;
|
||||||
MEMORY_AREA* Result;
|
KIRQL oldIrql;
|
||||||
NTSTATUS Status;
|
ULONG RegionSize;
|
||||||
|
|
||||||
DPRINT("MmMapLockedPages(Mdl %x, AccessMode %x)\n", Mdl, AccessMode);
|
DPRINT("MmMapLockedPages(Mdl %x, AccessMode %x)\n", Mdl, AccessMode);
|
||||||
|
|
||||||
|
@ -98,46 +137,50 @@ PVOID STDCALL MmMapLockedPages(PMDL Mdl, KPROCESSOR_MODE AccessMode)
|
||||||
{
|
{
|
||||||
return(Mdl->MappedSystemVa);
|
return(Mdl->MappedSystemVa);
|
||||||
}
|
}
|
||||||
|
|
||||||
MmLockAddressSpace(MmGetKernelAddressSpace());
|
if (AccessMode == UserMode)
|
||||||
|
|
||||||
Base = NULL;
|
|
||||||
Status = MmCreateMemoryArea(NULL,
|
|
||||||
MmGetKernelAddressSpace(),
|
|
||||||
MEMORY_AREA_MDL_MAPPING,
|
|
||||||
&Base,
|
|
||||||
Mdl->ByteCount + Mdl->ByteOffset,
|
|
||||||
0,
|
|
||||||
&Result,
|
|
||||||
FALSE);
|
|
||||||
if (!NT_SUCCESS(Status))
|
|
||||||
{
|
{
|
||||||
MmUnlockAddressSpace(MmGetKernelAddressSpace());
|
DPRINT1("MDL mapping to user-mode not yet handled.\n");
|
||||||
KeBugCheck(0);
|
KeBugCheck(0);
|
||||||
return(STATUS_SUCCESS);
|
|
||||||
}
|
}
|
||||||
MmUnlockAddressSpace(MmGetKernelAddressSpace());
|
|
||||||
|
/* Calculate the number of pages required. */
|
||||||
|
RegionSize = PAGE_ROUND_UP(Mdl->ByteCount + Mdl->ByteOffset) / PAGESIZE;
|
||||||
|
|
||||||
|
/* Allocate that number of pages from the mdl mapping region. */
|
||||||
|
KeAcquireSpinLock(&MiMdlMappingRegionLock, &oldIrql);
|
||||||
|
Base = MiMdlMappingRegionBase + MiMdlMappingRegionHighWaterMark * PAGESIZE;
|
||||||
|
for (i = 0; i < RegionSize; i++)
|
||||||
|
{
|
||||||
|
ULONG Offset = MiMdlMappingRegionHighWaterMark + i;
|
||||||
|
MiMdlMappingRegionAllocMap[Offset / 32] |= (1 << (Offset % 32));
|
||||||
|
}
|
||||||
|
MiMdlMappingRegionHighWaterMark += RegionSize;
|
||||||
|
KeReleaseSpinLock(&MiMdlMappingRegionLock, oldIrql);
|
||||||
|
|
||||||
|
/* Set the virtual mappings for the MDL pages. */
|
||||||
MdlPages = (PULONG)(Mdl + 1);
|
MdlPages = (PULONG)(Mdl + 1);
|
||||||
for (i=0; i<(PAGE_ROUND_UP(Mdl->ByteCount+Mdl->ByteOffset)/PAGESIZE); i++)
|
for (i = 0; i < RegionSize; i++)
|
||||||
{
|
{
|
||||||
Status = MmCreateVirtualMapping(NULL,
|
NTSTATUS Status;
|
||||||
(PVOID)((ULONG)Base+(i*PAGESIZE)),
|
Status = MmCreateVirtualMapping(NULL,
|
||||||
PAGE_READWRITE,
|
(PVOID)((ULONG)Base+(i*PAGESIZE)),
|
||||||
MdlPages[i],
|
PAGE_READWRITE,
|
||||||
TRUE);
|
MdlPages[i],
|
||||||
if (!NT_SUCCESS(Status))
|
FALSE);
|
||||||
{
|
if (!NT_SUCCESS(Status))
|
||||||
DbgPrint("Unable to create virtual mapping\n");
|
{
|
||||||
KeBugCheck(0);
|
DbgPrint("Unable to create virtual mapping\n");
|
||||||
}
|
KeBugCheck(0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Mark the MDL has having being mapped. */
|
||||||
Mdl->MdlFlags = Mdl->MdlFlags | MDL_MAPPED_TO_SYSTEM_VA;
|
Mdl->MdlFlags = Mdl->MdlFlags | MDL_MAPPED_TO_SYSTEM_VA;
|
||||||
Mdl->MappedSystemVa = Base + Mdl->ByteOffset;
|
Mdl->MappedSystemVa = Base + Mdl->ByteOffset;
|
||||||
return(Base + Mdl->ByteOffset);
|
return(Base + Mdl->ByteOffset);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
VOID STDCALL
|
VOID STDCALL
|
||||||
MmUnmapLockedPages(PVOID BaseAddress, PMDL Mdl)
|
MmUnmapLockedPages(PVOID BaseAddress, PMDL Mdl)
|
||||||
/*
|
/*
|
||||||
|
@ -147,26 +190,54 @@ MmUnmapLockedPages(PVOID BaseAddress, PMDL Mdl)
|
||||||
* MemoryDescriptorList = MDL describing the mapped pages
|
* MemoryDescriptorList = MDL describing the mapped pages
|
||||||
*/
|
*/
|
||||||
{
|
{
|
||||||
DPRINT("MmUnmapLockedPages(BaseAddress %x, Mdl %x)\n", Mdl, BaseAddress);
|
KIRQL oldIrql;
|
||||||
|
ULONG i;
|
||||||
|
ULONG RegionSize;
|
||||||
|
ULONG Base;
|
||||||
|
|
||||||
/*
|
DPRINT("MmUnmapLockedPages(BaseAddress %x, Mdl %x)\n", Mdl, BaseAddress);
|
||||||
* In this case, the MDL has the same system address as the base address
|
|
||||||
* so there is no need to free it
|
|
||||||
*/
|
|
||||||
if (Mdl->MdlFlags & MDL_SOURCE_IS_NONPAGED_POOL)
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
MmLockAddressSpace(MmGetKernelAddressSpace());
|
/*
|
||||||
(VOID)MmFreeMemoryArea(MmGetKernelAddressSpace(),
|
* In this case, the MDL has the same system address as the base address
|
||||||
BaseAddress - Mdl->ByteOffset,
|
* so there is no need to free it
|
||||||
Mdl->ByteOffset + Mdl->ByteCount,
|
*/
|
||||||
NULL,
|
if (Mdl->MdlFlags & MDL_SOURCE_IS_NONPAGED_POOL)
|
||||||
NULL);
|
{
|
||||||
Mdl->MdlFlags = Mdl->MdlFlags & ~MDL_MAPPED_TO_SYSTEM_VA;
|
return;
|
||||||
Mdl->MappedSystemVa = NULL;
|
}
|
||||||
MmUnlockAddressSpace(MmGetKernelAddressSpace());
|
|
||||||
|
/* Calculate the number of pages we mapped. */
|
||||||
|
RegionSize = PAGE_ROUND_UP(Mdl->ByteCount + Mdl->ByteOffset) / PAGESIZE;
|
||||||
|
|
||||||
|
KeAcquireSpinLock(&MiMdlMappingRegionLock, &oldIrql);
|
||||||
|
/* Deallocate all the pages used. */
|
||||||
|
Base = (ULONG)(BaseAddress - MiMdlMappingRegionBase - Mdl->ByteOffset);
|
||||||
|
Base = Base / PAGESIZE;
|
||||||
|
for (i = 0; i < RegionSize; i++)
|
||||||
|
{
|
||||||
|
ULONG Offset = Base + i;
|
||||||
|
MiMdlMappingRegionAllocMap[Offset / 32] &= ~(1 << (Offset % 32));
|
||||||
|
}
|
||||||
|
/* If all the pages below the high-water mark are free then move it down. */
|
||||||
|
if ((Base + RegionSize) == MiMdlMappingRegionHighWaterMark)
|
||||||
|
{
|
||||||
|
MiMdlMappingRegionHighWaterMark = Base;
|
||||||
|
}
|
||||||
|
KeReleaseSpinLock(&MiMdlMappingRegionLock, oldIrql);
|
||||||
|
|
||||||
|
/* Unmap all the pages. */
|
||||||
|
for (i = 0; i < RegionSize; i++)
|
||||||
|
{
|
||||||
|
MmDeleteVirtualMapping(NULL,
|
||||||
|
BaseAddress + (i * PAGESIZE),
|
||||||
|
FALSE,
|
||||||
|
NULL,
|
||||||
|
NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Reset the MDL state. */
|
||||||
|
Mdl->MdlFlags = Mdl->MdlFlags & ~MDL_MAPPED_TO_SYSTEM_VA;
|
||||||
|
Mdl->MappedSystemVa = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* $Id: mminit.c,v 1.33 2002/05/14 21:19:19 dwelch Exp $
|
/* $Id: mminit.c,v 1.34 2002/05/17 23:01:56 dwelch Exp $
|
||||||
*
|
*
|
||||||
* COPYRIGHT: See COPYING in the top directory
|
* COPYRIGHT: See COPYING in the top directory
|
||||||
* PROJECT: ReactOS kernel
|
* PROJECT: ReactOS kernel
|
||||||
|
@ -338,6 +338,8 @@ VOID MmInit1(ULONG FirstKrnlPhysAddr,
|
||||||
* Intialize memory areas
|
* Intialize memory areas
|
||||||
*/
|
*/
|
||||||
MmInitVirtualMemory(LastKernelAddress, kernel_len);
|
MmInitVirtualMemory(LastKernelAddress, kernel_len);
|
||||||
|
|
||||||
|
MmInitializeMdlImplementation();
|
||||||
}
|
}
|
||||||
|
|
||||||
VOID MmInit2(VOID)
|
VOID MmInit2(VOID)
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, write to the Free Software
|
||||||
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||||
*/
|
*/
|
||||||
/* $Id: section.c,v 1.82 2002/05/14 21:19:19 dwelch Exp $
|
/* $Id: section.c,v 1.83 2002/05/17 23:01:56 dwelch Exp $
|
||||||
*
|
*
|
||||||
* PROJECT: ReactOS kernel
|
* PROJECT: ReactOS kernel
|
||||||
* FILE: ntoskrnl/mm/section.c
|
* FILE: ntoskrnl/mm/section.c
|
||||||
|
@ -2396,7 +2396,7 @@ NtOpenSection(PHANDLE SectionHandle,
|
||||||
return(Status);
|
return(Status);
|
||||||
}
|
}
|
||||||
|
|
||||||
NTSTATUS
|
NTSTATUS STATIC
|
||||||
MmMapViewOfSegment(PEPROCESS Process,
|
MmMapViewOfSegment(PEPROCESS Process,
|
||||||
PMADDRESS_SPACE AddressSpace,
|
PMADDRESS_SPACE AddressSpace,
|
||||||
PSECTION_OBJECT Section,
|
PSECTION_OBJECT Section,
|
||||||
|
@ -2410,7 +2410,6 @@ MmMapViewOfSegment(PEPROCESS Process,
|
||||||
NTSTATUS Status;
|
NTSTATUS Status;
|
||||||
KIRQL oldIrql;
|
KIRQL oldIrql;
|
||||||
|
|
||||||
MmLockAddressSpace(&Process->AddressSpace);
|
|
||||||
if (Protect == PAGE_NOACCESS || Protect == PAGE_GUARD)
|
if (Protect == PAGE_NOACCESS || Protect == PAGE_GUARD)
|
||||||
{
|
{
|
||||||
DPRINT1("Mapping inaccessible region between 0x%.8X and 0x%.8X\n",
|
DPRINT1("Mapping inaccessible region between 0x%.8X and 0x%.8X\n",
|
||||||
|
@ -2424,29 +2423,28 @@ MmMapViewOfSegment(PEPROCESS Process,
|
||||||
Protect,
|
Protect,
|
||||||
&MArea,
|
&MArea,
|
||||||
FALSE);
|
FALSE);
|
||||||
MmUnlockAddressSpace(&Process->AddressSpace);
|
if (!NT_SUCCESS(Status))
|
||||||
if (!NT_SUCCESS(Status))
|
{
|
||||||
{
|
DPRINT1("Mapping between 0x%.8X and 0x%.8X failed.\n",
|
||||||
DPRINT1("Mapping between 0x%.8X and 0x%.8X failed.\n",
|
(*BaseAddress), (*BaseAddress) + ViewSize);
|
||||||
(*BaseAddress), (*BaseAddress) + ViewSize);
|
return(Status);
|
||||||
return(Status);
|
}
|
||||||
}
|
|
||||||
|
KeAcquireSpinLock(&Section->ViewListLock, &oldIrql);
|
||||||
KeAcquireSpinLock(&Section->ViewListLock, &oldIrql);
|
InsertTailList(&Section->ViewListHead,
|
||||||
InsertTailList(&Section->ViewListHead,
|
&MArea->Data.SectionData.ViewListEntry);
|
||||||
&MArea->Data.SectionData.ViewListEntry);
|
KeReleaseSpinLock(&Section->ViewListLock, oldIrql);
|
||||||
KeReleaseSpinLock(&Section->ViewListLock, oldIrql);
|
|
||||||
|
ObReferenceObjectByPointer((PVOID)Section,
|
||||||
ObReferenceObjectByPointer((PVOID)Section,
|
SECTION_MAP_READ,
|
||||||
SECTION_MAP_READ,
|
NULL,
|
||||||
NULL,
|
ExGetPreviousMode());
|
||||||
ExGetPreviousMode());
|
MArea->Data.SectionData.Segment = Segment;
|
||||||
MArea->Data.SectionData.Segment = Segment;
|
MArea->Data.SectionData.Section = Section;
|
||||||
MArea->Data.SectionData.Section = Section;
|
MArea->Data.SectionData.ViewOffset = ViewOffset;
|
||||||
MArea->Data.SectionData.ViewOffset = ViewOffset;
|
MArea->Data.SectionData.WriteCopyView = FALSE;
|
||||||
MArea->Data.SectionData.WriteCopyView = FALSE;
|
|
||||||
|
return(STATUS_SUCCESS);
|
||||||
return(STATUS_SUCCESS);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* $Id: thread.c,v 1.92 2002/05/14 21:19:21 dwelch Exp $
|
/* $Id: thread.c,v 1.93 2002/05/17 23:01:56 dwelch Exp $
|
||||||
*
|
*
|
||||||
* COPYRIGHT: See COPYING in the top level directory
|
* COPYRIGHT: See COPYING in the top level directory
|
||||||
* PROJECT: ReactOS kernel
|
* PROJECT: ReactOS kernel
|
||||||
|
@ -125,7 +125,7 @@ VOID PsDumpThreads(BOOLEAN IncludeSystem)
|
||||||
i = 0;
|
i = 0;
|
||||||
while (Ebp != 0 && Ebp >= (PULONG)current->Tcb.StackLimit)
|
while (Ebp != 0 && Ebp >= (PULONG)current->Tcb.StackLimit)
|
||||||
{
|
{
|
||||||
DbgPrint("%.8X%s", Ebp[0], Ebp[1],
|
DbgPrint("%.8X %.8X%s", Ebp[0], Ebp[1],
|
||||||
(i % 8) == 7 ? "\n" : " ");
|
(i % 8) == 7 ? "\n" : " ");
|
||||||
Ebp = (PULONG)Ebp[0];
|
Ebp = (PULONG)Ebp[0];
|
||||||
i++;
|
i++;
|
||||||
|
|
Loading…
Reference in a new issue