mirror of
				https://github.com/acidanthera/audk.git
				synced 2025-10-26 01:33:45 +02:00 
			
		
		
		
	Currently, the value of the page tables' address is hard-coded in the ResetVector. This patch replaces these values with a PCD dependency. A check for the size has been added to alert the developer to rewrite the ASM according to the new size, if it has been changed. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Marvin Haeuser <Marvin.Haeuser@outlook.com> Reviewed-by: Laszlo Ersek <lersek@redhat.com> Tested-by: Laszlo Ersek <lersek@redhat.com> Reviewed-by: Jordan Justen <jordan.l.justen@intel.com>
		
			
				
	
	
		
			74 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			74 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| ;------------------------------------------------------------------------------
 | |
| ; @file
 | |
| ; This file includes all other code files to assemble the reset vector code
 | |
| ;
 | |
| ; Copyright (c) 2008 - 2013, Intel Corporation. All rights reserved.<BR>
 | |
| ; 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.
 | |
| ;
 | |
| ;------------------------------------------------------------------------------
 | |
| 
 | |
| ;
 | |
| ; If neither ARCH_IA32 nor ARCH_X64 are defined, then try to include
 | |
| ; Base.h to use the C pre-processor to determine the architecture.
 | |
| ;
 | |
| %ifndef ARCH_IA32
 | |
|   %ifndef ARCH_X64
 | |
|     #include <Base.h>
 | |
|     #if defined (MDE_CPU_IA32)
 | |
|       %define ARCH_IA32
 | |
|     #elif defined (MDE_CPU_X64)
 | |
|       %define ARCH_X64
 | |
|     #endif
 | |
|   %endif
 | |
| %endif
 | |
| 
 | |
| %ifdef ARCH_IA32
 | |
|   %ifdef ARCH_X64
 | |
|     %error "Only one of ARCH_IA32 or ARCH_X64 can be defined."
 | |
|   %endif
 | |
| %elifdef ARCH_X64
 | |
| %else
 | |
|   %error "Either ARCH_IA32 or ARCH_X64 must be defined."
 | |
| %endif
 | |
| 
 | |
| %include "CommonMacros.inc"
 | |
| 
 | |
| %include "PostCodes.inc"
 | |
| 
 | |
| %ifdef DEBUG_PORT80
 | |
|   %include "Port80Debug.asm"
 | |
| %elifdef DEBUG_SERIAL
 | |
|   %include "SerialDebug.asm"
 | |
| %else
 | |
|   %include "DebugDisabled.asm"
 | |
| %endif
 | |
| 
 | |
| %include "Ia32/SearchForBfvBase.asm"
 | |
| %include "Ia32/SearchForSecEntry.asm"
 | |
| 
 | |
| %ifdef ARCH_X64
 | |
|   #include <AutoGen.h>
 | |
| 
 | |
|   %if (FixedPcdGet32 (PcdOvmfSecPageTablesSize) != 0x6000)
 | |
|     %error "This implementation inherently depends on PcdOvmfSecPageTablesSize"
 | |
|   %endif
 | |
| 
 | |
|   %define PT_ADDR(Offset) (FixedPcdGet32 (PcdOvmfSecPageTablesBase) + (Offset))
 | |
| %include "Ia32/Flat32ToFlat64.asm"
 | |
| %include "Ia32/PageTables64.asm"
 | |
| %endif
 | |
| 
 | |
| %include "Ia16/Real16ToFlat32.asm"
 | |
| %include "Ia16/Init16.asm"
 | |
| 
 | |
| %include "Main.asm"
 | |
| 
 | |
| %include "Ia16/ResetVectorVtf0.asm"
 | |
| 
 |