equation314
|
a59a7fbe9a
|
aarch64/mmu: simply handle page fault
|
2018-12-01 20:00:35 +08:00 |
|
equation314
|
d6a54496f0
|
arch64/mmu: invalidate all icaches in InactivePageTable::with()
|
2018-12-01 19:43:58 +08:00 |
|
equation314
|
0eb33b661f
|
aarch64/mmu: fix some bugs
|
2018-12-01 19:31:46 +08:00 |
|
WangRunji
|
210854971d
|
add travis for macOS
|
2018-12-01 19:14:51 +08:00 |
|
WangRunji
|
1f305a883c
|
add travis for riscv32 M-mode
|
2018-12-01 17:47:02 +08:00 |
|
WangRunji
|
fcf5074500
|
impl M-mode kernel for riscv32
|
2018-12-01 17:37:37 +08:00 |
|
WangRunji
|
2f8cfabbca
|
remove redundant nightly features
|
2018-11-29 22:00:35 +08:00 |
|
WangRunji
|
a74b893bd2
|
update Makefile
|
2018-11-29 21:39:43 +08:00 |
|
equation314
|
f882a085d6
|
user: link created SFS image in kernel
|
2018-11-29 17:33:31 +08:00 |
|
equation314
|
94bc8353f7
|
user: create SFS image in Makefile
|
2018-11-29 12:49:58 +08:00 |
|
WangRunji
|
b3a80ba571
|
update riscv-pk & README
|
2018-11-29 00:20:12 +08:00 |
|
WangRunji
|
02eb7d9125
|
update 'riscv-pk' to upstream submodule
|
2018-11-29 00:00:52 +08:00 |
|
WangRunji
|
6921e9018d
|
fix NoMMU entry point
|
2018-11-27 11:26:37 +08:00 |
|
WangRunji
|
18640b7537
|
impl NoMMU
|
2018-11-27 01:23:07 +08:00 |
|
WangRunji
|
52fe93188d
|
disable delay allocating frame, remove memory_set_record
|
2018-11-27 01:18:30 +08:00 |
|
WangRunji
|
2db453556d
|
try to fix interrupt & deadlock on RV32
|
2018-11-26 16:58:45 +08:00 |
|
equation314
|
d30c7e59ca
|
aarch64: minor modify
|
2018-11-25 20:01:13 +08:00 |
|
equation314
|
264600f145
|
aarch64/mmu: add io remap
|
2018-11-25 18:27:31 +08:00 |
|
equation314
|
a8b334123a
|
aarch64/mmu: add memory region attribute config
|
2018-11-25 17:58:17 +08:00 |
|
equation314
|
f9e47b2fd8
|
aarch64/mmu: refactor PageTableFlags
|
2018-11-25 00:29:39 +08:00 |
|
equation314
|
de6354ddd3
|
aarch64/mmu: use ASID to avoid flush TLB frequently in context switch
|
2018-11-23 23:25:15 +08:00 |
|
equation314
|
33d4b6975b
|
aarch64/mmu: use DSB instead of TLB flush after modifying PTE
|
2018-11-23 15:23:48 +08:00 |
|
equation314
|
55087fc5a2
|
aarch64/mmu: use both TTBR0_EL1 & TTBR1_EL1
|
2018-11-23 00:43:18 +08:00 |
|
WangRunji
|
46f0e85230
|
add ucore-i386-pic.img user programs. reorganize imgs.
|
2018-11-22 18:06:39 +08:00 |
|
equation314
|
bb1c1abaa4
|
aarch64/mmu: can run on the real raspi3
|
2018-11-21 20:02:34 +08:00 |
|
equation314
|
a9de99d3a9
|
aarch64/mmu: remap kernel memory ranges at the end of memory::init()
|
2018-11-21 01:50:34 +08:00 |
|
WangRunji
|
4034a473bd
|
update user crate to 2018 edition. add travis for user
|
2018-11-20 21:35:18 +08:00 |
|
equation314
|
99c5b3c3f8
|
Merge branch 'arch-aarch64' into mmu
|
2018-11-20 18:36:23 +08:00 |
|
equation314
|
13be52133d
|
aarch64: move kernel stack top to 0x100000
|
2018-11-20 18:32:26 +08:00 |
|
equation314
|
f398945ad3
|
aarch64: hard link user program
|
2018-11-20 18:29:51 +08:00 |
|
equation314
|
9e8124abbb
|
aarch64/mmu: mmu enabled
|
2018-11-20 16:46:16 +08:00 |
|
WangRunji
|
e1f93a179a
|
add travis for aarch64
|
2018-11-20 01:33:21 +08:00 |
|
WangRunji
|
4f8d110d31
|
update README
|
2018-11-20 01:29:44 +08:00 |
|
WangRunji
|
b1bdac7d0f
|
fix merge for aarch64. now it works!
|
2018-11-20 01:08:39 +08:00 |
|
WangRunji
|
2daf8c188d
|
Merge remote-tracking branch 'equation314/arch-aarch64' into dev
# Conflicts:
# .gitignore
# kernel/Cargo.lock
# kernel/Cargo.toml
# kernel/Makefile
# kernel/riscv32-blog_os.json
# kernel/src/consts.rs
# kernel/src/fs.rs
# kernel/src/lib.rs
# kernel/src/process/context.rs
# kernel/src/process/mod.rs
|
2018-11-20 00:15:19 +08:00 |
|
WangRunji
|
56fcad245a
|
update kernel to 2018 edition
|
2018-11-19 20:11:17 +08:00 |
|
WangRunji
|
4495622317
|
update process crate to 2018 edition
|
2018-11-19 15:46:40 +08:00 |
|
WangRunji
|
12457f10cb
|
update memory crate to 2018 edition
|
2018-11-19 15:43:28 +08:00 |
|
WangRunji
|
c4935a1477
|
use pc-keyboard crate and enable keyboard again for x86
|
2018-11-18 19:20:26 +08:00 |
|
lcy1996
|
76d2c6ec7b
|
Fix the bug of active_table_swap() wrongly force unlock in pg fault handler
|
2018-11-17 23:17:42 +08:00 |
|
lcy1996
|
b2fec2b16b
|
Fix a bug in context for smp
|
2018-11-17 21:34:21 +08:00 |
|
lcy1996
|
67035ac556
|
Fix a bug in pg fault handler caused by memory_set_record
|
2018-11-17 19:18:48 +08:00 |
|
lcy1996
|
00d0ea8a8b
|
Modified the code in pgfault
|
2018-11-17 16:54:21 +08:00 |
|
lcy1996
|
9d803e87d9
|
replace some unwrap() and comment the cow pgfault handler
|
2018-11-17 16:25:24 +08:00 |
|
WangRunji
|
7d7cedfdd0
|
move g4 docs
|
2018-11-17 13:07:52 +08:00 |
|
WangRunji
|
df485d506e
|
simplify ProcessManager
- given that a proc can only be waited by its parent, wait_queue is no longer needed.
|
2018-11-17 12:58:40 +08:00 |
|
WangRunji
|
5478b9ba7b
|
no longer show normal page fault
|
2018-11-17 12:42:19 +08:00 |
|
WangRunji
|
ef75c8a072
|
fix unwrap panic. now user shell is working.
|
2018-11-17 12:40:51 +08:00 |
|
WangRunji
|
da399dca96
|
remove Process struct
|
2018-11-16 22:27:03 +08:00 |
|
WangRunji
|
205f90a264
|
Merge branch 'dev' into g4-merge
# Conflicts:
# crate/memory/src/cow.rs
# crate/memory/src/memory_set.rs
# crate/memory/src/paging/mod.rs
# crate/memory/src/swap/mod.rs
# crate/process/src/lib.rs
# crate/process/src/process_manager.rs
# crate/process/src/processor.rs
# crate/process/src/thread.rs
# crate/riscv
# kernel/Cargo.lock
# kernel/src/arch/riscv32/compiler_rt.rs
# kernel/src/arch/riscv32/consts.rs
# kernel/src/arch/riscv32/context.rs
# kernel/src/arch/riscv32/interrupt.rs
# kernel/src/arch/riscv32/memory.rs
# kernel/src/arch/riscv32/mod.rs
# kernel/src/arch/riscv32/paging.rs
# kernel/src/arch/x86_64/driver/ide.rs
# kernel/src/arch/x86_64/interrupt/handler.rs
# kernel/src/arch/x86_64/mod.rs
# kernel/src/console.rs
# kernel/src/consts.rs
# kernel/src/fs.rs
# kernel/src/lib.rs
# kernel/src/memory.rs
# kernel/src/process/context.rs
# kernel/src/process/mod.rs
# kernel/src/syscall.rs
# kernel/src/trap.rs
|
2018-11-16 18:58:29 +08:00 |
|