]> rtime.felk.cvut.cz Git - l4.git/blob - kernel/fiasco/src/kern/ux/startup.cpp
cd7ec7bb4c58e47ec3ed479f2ec13d6088f46d10
[l4.git] / kernel / fiasco / src / kern / ux / startup.cpp
1 IMPLEMENTATION:
2
3 #include "banner.h"
4 #include "boot_info.h"
5 #include "config.h"
6 #include "cpu.h"
7 #include "dirq_pic_pin.h"
8 #include "fb.h"
9 #include "fpu.h"
10 #include "idt.h"
11 #include "initcalls.h"
12 #include "jdb.h"
13 #include "kernel_task.h"
14 #include "kip_init.h"
15 #include "kmem.h"
16 #include "kmem_alloc.h"
17 #include "net.h"
18 #include "per_cpu_data.h"
19 #include "per_cpu_data_alloc.h"
20 #include "pic.h"
21 #include "static_init.h"
22 #include "timer.h"
23 #include "usermode.h"
24 #include "utcb_init.h"
25 #include "vmem_alloc.h"
26
27 STATIC_INITIALIZER_P(startup_system1, UX_STARTUP1_INIT_PRIO);
28 STATIC_INITIALIZER_P(startup_system2, STARTUP_INIT_PRIO);
29
30 static void FIASCO_INIT
31 startup_system1()
32 {
33   Usermode::init(0);
34   Boot_info::init();
35   Config::init();
36 }
37
38 static void FIASCO_INIT
39 startup_system2()
40 {
41   Banner::init();
42   Kip_init::setup_ux();
43   Kmem_alloc::base_init();
44   Kip_init::init();
45   Kmem_alloc::init();
46
47   // Initialize cpu-local data management and run constructors for CPU 0
48   Per_cpu_data::init_ctors(Kmem_alloc::allocator());
49   Per_cpu_data_alloc::alloc(0);
50   Per_cpu_data::run_ctors(0);
51
52   Kmem::init_mmu(*Cpu::boot_cpu());
53   Kernel_task::init();          // enables current_mem_space()
54   Kip_init::init_freq(*Cpu::boot_cpu());
55
56   // must copy the KIP to allocated phys memory, because user apps cannot
57   // access the kernel image memory
58   Kip *kip = (Kip*)Kmem_alloc::allocator()->alloc(Config::PAGE_SHIFT);
59   memcpy(kip, Kip::k(), Config::PAGE_SIZE);
60   Kip::init_global_kip(kip);
61
62   Vmem_alloc::init();
63   Utcb_init::init();
64   Pic::init();
65   Dirq_pic_pin::init();
66   Ipi::cpu(0).init();
67   Idt::init();
68   Fpu::init(0);
69   Timer::init();
70   Fb::init();
71   Net::init();
72   Cpu::init_global_features();
73 }