;------------------------------------------------------------------------------ ; ; Copyright (c) 2010 - 2012, 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: ; ; PageFaultHandler.asm ; ; Abstract: ; ; Defines page fault handler used to hook SMM IDT ; ;------------------------------------------------------------------------------ EXTERN mOriginalHandler:QWORD EXTERN PageFaultHandler:PROC .code PageFaultHandlerHook PROC push rax ; save all volatile registers push rcx push rdx push r8 push r9 push r10 push r11 add rsp, -10h * 6 - 8 ; reserve memory to store XMM registers and make address 16-byte alignment movdqa [rsp], xmm0 movdqa [rsp + 10h], xmm1 movdqa [rsp + 20h], xmm2 movdqa [rsp + 30h], xmm3 movdqa [rsp + 40h], xmm4 movdqa [rsp + 50h], xmm5 add rsp, -20h call PageFaultHandler add rsp, 20h movdqa xmm0, [rsp] movdqa xmm1, [rsp + 10h] movdqa xmm2, [rsp + 20h] movdqa xmm3, [rsp + 30h] movdqa xmm4, [rsp + 40h] movdqa xmm5, [rsp + 50h] add rsp, 10h * 6 + 8 test al, al ; set ZF flag pop r11 pop r10 pop r9 pop r8 pop rdx pop rcx pop rax ; restore all volatile registers jnz @F ; check ZF flag jmp mOriginalHandler @@: add rsp, 08h ; skip error code for PF iretq PageFaultHandlerHook ENDP END