Source code of Windows XP (NT5)
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
/*++
Copyright (c) 1990, 1991 Microsoft Corporation
Module Name:
hwheap.c
Abstract:
This is a very simple Heap Manager for NT OS Hardware recognizer. This module provides functions to allocate memory in byte-unit from a permanent heap.
Author:
Shie-Lin Tzong (shielint) 18-Oct-91
Environment:
Kernel Mode
Revision History:
--*/
#include "hwdetect.h"
#include "string.h"
VOID GrowHeapSpace( ULONG );
VOID HeapCheck( PVOID );
//
// Heap management variables.
//
ULONG_PTR HwHeapBase = 0; // Current virtual address of base of heap
ULONG_PTR HwHeapPointer = 0; // Pointer to the end of available heap
ULONG HwHeapSize = 0; // Size of Heap
ULONG HwAvailableHeap = 0; // Currently available heap space
#if DBG
ULONG HwPreviousAllocSize = 0; #endif
BOOLEAN HwResizeHeap ( ULONG NewHeapSize )
/*++
Routine Description:
The routine grows current heap to the specified size. It reallocates the heap, copies the data in current heap to the new heap, updates heap variables, updates heap pointers in hardware data structures and finally frees the old heap.
Arguments:
NewHeapSize - Specifies the size of the new heap.
Returns:
TRUE - if operation is done sucessfully. Else it returns FALSE.
--*/
{ //
// Not implemented yet.
//
return(FALSE); }
BOOLEAN HwInitializeHeap( ULONG HeapStart, ULONG HeapSize )
/*++
Routine Description:
The routine allocates heap and initializes some vital heap variables.
Arguments:
None
Returns:
FALSE - if unable to allocate initial heap. Else it returns TRUE.
--*/
{
HwHeapBase = HeapStart; HwHeapPointer = HwHeapBase; HwHeapSize = HeapSize; HwAvailableHeap = HwHeapSize; return(TRUE);
}
FPVOID HwAllocateHeap( ULONG RequestSize, BOOLEAN ZeroInitialized )
/**
Routine Description:
Allocates memory from the hardware recognizer's heap.
The heap begins with a default size. If a request exhausts heap space, the heap will be grown to accomodate the request. The heap can grow up to any size limited by NTLDR. If we run out of heap space and are unable to allocate more memory, a value of NULL will be returned.
Arguments:
RequestSize - Size of block to allocate.
ZeroInitialized - Specifies if the heap should be zero initialized.
Returns:
Returns a pointer to the allocated block of memory. A NULL pointer will be returned if we run out of heap and are unable to resize current heap.
--*/
{ FPVOID ReturnPointer;
if (RequestSize > HwAvailableHeap) {
//
// We're out of heap. Try to grow current heap to satisfy the
// request.
//
if (!HwResizeHeap(HwHeapSize + RequestSize)) { #if DBG
BlPrint("Unable to grow heap\n"); #endif
return(NULL); } }
//
// Set our return value to the new Heap pointer then
// update the remaining space and heap pointer.
//
HwHeapPointer = (HwHeapPointer + 0xf) & ~0xf; MAKE_FP(ReturnPointer, HwHeapPointer); HwHeapPointer += (RequestSize + 0xf) & ~0xf; #if DBG
HwPreviousAllocSize = RequestSize; #endif
HwAvailableHeap -= RequestSize; if (ZeroInitialized) { _fmemset(ReturnPointer, 0, (USHORT)RequestSize); } return (ReturnPointer); }
VOID HwFreeHeap( ULONG Size )
/**
Routine Description:
Unallocates memory from the hardware recognizer's heap.
The unallocation is very basic. It simply moves heap pointer back by the size specified and increases the heap size by the specified size. The routine should be used only when previous allocateHeap allocated too much memory.
Arguments:
RequestSize - Size of block to allocate.
Returns:
Returns a pointer to the allocated block of memory. A NULL pointer will be returned if we run out of heap and are unable to resize current heap.
--*/
{
#if DBG
if (Size > HwPreviousAllocSize) { BlPrint("Invalid heap deallocation ...\n"); } else { HwPreviousAllocSize -= Size; } #endif
Size = (Size + 0xf) & 0xfffffff0; // align at 16-byte boundary
HwHeapPointer -= Size; HwAvailableHeap += Size; }
|