summaryrefslogtreecommitdiff
path: root/ArmPkg/Include
diff options
context:
space:
mode:
authoroliviermartin <oliviermartin@6f19259b-4bc3-4df7-8a09-765794883524>2013-03-06 00:01:49 +0000
committeroliviermartin <oliviermartin@6f19259b-4bc3-4df7-8a09-765794883524>2013-03-06 00:01:49 +0000
commit166c01fbc239d28f0d6363164a2a589b36aec958 (patch)
tree242f09cca53e6e24fea793007c2027b0dd7d5ee4 /ArmPkg/Include
parent28929e20d449b534c41ff1573f003062900a2a54 (diff)
downloadedk2-platforms-166c01fbc239d28f0d6363164a2a589b36aec958.tar.xz
ArmPkg: Move ArmSmcLib from ArmPlatformLib to ArmPkg
A ArmSmcLib Null implementation has also been added for CPU without the ARM Security Extension (Trustzone support). Signed-off-by: Olivier Martin <olivier.martin@arm.com> git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@14164 6f19259b-4bc3-4df7-8a09-765794883524
Diffstat (limited to 'ArmPkg/Include')
-rw-r--r--ArmPkg/Include/Library/ArmSmcLib.h44
1 files changed, 44 insertions, 0 deletions
diff --git a/ArmPkg/Include/Library/ArmSmcLib.h b/ArmPkg/Include/Library/ArmSmcLib.h
new file mode 100644
index 0000000000..ff946f2dea
--- /dev/null
+++ b/ArmPkg/Include/Library/ArmSmcLib.h
@@ -0,0 +1,44 @@
+/** @file
+*
+* Copyright (c) 2012, ARM Limited. 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.
+*
+**/
+
+#ifndef __ARM_SMC_LIB__
+#define __ARM_SMC_LIB__
+
+VOID
+ArmCallSmc (
+ IN OUT UINTN *Rx
+ );
+
+VOID
+ArmCallSmcArg1 (
+ IN OUT UINTN *Rx,
+ IN OUT UINTN *Arg1
+ );
+
+VOID
+ArmCallSmcArg2 (
+ IN OUT UINTN *Rx,
+ IN OUT UINTN *Arg1,
+ IN OUT UINTN *Arg2
+ );
+
+VOID
+ArmCallSmcArg3 (
+ IN OUT UINTN *Rx,
+ IN OUT UINTN *Arg1,
+ IN OUT UINTN *Arg2,
+ IN OUT UINTN *Arg3
+ );
+
+#endif