1
0
mirror of https://github.com/rcore-os/rCore.git synced 2024-11-23 08:26:17 +04:00
Commit Graph

201 Commits

Author SHA1 Message Date
WangRunji
6c135bca24 Refactor interrupt mod and add some docs 2018-05-21 16:05:36 +08:00
WangRunji
f7bdfa2913 Generate vector.asm by build.rs. 2018-05-20 23:56:41 +08:00
WangRunji
ffb7e194f9 Fix set TSS in SMP 2018-05-20 22:12:18 +08:00
WangRunji
2f71eab39b Use x86_64 IDT again 2018-05-20 21:09:31 +08:00
WangRunji
f35d74c734 Huge refactor for interrupt. 2018-05-20 19:15:01 +08:00
WangRunji
4e35b927d2 Yield. Shorter schedule interval. 2018-05-20 17:14:05 +08:00
WangRunji
601d0f85bd Add an event system in the Processor. Can sleep and wakeup. 2018-05-20 15:37:48 +08:00
WangRunji
c02c82cbd6 Fix a lot of bugs by adding an instruction. 2018-05-20 15:34:13 +08:00
WangRunji
0f26f6ffd6 Basic EventHub and Timer. 2018-05-20 00:22:52 +08:00
WangRunji
950fe4fedc Use crate log. Print with color in console. 2018-05-19 18:42:08 +08:00
WangRunji
d798c8084a Pass uCore forktest 2018-05-19 16:32:18 +08:00
WangRunji
731d6319e4 Can load user programs from sfs.img (hard linked). 2018-05-18 11:49:27 +08:00
WangRunji
893658baf8 uCore hello is available! 2018-05-17 22:19:15 +08:00
WangRunji
8c64b2abb2 uCore 32bit user program is runnable! 2018-05-17 21:06:13 +08:00
WangRunji
5a1dc423e0 Shared memory & Copy on write ! 2018-05-14 22:55:49 +08:00
WangRunji
4d6925a562 Fork (not finished). Not depend on boot_info after remap_kernel. 2018-05-13 21:13:57 +08:00
WangRunji
678d1d2b54 Some tiny changes 2018-05-13 15:06:44 +08:00
WangRunji
7cdfb9e6e2 Basic syscall 2018-05-13 03:41:41 +08:00
WangRunji
09147732bc Fix user stack. Make MemoryArea fields private. 2018-05-13 02:30:26 +08:00
WangRunji
b885b7ce6a Fix check for MemorySet. Fix copy user program. 2018-05-13 01:57:49 +08:00
WangRunji
9723d7c1a3 Add Invalid Opcode handler. Set rsp when going to user. 2018-05-13 01:36:16 +08:00
WangRunji
40b02c33cb Switch page table for user process 2018-05-13 00:47:16 +08:00
WangRunji
369f3183a3 Ready for running user process. TODO: switch page table 2018-05-12 22:57:30 +08:00
WangRunji
82739d3d3d Update crate multiboot2 to 0.5 . Get section's name. 2018-05-12 12:05:01 +08:00
WangRunji
dff2c4d1be Refactor remap_the_kernel using MemorySet 2018-05-12 11:45:31 +08:00
WangRunji
5714df7c39 Remove temporary_page from function args 2018-05-12 00:22:00 +08:00
WangRunji
5075abc5b0 Make FrameAllocator global! 2018-04-28 17:47:17 +08:00
WangRunji
5707dfd00a Merge branch 'memory' into process
# Conflicts:
#	src/arch/x86_64/smp.rs
#	src/memory/mod.rs
2018-04-28 13:32:46 +08:00
WangRunji
62cb97de8c Fit name conventions by Clion, simplify some names. 2018-04-28 13:32:16 +08:00
WangRunji
8ce3173c3d Link a user program from xv6-x86_64 in. Add elf crate. 2018-04-28 10:40:31 +08:00
WangRunji
6e157ee97d Split process mod. Move TrapFrame operation to arch. 2018-04-27 23:10:39 +08:00
WangRunji
0553d3374d Can switch between init and idle process 2018-04-27 21:49:01 +08:00
WangRunji
4f18f70e19 Can switch between ring0 and ring 3. Fix IDT bugs. 2018-04-27 16:32:57 +08:00
WangRunji
7d28231f1b Can run into another kernel thread 2018-04-27 00:03:24 +08:00
WangRunji
5d857c38eb Let struct Stack own the stack, panic on Drop. Add a little process mod. 2018-04-26 21:53:20 +08:00
WangRunji
0539f8673e Rewrite interrupt handlers using Redox style. Prepare for saving context. 2018-04-26 01:00:32 +08:00
WangRunji
69f6f4070e Add IRQ handler for ToUser, ToKernel, GPF, Syscall.
Now trigger ToUser interrupt will cause GPF.
2018-04-18 21:53:39 +08:00
WangRunji
cb19bc5464 Start AP one by one. Fix deadlock. 2018-04-18 15:22:06 +08:00
WangRunji
2b813b2acc Set CPU num to 4. Init lapic for each. TODO: fix deadlock. 2018-04-18 14:55:09 +08:00
WangRunji
f6df3c412c Now CPU1 can handle interrupt. Alloc TSS & GDT & IDT at kernel heap. 2018-04-18 14:26:34 +08:00
WangRunji
3e9ee46850 Now CPU1 can enter Rust. Change kernel guard page.
CPU1 is sharing page table with CPU0
2018-04-18 12:26:21 +08:00
WangRunji
1e293763bc Fix loading entryother. Now CPU1 can print OK. 2018-04-18 10:23:00 +08:00
WangRunji
8a8aff8917 Copy start_ap to lapic.c . Simple startothers(). Try to boot AP but failed. 2018-04-18 01:56:54 +08:00
WangRunji
cc34857482 Copy entrystart.S from xv6 x86_64, translate it to nasm, link @ 0x7000. 2018-04-18 00:07:43 +08:00
WangRunji
491f9d0d4a PIT working 2018-04-17 21:34:36 +08:00
WangRunji
7b3b59bf1e Update crate bitflags to 1.0 2018-04-17 20:55:12 +08:00
WangRunji
fa2e9866de Keyboard working. Link C code from xv6 x86_64. 2018-04-17 20:13:28 +08:00
WangRunji
df58911ac4 COM2. Merge APIC/PIC interface. 2018-04-17 19:42:58 +08:00
WangRunji
57fabda398 Copy serial mod from Redox. Now serial interrupt is working. 2018-04-17 15:57:34 +08:00
WangRunji
038867921e Move device init to arch mod 2018-04-17 15:32:53 +08:00