There are two FSP images at different locations in a flash (one factory version is read only and other in updatable version) TempRamInit, FspMemoryInit and TempRamExit are executed from factory version and FspSiliconInit/NotifyPhase will be executed from updatable version. Also update FSP specification version to v1.1. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: "Ma, Maurice" <maurice.ma@intel.com> Reviewed-by: "Yao, Jiewen" <Jiewen.Yao@intel.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@17248 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			78 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			NASM
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			NASM
		
	
	
	
	
	
;------------------------------------------------------------------------------
 | 
						|
;
 | 
						|
; Copyright (c) 2014 - 2015, 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.
 | 
						|
;
 | 
						|
; Abstract:
 | 
						|
;
 | 
						|
;   Switch the stack from temporary memory to permenent memory.
 | 
						|
;
 | 
						|
;------------------------------------------------------------------------------
 | 
						|
 | 
						|
    .586p
 | 
						|
    .model  flat,C
 | 
						|
    .code
 | 
						|
 | 
						|
;------------------------------------------------------------------------------
 | 
						|
; UINT32
 | 
						|
; EFIAPI
 | 
						|
; Pei2LoaderSwitchStack (
 | 
						|
;   VOID
 | 
						|
;   )
 | 
						|
;------------------------------------------------------------------------------
 | 
						|
EXTERNDEF  C   MeasurePoint:PROC
 | 
						|
Pei2LoaderSwitchStack   PROC C PUBLIC
 | 
						|
    xor     eax, eax
 | 
						|
    jmp     FspSwitchStack
 | 
						|
Pei2LoaderSwitchStack   ENDP
 | 
						|
 | 
						|
;------------------------------------------------------------------------------
 | 
						|
; UINT32
 | 
						|
; EFIAPI
 | 
						|
; Loader2PeiSwitchStack (
 | 
						|
;   VOID
 | 
						|
;   )
 | 
						|
;------------------------------------------------------------------------------
 | 
						|
Loader2PeiSwitchStack   PROC C PUBLIC
 | 
						|
    jmp     FspSwitchStack
 | 
						|
Loader2PeiSwitchStack   ENDP
 | 
						|
 | 
						|
;------------------------------------------------------------------------------
 | 
						|
; UINT32
 | 
						|
; EFIAPI
 | 
						|
; FspSwitchStack (
 | 
						|
;   VOID
 | 
						|
;   )
 | 
						|
;------------------------------------------------------------------------------
 | 
						|
EXTERNDEF  C   SwapStack:PROC
 | 
						|
FspSwitchStack   PROC C PUBLIC
 | 
						|
    ; Save current contexts
 | 
						|
    push    eax
 | 
						|
    pushfd
 | 
						|
    cli
 | 
						|
    pushad
 | 
						|
    sub     esp, 8
 | 
						|
    sidt    fword ptr [esp]
 | 
						|
 | 
						|
    ; Load new stack
 | 
						|
    push    esp
 | 
						|
    call    SwapStack
 | 
						|
    mov     esp, eax
 | 
						|
 | 
						|
    ; Restore previous contexts
 | 
						|
    lidt    fword ptr [esp]
 | 
						|
    add     esp, 8
 | 
						|
    popad
 | 
						|
    popfd
 | 
						|
    add     esp, 4
 | 
						|
    ret
 | 
						|
FspSwitchStack   ENDP
 | 
						|
 | 
						|
    END
 |