75 Commits (5852881611076f5b77f41c0f8a96b2e343d7e4fe)

Author SHA1 Message Date
WangRunji b7d6b2989d Fix bugs. Pass test 'spin'
6 years ago
WangRunji ed20aa45fd Fix user process bug on RV32.
6 years ago
WangRunji 6fc23e1134 Ugly impl sys_wait(0)
6 years ago
WangRunji 74facd8e87 Use Vec to replace array in ProcessManager.
6 years ago
WangRunji 182c595a20 Enable multi-core on RV32.
6 years ago
WangRunji 250f1385d3 Better debug print for TrapFrame on RV32
6 years ago
WangRunji 7229b49eb8 Use rust-lld for RV32. Remove riscv git submodule.
6 years ago
WangRunji 72dc3f62ad Remove kernel stack from MemorySet.
6 years ago
WangRunji 438e290b6d Fix PageTable::get_entry -> Option.
6 years ago
WangRunji a42d6086c6 Simplify IDE code.
6 years ago
WangRunji 81196729e4 Fix RV32 atomic.
6 years ago
WangRunji 95ab9caba1 Add impl of atomic_fetch_*
6 years ago
WangRunji 0680023e35 Recover wait/sleep
6 years ago
WangRunji 85a1dca684 Use weak linkage to provide dependencies for process::thread.
6 years ago
WangRunji 80b161db98 Recover set_priority and fork
6 years ago
WangRunji 5db908b1c5 Separate ProcessManager to a mod.
6 years ago
WangRunji f7eb09e856 Multicore processing WORKS! Basically ...
6 years ago
WangRunji 6741ba399b Add arch::cpu::halt(). Halt when panic.
6 years ago
WangRunji 5bc392f388 Enable RV32 IPI.
6 years ago
WangRunji 1b4edf3bb2 Merge branch 'rv32-smp-porting' into dev
6 years ago
WangRunji 72e92c07f9 Switch to RV64 GNU toolchain. Simplify compiler_rt.
6 years ago
WangRunji f1771f8ef2 Finish x86 SMP startup. Support timer & IPI.
6 years ago
maoyuchaxue f27fd37d82 replaced spin::Mutex with sync::SpinLock, now spinlock works well.
6 years ago
maoyuchaxue f7b7b1bcd6 added workaround for atomic ops
6 years ago
maoyuchaxue cfda03a0f2 trying to add atomic implementations in rv32, but still buggy
6 years ago
maoyuchaxue 49cd04dce3 added rv32 smp booting, with slight modification to bbl
6 years ago
maoyuchaxue 6cf0d6db23 fixed setting in riscv-pk to enable rv32ia, added smp option in Makefile
6 years ago
WangRunji cd1bd55729 Update README, travis, riscv crate.
6 years ago
WangRunji 924c061d64 Merge branch 'x86-boot'
6 years ago
WangRunji 224905f12c Update Makefile
6 years ago
WangRunji 7a9b746c68 x86_64 back to normal.
6 years ago
WangRunji 7f00001fd1 Move to higher half
6 years ago
dzy 5a0ce1e464 Refactored RISC-V page table identity mapping into a function.
6 years ago
dzy 11223957d1 Add `mkdir build` in makefile.
6 years ago
WangRunji 0a9c294814 Fix x86_64 startup. TODO: higher half.
6 years ago
WangRunji 0437e5cb17 Make it compile for bootimage toolchain
6 years ago
WangRunji caeff9ad97 Update packages and fit for new Rust nightly
6 years ago
WangRunji cbe7affc5d Merge riscv for QEMU & FPGA
6 years ago
WangRunji ff8930a36c Make frame allocator smaller. Fix serial stupid bug.
6 years ago
WangRunji 3cf118ba67 Mul & div inst emulation
6 years ago
WangRunji b99dc3d1cf Merge branch 'new-rv-toolchain' into board
6 years ago
WangRunji 640872d154 Use alloc API to fix stack overflow in release mode.
6 years ago
WangRunji 384f6a9c9c Change kernel heap to identity map
6 years ago
WangRunji dc97b4b433 Fix atomic_compare_exchange
6 years ago
WangRunji 3d0d6e3d02 Merge branch 'new-rv-toolchain' into board
6 years ago
WangRunji 3d6fcb8d8c Fix x86_64. Not elegant.
6 years ago
WangRunji 10e3cea340 Only use Rust toolchain to build for rv32. Set arch to rv32i. x86_64 broken.
6 years ago
WangRunji 296b6196f4 rv64 toolchain configure for riscv-pk
6 years ago
WangRunji b88648ff44 Fit for newest Rust nightly. x86_64 ok, riscv32 broken.
6 years ago
WangRunji 7e5726845f Simple bootloader. Remove riscv-pk.
6 years ago