2010-02-02 18:56:00 +01:00
|
|
|
;------------------------------------------------------------------------------
|
|
|
|
; @file
|
|
|
|
; This file includes all other code files to assemble the reset vector code
|
|
|
|
;
|
2013-09-24 20:23:09 +02:00
|
|
|
; Copyright (c) 2008 - 2013, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:07:22 +02:00
|
|
|
; SPDX-License-Identifier: BSD-2-Clause-Patent
|
2010-02-02 18:56:00 +01:00
|
|
|
;
|
|
|
|
;------------------------------------------------------------------------------
|
|
|
|
|
2014-08-19 01:03:30 +02:00
|
|
|
;
|
|
|
|
; 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
|
|
|
|
|
2010-02-02 18:56:00 +01:00
|
|
|
%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"
|
|
|
|
|
2021-09-11 13:25:51 +02:00
|
|
|
%include "PageTables.inc"
|
|
|
|
|
2014-08-19 01:03:46 +02:00
|
|
|
%ifdef ARCH_X64
|
2021-09-11 13:25:51 +02:00
|
|
|
%ifdef PAGE_TABLE_1G
|
|
|
|
%include "X64/PageTables1G.asm"
|
|
|
|
%else
|
|
|
|
%include "X64/PageTables2M.asm"
|
|
|
|
%endif
|
2014-08-19 01:03:46 +02:00
|
|
|
%endif
|
|
|
|
|
2014-08-19 01:03:30 +02:00
|
|
|
%ifdef DEBUG_PORT80
|
2010-02-02 18:56:00 +01:00
|
|
|
%include "Port80Debug.asm"
|
|
|
|
%elifdef DEBUG_SERIAL
|
|
|
|
%include "SerialDebug.asm"
|
|
|
|
%else
|
2014-08-19 01:03:30 +02:00
|
|
|
%include "DebugDisabled.asm"
|
2010-02-02 18:56:00 +01:00
|
|
|
%endif
|
|
|
|
|
|
|
|
%include "Ia32/SearchForBfvBase.asm"
|
|
|
|
%include "Ia32/SearchForSecEntry.asm"
|
|
|
|
|
|
|
|
%ifdef ARCH_X64
|
2010-09-07 12:23:05 +02:00
|
|
|
%include "Ia32/Flat32ToFlat64.asm"
|
2013-09-24 20:23:09 +02:00
|
|
|
%include "Ia32/PageTables64.asm"
|
2010-02-02 18:56:00 +01:00
|
|
|
%endif
|
|
|
|
|
2010-09-07 12:23:05 +02:00
|
|
|
%include "Ia16/Real16ToFlat32.asm"
|
2010-02-02 18:56:00 +01:00
|
|
|
%include "Ia16/Init16.asm"
|
|
|
|
|
|
|
|
%include "Main.asm"
|
|
|
|
|
|
|
|
%include "Ia16/ResetVectorVtf0.asm"
|
|
|
|
|