mirror of https://github.com/acidanthera/audk.git
edk2/MdePkg/Library/BaseLib/BaseLib.inf:
edk2/MdePkg/Library/BaseLib/Ipf/AsmCpuMisc.s: * Add GCC IPF implementation of CpuBreakpoint, MemoryFence, DisableInterrupts, EnableInterrupts, and EnableDisableInterrupts. (Thanks Vara!) git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@5701 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
d4775f2a4c
commit
44f5e74f28
|
@ -568,6 +568,7 @@
|
||||||
ChkStkGcc.c | GCC
|
ChkStkGcc.c | GCC
|
||||||
|
|
||||||
[Sources.IPF]
|
[Sources.IPF]
|
||||||
|
Ipf/AsmCpuMisc.s
|
||||||
Ipf/AccessGp.s
|
Ipf/AccessGp.s
|
||||||
Ipf/ReadCpuid.s
|
Ipf/ReadCpuid.s
|
||||||
Ipf/ExecFc.s
|
Ipf/ExecFc.s
|
||||||
|
|
|
@ -0,0 +1,79 @@
|
||||||
|
/// @file
|
||||||
|
/// Contains an implementation of CallPalProcStacked on Itanium-based
|
||||||
|
/// architecture.
|
||||||
|
///
|
||||||
|
/// Copyright (c) 2008, 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: AsmCpuMisc.s
|
||||||
|
///
|
||||||
|
///
|
||||||
|
|
||||||
|
|
||||||
|
.text
|
||||||
|
.proc CpuBreakpoint
|
||||||
|
.type CpuBreakpoint, @function
|
||||||
|
|
||||||
|
CpuBreakpoint::
|
||||||
|
break.i 0;;
|
||||||
|
br.ret.dpnt b0;;
|
||||||
|
|
||||||
|
.endp CpuBreakpoint
|
||||||
|
|
||||||
|
.proc MemoryFence
|
||||||
|
.type MemoryFence, @function
|
||||||
|
|
||||||
|
MemoryFence::
|
||||||
|
mf;; // memory access ordering
|
||||||
|
|
||||||
|
// do we need the mf.a also here?
|
||||||
|
mf.a // wait for any IO to complete?
|
||||||
|
|
||||||
|
// not sure if we need serialization here, just put it, in case...
|
||||||
|
|
||||||
|
srlz.d;;
|
||||||
|
srlz.i;;
|
||||||
|
|
||||||
|
br.ret.dpnt b0;;
|
||||||
|
.endp MemoryFence
|
||||||
|
|
||||||
|
.proc DisableInterrupts
|
||||||
|
.type DisableInterrupts, @function
|
||||||
|
|
||||||
|
DisableInterrupts::
|
||||||
|
rsm 0x4000
|
||||||
|
srlz.d;;
|
||||||
|
br.ret.dpnt b0;;
|
||||||
|
|
||||||
|
.endp DisableInterrupts
|
||||||
|
|
||||||
|
.proc EnableInterrupts
|
||||||
|
.type EnableInterrupts, @function
|
||||||
|
|
||||||
|
EnableInterrupts::
|
||||||
|
ssm 0x4000
|
||||||
|
srlz.d;;
|
||||||
|
br.ret.dpnt b0;;
|
||||||
|
|
||||||
|
.endp EnableInterrupts
|
||||||
|
|
||||||
|
.proc EnableDisableInterrupts
|
||||||
|
.type EnableDisableInterrupts, @function
|
||||||
|
|
||||||
|
EnableDisableInterrupts::
|
||||||
|
ssm 0x4000
|
||||||
|
srlz.d;;
|
||||||
|
srlz.i;;
|
||||||
|
rsm 0x4000
|
||||||
|
srlz.d;;
|
||||||
|
|
||||||
|
br.ret.dpnt b0;;
|
||||||
|
|
||||||
|
.endp EnableDisableInterrupts
|
||||||
|
|
Loading…
Reference in New Issue