87 Commits (601d0f85bde9200af72d66ef7e0e5916b1af1d6f)

Author SHA1 Message Date
WangRunji 601d0f85bd Add an event system in the Processor. Can sleep and wakeup.
7 years ago
WangRunji 0f26f6ffd6 Basic EventHub and Timer.
7 years ago
WangRunji 950fe4fedc Use crate `log`. Print with color in console.
7 years ago
WangRunji 731d6319e4 Can load user programs from sfs.img (hard linked).
7 years ago
WangRunji 5a1dc423e0 Shared memory & Copy on write !
7 years ago
WangRunji 4d6925a562 Fork (not finished). Not depend on boot_info after remap_kernel.
7 years ago
WangRunji 678d1d2b54 Some tiny changes
7 years ago
WangRunji 7cdfb9e6e2 Basic syscall
7 years ago
WangRunji 40b02c33cb Switch page table for user process
7 years ago
WangRunji 8ce3173c3d Link a user program from xv6-x86_64 in. Add elf crate.
7 years ago
WangRunji 0553d3374d Can switch between `init` and `idle` process
7 years ago
WangRunji 4f18f70e19 Can switch between ring0 and ring 3. Fix IDT bugs.
7 years ago
WangRunji 7d28231f1b Can run into another kernel thread
7 years ago
WangRunji 5d857c38eb Let struct Stack own the stack, panic on Drop. Add a little process mod.
7 years ago
WangRunji 0539f8673e Rewrite interrupt handlers using Redox style. Prepare for saving context.
7 years ago
WangRunji 69f6f4070e Add IRQ handler for ToUser, ToKernel, GPF, Syscall.
7 years ago
WangRunji cb19bc5464 Start AP one by one. Fix deadlock.
7 years ago
WangRunji 2b813b2acc Set CPU num to 4. Init lapic for each. TODO: fix deadlock.
7 years ago
WangRunji f6df3c412c Now CPU1 can handle interrupt. Alloc TSS & GDT & IDT at kernel heap.
7 years ago
WangRunji 3e9ee46850 Now CPU1 can enter Rust. Change kernel guard page.
7 years ago
WangRunji 8a8aff8917 Copy start_ap to lapic.c . Simple startothers(). Try to boot AP but failed.
7 years ago
WangRunji 038867921e Move device init to arch mod
7 years ago
WangRunji 01c0c3b2ad Move IDT & GDT to arch, as Redox did.
7 years ago
WangRunji 77703442e7 Move `paging` mod to `arch`, as Redox did.
7 years ago
WangRunji 5b91db9d76 Move interrupt mod
7 years ago
WangRunji d330bd8224 Merge branch 'dev' into move-kernel-va
7 years ago
WangRunji cea8ccdac9 Recover IDT, using Once<>
7 years ago
WangRunji 230d5a0287 Move remap_the_kernel() out of `paging` mod. Add page fault handler.
7 years ago
WangRunji 9b4d9a4a1f Init IDT at beginning
7 years ago
WangRunji 3b792baf5b ACK for APIC IRQ
7 years ago
WangRunji 156034c3d1 Support timer IRQ from PIC
7 years ago
WangRunji 8af7220d25 Disable PIC
7 years ago
WangRunji cf099ffa99 Make inits 'safe'
7 years ago
WangRunji 15b1687ac6 Complete IOAPIC init
7 years ago
WangRunji a76bfbc7f8 Copy PIC mod from Redox
7 years ago
WangRunji ab37e359ac Temporarily map pages and run pass APIC init.
7 years ago
WangRunji 03d4adfcfe Fix rsp. Use PhysicalAddress.
7 years ago
WangRunji 21d97418d6 Impl lapic linking C code. Fix build.rs in macOS.
7 years ago
WangRunji 5c80d903ad Finish ACPI init
7 years ago
WangRunji 8c7ca612e7 Add example of binding C
7 years ago
WangRunji c446d2bb5e Add test for travis
7 years ago
WangRunji e9d89576a3 Port acpiinit()
7 years ago
WangRunji 936c485ab9 Port MP & RSDP detecting
7 years ago
WangRunji 5bf407de7c Split vga_buffer.rs to VGA driver and VGA writer
7 years ago
WangRunji c436b9afbe Move asm to boot dir. Continue to refactor...
7 years ago
WangRunji 4ce1ba8f6d Rewrite README. Add docker.
7 years ago
Philipp Oppermann f651987666 Add a dependency on bit_field
8 years ago
Philipp Oppermann 00bbd6fbc6 Pass the memory controller to interrupts::init and use it to create a double fault stack
8 years ago
Philipp Oppermann 3efe54169e Provoke a stack overflow, which still causes a boot loop
8 years ago
Philipp Oppermann 91ffde4728 Trigger a double fault by causing a page fault
8 years ago