The fix is for EFI Linux capsule test case can not run.

It should use runtime library EfiSetVariable, gRT is not converted to virtual address which cause SetVariable failure in EFI Linux.

git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@9986 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
li-elvin 2010-02-11 06:27:18 +00:00
parent 97c74782a6
commit b3b1a4cfa9
1 changed files with 9 additions and 9 deletions

View File

@ -4,7 +4,7 @@
It installs the Capsule Architectural Protocol defined in PI1.0a to signify It installs the Capsule Architectural Protocol defined in PI1.0a to signify
the capsule runtime services are ready. the capsule runtime services are ready.
Copyright (c) 2006 - 2009, Intel Corporation. <BR> Copyright (c) 2006 - 2010, Intel Corporation. <BR>
All rights reserved. This program and the accompanying materials All rights reserved. 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
@ -164,20 +164,20 @@ UpdateCapsule (
// system reset. Set its value into NV storage to let pre-boot driver to pick it up // system reset. Set its value into NV storage to let pre-boot driver to pick it up
// after coming through a system reset. // after coming through a system reset.
// //
Status = gRT->SetVariable ( Status = EfiSetVariable (
EFI_CAPSULE_VARIABLE_NAME, EFI_CAPSULE_VARIABLE_NAME,
&gEfiCapsuleVendorGuid, &gEfiCapsuleVendorGuid,
EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS, EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_BOOTSERVICE_ACCESS,
sizeof (UINTN), sizeof (UINTN),
(VOID *) &ScatterGatherList (VOID *) &ScatterGatherList
); );
if (!EFI_ERROR (Status) && InitiateReset) { if (!EFI_ERROR (Status) && InitiateReset) {
// //
// Firmware that encounters a capsule which has the CAPSULE_FLAGS_INITIATE_RESET Flag set in its header // Firmware that encounters a capsule which has the CAPSULE_FLAGS_INITIATE_RESET Flag set in its header
// will initiate a reset of the platform which is compatible with the passed-in capsule request and will // will initiate a reset of the platform which is compatible with the passed-in capsule request and will
// not return back to the caller. // not return back to the caller.
// //
gRT->ResetSystem (EfiResetWarm, EFI_SUCCESS, 0, NULL); EfiResetSystem (EfiResetWarm, EFI_SUCCESS, 0, NULL);
} }
return Status; return Status;
} }