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)