Files
system76-edk2/MdeModulePkg/Core/Pei/Ipf/SwitchStack.s
klu2 5aae0aa7d8 PI Enable:
1) The entry point of PeiCore has been changed to EFI_PEI_CORE_ENTRY_POINT defined in PI. 
2) Nt32, Tiger and lakeport platform's SecCore has been updated.
3) Autogen tools also has been updated.

git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@3804 6f19259b-4bc3-4df7-8a09-765794883524
2007-09-12 09:52:37 +00:00

53 lines
1.6 KiB
ArmAsm

/// @file
/// IPF specific SwitchStack() function
///
/// Copyright (c) 2006, Intel Corporation
/// All rights reserved. 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.
///
/// Module Name: SwitchStack.s
///
///
.auto
.text
.proc IpfAsmSwitchStack
.type IpfAsmSwitchStack, @function
.regstk 6, 0, 0, 0
IpfAsmSwitchStack::
mov r14 = ar.rsc
movl r2 = ~((((1 << 14) - 1) << 16) | 3)
mov r17 = in1
mov r18 = in2
mov r19 = in3
and r2 = r14, r2
mov ar.rsc = r2
mov sp = in4
mov r20 = in5
ld8.nt1 r16 = [in0], 8
ld8.nta gp = [in0]
mov r3 = -1
loadrs
mov ar.bspstore = r20
mov b7 = r16
alloc r2 = ar.pfs, 0, 0, 3, 0
mov out0 = r17
mov out1 = r18
mov out2 = r19
mov ar.rnat = r3
mov ar.rsc = r14
br.call.sptk.many b0 = b7
.endp IpfAsmSwitchStack