UefiCpuPkg VTF0: Fix support for finding SEC image of type TE.

Update Flat32SearchForSecEntryPoint assembly code to support finding an SEC image using the TE image format.

Signed-off-by: rsun3
Reviewed-by: jljusten


git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@12462 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
rsun3 2011-09-28 01:36:33 +00:00
parent 19a7404aec
commit f7bb98019a
7 changed files with 23 additions and 19 deletions

View File

@ -2,7 +2,7 @@
; @file ; @file
; Search for the SEC Core entry point ; Search for the SEC Core entry point
; ;
; Copyright (c) 2008 - 2009, Intel Corporation. All rights reserved.<BR> ; Copyright (c) 2008 - 2011, Intel Corporation. All rights reserved.<BR>
; This program and the accompanying materials ; This program and the accompanying materials
; are licensed and made available under the terms and conditions of the BSD License ; 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 ; which accompanies this distribution. The full text of the license may be found at
@ -115,6 +115,7 @@ secCoreEntryPointWasFound:
OneTimeCallRet Flat32SearchForSecEntryPoint OneTimeCallRet Flat32SearchForSecEntryPoint
%define EFI_SECTION_PE32 0x10 %define EFI_SECTION_PE32 0x10
%define EFI_SECTION_TE 0x12
; ;
; Input: ; Input:
@ -139,8 +140,11 @@ getEntryPointOfFfsFileLoopForSections:
cmp byte [eax + 3], EFI_SECTION_PE32 cmp byte [eax + 3], EFI_SECTION_PE32
je getEntryPointOfFfsFileFoundPe32Section je getEntryPointOfFfsFileFoundPe32Section
cmp byte [eax + 3], EFI_SECTION_TE
je getEntryPointOfFfsFileFoundTeSection
; ;
; The section type was not PE32, so move to next section ; The section type was not PE32 or TE, so move to next section
; ;
mov ebx, dword [eax] mov ebx, dword [eax]
and ebx, 0x00ffffff and ebx, 0x00ffffff
@ -158,26 +162,10 @@ getEntryPointOfFfsFileLoopForSections:
getEntryPointOfFfsFileFoundPe32Section: getEntryPointOfFfsFileFoundPe32Section:
add eax, 4 ; EAX = Start of PE32 image add eax, 4 ; EAX = Start of PE32 image
mov ebx, eax
cmp word [eax], 'MZ' cmp word [eax], 'MZ'
jne thereIsNotAnMzSignature jne getEntryPointOfFfsFileErrorReturn
movzx ebx, word [eax + 0x3c] movzx ebx, word [eax + 0x3c]
add ebx, eax add ebx, eax
thereIsNotAnMzSignature:
; if (Hdr.Te->Signature == EFI_TE_IMAGE_HEADER_SIGNATURE)
cmp word [ebx], 'VZ'
jne thereIsNoVzSignature
; *EntryPoint = (VOID *)((UINTN)Pe32Data +
; (UINTN)(Hdr.Te->AddressOfEntryPoint & 0x0ffffffff) +
; sizeof(EFI_TE_IMAGE_HEADER) - Hdr.Te->StrippedSize);
add eax, [ebx + 0x8]
add eax, 0x28
movzx ebx, word [ebx + 0x6]
sub eax, ebx
jmp getEntryPointOfFfsFileReturn
thereIsNoVzSignature:
; if (Hdr.Pe32->Signature == EFI_IMAGE_NT_SIGNATURE) ; if (Hdr.Pe32->Signature == EFI_IMAGE_NT_SIGNATURE)
cmp dword [ebx], `PE\x00\x00` cmp dword [ebx], `PE\x00\x00`
@ -188,6 +176,22 @@ thereIsNoVzSignature:
add eax, [ebx + 0x4 + 0x14 + 0x10] add eax, [ebx + 0x4 + 0x14 + 0x10]
jmp getEntryPointOfFfsFileReturn jmp getEntryPointOfFfsFileReturn
getEntryPointOfFfsFileFoundTeSection:
add eax, 4 ; EAX = Start of TE image
mov ebx, eax
; if (Hdr.Te->Signature == EFI_TE_IMAGE_HEADER_SIGNATURE)
cmp word [ebx], 'VZ'
jne getEntryPointOfFfsFileErrorReturn
; *EntryPoint = (VOID *)((UINTN)Pe32Data +
; (UINTN)(Hdr.Te->AddressOfEntryPoint & 0x0ffffffff) +
; sizeof(EFI_TE_IMAGE_HEADER) - Hdr.Te->StrippedSize);
add eax, [ebx + 0x8]
add eax, 0x28
movzx ebx, word [ebx + 0x6]
sub eax, ebx
jmp getEntryPointOfFfsFileReturn
getEntryPointOfFfsFileErrorReturn: getEntryPointOfFfsFileErrorReturn:
mov eax, 0 mov eax, 0