]> git.proxmox.com Git - mirror_edk2.git/blobdiff - MdePkg/Library/BaseLib/Ia32/SetJump.S
Update the copyright notice format
[mirror_edk2.git] / MdePkg / Library / BaseLib / Ia32 / SetJump.S
index 05acc4ab2620fb7b7cdff8cd7e19e859d695da3c..5084bc5010170b5cdc96cf50d250f662f9b96432 100644 (file)
@@ -1,7 +1,7 @@
 #------------------------------------------------------------------------------\r
 #\r
-# Copyright (c) 2006, Intel Corporation\r
-# All rights reserved. This program and the accompanying materials\r
+# Copyright (c) 2006 - 2008, Intel Corporation. All rights reserved.<BR>\r
+# This program and the accompanying materials\r
 # are licensed and made available under the terms and conditions of the BSD License\r
 # which accompanies this distribution.  The full text of the license may be found at\r
 # http://opensource.org/licenses/bsd-license.php\r
@@ -11,7 +11,7 @@
 #\r
 # Module Name:\r
 #\r
-#   SetJump.Asm\r
+#   SetJump.S\r
 #\r
 # Abstract:\r
 #\r
 #\r
 #------------------------------------------------------------------------------\r
 \r
+ASM_GLOBAL ASM_PFX(SetJump), ASM_PFX(InternalAssertJumpBuffer)\r
 \r
-\r
-     \r
-\r
-.global _SetJump, _InternalAssertJumpBuffer\r
-_SetJump: \r
+#------------------------------------------------------------------------------\r
+# UINTN\r
+# EFIAPI\r
+# SetJump (\r
+#   OUT     BASE_LIBRARY_JUMP_BUFFER  *JumpBuffer\r
+#   );\r
+#------------------------------------------------------------------------------\r
+ASM_PFX(SetJump):\r
     pushl   0x4(%esp)\r
-    call    _InternalAssertJumpBuffer\r
-    popl    %ecx\r
-    popl    %ecx\r
-    movl    (%esp),%edx\r
-    movl    %ebx,(%edx)\r
-    movl    %esi,4(%edx)\r
-    movl    %edi,8(%edx)\r
-    movl    %ebp,12(%edx)\r
-    movl    %esp,16(%edx)\r
-    movl    %ecx,20(%edx)\r
-    xorl    %eax,%eax\r
+    call    ASM_PFX(InternalAssertJumpBuffer)               # To validate JumpBuffer\r
+    pop     %ecx\r
+    pop     %ecx                                            # ecx <- return address\r
+    movl    (%esp), %edx\r
+    movl    %ebx, (%edx)\r
+    movl    %esi, 4(%edx)\r
+    movl    %edi, 8(%edx)\r
+    movl    %ebp, 12(%edx)\r
+    movl    %esp, 16(%edx)\r
+    movl    %ecx, 20(%edx)                                  # eip value to restore in LongJump\r
+    xorl    %eax, %eax\r
     jmp     *%ecx\r
-\r
-\r
-\r