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  * Okay, this file contains the code that's going to bootstrap the AP cpus
 
   34    .globl  ap_trampoline_start,ap_trampoline_end
 
   41    movw    %cs,%ax         // The CPU knows its CS already, so lets use it for the other segments
 
   46    // Do some bochs-specific bullshit
 
   51    lgdt    ap_trampoline_gdt_limit - ap_trampoline_start
 
   54    movl    %eax,%cr0       // PMODE!
 
   58    ljmp    $0x08,$(ap_trampoline_32 - ap_trampoline_start)         // 0x08 == KERNEL_CS
 
   73    mov     ap_trampoline_spl - ap_trampoline_start,%edi
 
   78    mov     $1,%eax      // Value to be set
 
   88    mov     ap_trampoline_stackptr - ap_trampoline_start,%ebx
 
   91    mov     %ebx,ap_trampoline_stackptr - ap_trampoline_start
 
   99    mov     ap_trampoline_spl - ap_trampoline_start,%edi
 
  107    mov     ap_trampoline_epoint,%eax
 
  111    jmp     1b              // Halt if we ever get here somehow
 
  113    // Stack.. This sucks, since CPU initialization isn't serialized
 
  114 ap_trampoline_stackptr:
 
  115    .long   0x10000         // 256KB
 
  116 ap_trampoline_epoint:
 
  127 ap_trampoline_gdt_limit:
 
  128    .word   128     // Room for 32 descriptors
 
  129 ap_trampoline_gdt_base:
 
  130    .long   0x20000         // 128KB (move this later)