]>
Commit | Line | Data |
---|---|---|
f1baef62 | 1 | ;------------------------------------------------------------------------------\r |
2 | ;\r | |
bb817c56 HT |
3 | ; Copyright (c) 2006 - 2008, Intel Corporation. All rights reserved.<BR>\r |
4 | ; This program and the accompanying materials\r | |
f1baef62 | 5 | ; are licensed and made available under the terms and conditions of the BSD License\r |
6 | ; which accompanies this distribution. The full text of the license may be found at\r | |
2fc59a00 | 7 | ; http://opensource.org/licenses/bsd-license.php.\r |
f1baef62 | 8 | ;\r |
9 | ; THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r | |
10 | ; WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r | |
11 | ;\r | |
12 | ; Module Name:\r | |
13 | ;\r | |
14 | ; SwitchStack.Asm\r | |
15 | ;\r | |
16 | ; Abstract:\r | |
17 | ;\r | |
18 | ;------------------------------------------------------------------------------\r | |
19 | \r | |
20 | .code\r | |
21 | \r | |
22 | ;------------------------------------------------------------------------------\r | |
23 | ; Routine Description:\r | |
24 | ;\r | |
d2e6d788 | 25 | ; Routine for switching stacks with 2 parameters\r |
f1baef62 | 26 | ;\r |
27 | ; Arguments:\r | |
28 | ;\r | |
29 | ; (rcx) EntryPoint - Entry point with new stack.\r | |
d2e6d788 | 30 | ; (rdx) Context1 - Parameter1 for entry point.\r |
f1baef62 | 31 | ; (r8) Context2 - Parameter2 for entry point.\r |
2fc59a00 | 32 | ; (r9) NewStack - The pointer to new stack.\r |
f1baef62 | 33 | ;\r |
34 | ; Returns:\r | |
35 | ;\r | |
36 | ; None\r | |
37 | ;\r | |
38 | ;------------------------------------------------------------------------------\r | |
39 | InternalSwitchStack PROC\r | |
40 | mov rax, rcx\r | |
41 | mov rcx, rdx\r | |
42 | mov rdx, r8\r | |
d2e6d788 | 43 | ;\r |
44 | ; Reserve space for register parameters (rcx, rdx, r8 & r9) on the stack,\r | |
45 | ; in case the callee wishes to spill them.\r | |
46 | ;\r | |
f1baef62 | 47 | lea rsp, [r9 - 20h]\r |
48 | call rax\r | |
49 | InternalSwitchStack ENDP\r | |
50 | \r | |
51 | END\r |