2  * Copyright (c) 2002-2018 The UbixOS Project.
 
    5  * This was developed by Christopher W. Olsen for the UbixOS Project.
 
    7  * Redistribution and use in source and binary forms, with or without modification, are permitted
 
    8  * provided that the following conditions are met:
 
   10  * 1) Redistributions of source code must retain the above copyright notice, this list of
 
   11  *    conditions, the following disclaimer and the list of authors.
 
   12  * 2) Redistributions in binary form must reproduce the above copyright notice, this list of
 
   13  *    conditions, the following disclaimer and the list of authors in the documentation and/or
 
   14  *    other materials provided with the distribution.
 
   15  * 3) Neither the name of the UbixOS Project nor the names of its contributors may be used to
 
   16  *    endorse or promote products derived from this software without specific prior written
 
   19  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED
 
   20  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
 
   21  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
 
   22  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 
   23  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
 
   24  * OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 
   25  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
 
   26  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 
   30  Page fault wrapper this will aquire some values we need for later use
 
   33 .globl _vmm_pageFault2
 
   37 xchgl %eax,(%esp) /* Save EAX                                         */
 
   38 movl 4(%esp),%eax /* Move EIP into EAX to use later                   */
 
   39 pushl %ebx /* Save EBX                                         */
 
   40 movl 20(%esp),%ebx /* Save ESP for ring 3 to use later                 */
 
   41 pushl %ecx /* Save ECX,EDX                                     */
 
   43 push %ebx /* Push ESP                                         */
 
   44 push %eax /* Push EIP                                         */
 
   45 movl %cr2,%eax /* Push the faulted address                         */
 
   47 sti /* Turn interrupts back on we are now entrant safe  */
 
   48 call vmm_pageFault /* Call our page fault handler                      */
 
   49 addl $0xC,%esp /* Adjust the stack to compensate for pushed values */
 
   50 popl %edx /* Restore EAX,EBX,ECX,EDX                          */
 
   54 iret /* Return from the interrupt                        */
 
   90 testl $0x2000,0x3c(%esp) /* Test If VM */
 
   94 testb $0x3,0x38(%esp) /* See If We're In User CS (GDT Entry 5) */
 
   98 testl $0x10800,0x80(%eax) /* Document This */