git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@2358 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			228 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			228 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*++
 | 
						|
 | 
						|
Copyright (c) 2006, Intel Corporation                                                         
 | 
						|
All rights reserved. This program and the accompanying materials                          
 | 
						|
are licensed and made available under the terms and conditions of the BSD License         
 | 
						|
which accompanies this distribution.  The full text of the license may be found at        
 | 
						|
http://opensource.org/licenses/bsd-license.php                                            
 | 
						|
                                                                                          
 | 
						|
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,                     
 | 
						|
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.             
 | 
						|
 | 
						|
Module Name:
 | 
						|
 | 
						|
  imem.h
 | 
						|
 | 
						|
Abstract:
 | 
						|
 | 
						|
  Head file to imem.h
 | 
						|
 | 
						|
 | 
						|
Revision History
 | 
						|
 | 
						|
--*/
 | 
						|
 | 
						|
#ifndef _IMEM_H_
 | 
						|
#define _IMEM_H_
 | 
						|
 | 
						|
#if defined (MDE_CPU_IPF)
 | 
						|
//
 | 
						|
// For Itanium machines make the default allocations 8K aligned
 | 
						|
//
 | 
						|
#define EFI_ACPI_RUNTIME_PAGE_ALLOCATION_ALIGNMENT  (EFI_PAGE_SIZE * 2)
 | 
						|
#define DEFAULT_PAGE_ALLOCATION                     (EFI_PAGE_SIZE * 2)
 | 
						|
 | 
						|
#else
 | 
						|
//
 | 
						|
// For genric EFI machines make the default allocations 4K aligned
 | 
						|
//
 | 
						|
#define EFI_ACPI_RUNTIME_PAGE_ALLOCATION_ALIGNMENT  (EFI_PAGE_SIZE)
 | 
						|
#define DEFAULT_PAGE_ALLOCATION                     (EFI_PAGE_SIZE)
 | 
						|
 | 
						|
#endif
 | 
						|
 | 
						|
 | 
						|
//
 | 
						|
// MEMORY_MAP_ENTRY
 | 
						|
//
 | 
						|
 | 
						|
#define MEMORY_MAP_SIGNATURE   EFI_SIGNATURE_32('m','m','a','p')
 | 
						|
typedef struct {
 | 
						|
  UINTN           Signature;
 | 
						|
  LIST_ENTRY      Link;
 | 
						|
  BOOLEAN         FromPages;
 | 
						|
 | 
						|
  EFI_MEMORY_TYPE Type;
 | 
						|
  UINT64          Start;
 | 
						|
  UINT64          End;
 | 
						|
 | 
						|
  UINT64          VirtualStart;
 | 
						|
  UINT64          Attribute;
 | 
						|
} MEMORY_MAP;
 | 
						|
 | 
						|
//
 | 
						|
// Internal prototypes
 | 
						|
//
 | 
						|
 | 
						|
VOID *
 | 
						|
CoreAllocatePoolPages (
 | 
						|
  IN EFI_MEMORY_TYPE   PoolType,
 | 
						|
  IN UINTN             NumberOfPages,
 | 
						|
  IN UINTN             Alignment
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  Internal function.  Used by the pool functions to allocate pages
 | 
						|
  to back pool allocation requests.
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  PoolType      - The type of memory for the new pool pages
 | 
						|
 | 
						|
  NumberOfPages - No of pages to allocate
 | 
						|
  
 | 
						|
  Alignment     - Bits to align.
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  The allocated memory, or NULL
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
 | 
						|
VOID
 | 
						|
CoreFreePoolPages (
 | 
						|
  IN EFI_PHYSICAL_ADDRESS   Memory,
 | 
						|
  IN UINTN                  NumberOfPages
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  Internal function.  Frees pool pages allocated via AllocatePoolPages ()
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  Memory        - The base address to free
 | 
						|
 | 
						|
  NumberOfPages - The number of pages to free
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  None
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
 | 
						|
VOID *
 | 
						|
CoreAllocatePoolI (
 | 
						|
  IN EFI_MEMORY_TYPE  PoolType,
 | 
						|
  IN UINTN            Size
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  Internal function to allocate pool of a particular type.
 | 
						|
 | 
						|
  Caller must have the memory lock held
 | 
						|
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  PoolType    - Type of pool to allocate
 | 
						|
 | 
						|
  Size        - The amount of pool to allocate
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  The allocate pool, or NULL
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
 | 
						|
EFI_STATUS
 | 
						|
CoreFreePoolI (
 | 
						|
  IN VOID           *Buffer
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  Internal function to free a pool entry.
 | 
						|
 | 
						|
  Caller must have the memory lock held
 | 
						|
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  Buffer      - The allocated pool entry to free
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  EFI_INVALID_PARAMETER     - Buffer not valid
 | 
						|
  
 | 
						|
  EFI_SUCCESS               - Buffer successfully freed.
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
 | 
						|
VOID
 | 
						|
CoreAcquireMemoryLock (
 | 
						|
  VOID
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  Enter critical section by gaining lock on gMemoryLock
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  None
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  None
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
VOID
 | 
						|
CoreReleaseMemoryLock (
 | 
						|
  VOID
 | 
						|
  )
 | 
						|
/*++
 | 
						|
 | 
						|
Routine Description:
 | 
						|
 | 
						|
  Exit critical section by releasing lock on gMemoryLock
 | 
						|
 | 
						|
Arguments:
 | 
						|
 | 
						|
  None
 | 
						|
 | 
						|
Returns:
 | 
						|
 | 
						|
  None
 | 
						|
 | 
						|
--*/
 | 
						|
;
 | 
						|
 | 
						|
 | 
						|
//
 | 
						|
// Internal Global data
 | 
						|
//
 | 
						|
 | 
						|
extern EFI_LOCK           gMemoryLock; 
 | 
						|
extern LIST_ENTRY         gMemoryMap;
 | 
						|
extern MEMORY_MAP         *gMemoryLastConvert;
 | 
						|
extern LIST_ENTRY         mGcdMemorySpaceMap;
 | 
						|
#endif
 |