WangRunji
92ae57b251
fix user program memory layout on NoMMU
6 years ago
WangRunji
daee1e9f94
fix bugs on K210
6 years ago
WangRunji
b3a8e95d78
merge interrupt & context switch for rv32 & rv64
6 years ago
WangRunji
de24f6673c
remove '\r'
6 years ago
WangRunji
0d957ff1a6
fix getchar on K210
6 years ago
dzy
4b17055f30
running user program.
6 years ago
dzy
e74f749ff3
fix context change bug. user sh is running!!!
6 years ago
dzy
6f2d059ba5
implement map_kernel, now enters the kernel well
6 years ago
dzy
bf3a67a7e4
remap_kernel runs fine
6 years ago
dzy
21adebb203
run until ms.token()
6 years ago
dzy
ccee527272
runs without pagefault but does not reach end of remap_kernel
6 years ago
dzy
a4348428a6
can run until update
6 years ago
dzy
d67a224494
add wrj's 704af94
patch
6 years ago
dzy
ed3fb6d423
another temporary
6 years ago
dzy
0dbffbc0fa
temporary
6 years ago
WangRunji
af6d533cb5
fix trap return on M-Mode
6 years ago
WangRunji
3de76885fa
llc build for rv64imc
6 years ago
WangRunji
020e3505ee
enable timer interrupt for K210
6 years ago
dzy
b7e124930d
fix compilation errors
6 years ago
dzy
3910f71521
preliminary support for riscv64, not tested.
...
riscv32 runs fine.
6 years ago
WangRunji
3a4b8f5dac
fix trap for rv64
6 years ago
WangRunji
8529d9fe4e
fix const, linker, build for K210
6 years ago
WangRunji
9ab4fd40ea
fix atomic for K210. enable print mutex again
6 years ago
WangRunji
70b6db4282
make clear_bss faster
6 years ago
dzy
1d1d4109c3
Make script easily support both rv32 and rv64.
6 years ago
dzy
98c94a0d83
Fix register size (4->XLEN) in trap handling.
6 years ago
WangRunji
45b91fbcad
update rv64 build script. print hello on QEMU!
6 years ago
WangRunji
d3ef0252ac
move setup_page_table to BBL
6 years ago
WangRunji
3ea104da97
Merge remote-tracking branch 'dzy/rust-rv64' into rust-rv64
...
# Conflicts:
# kernel/Cargo.toml
6 years ago
WangRunji
0af9776dbd
add .stack section. clear bss
6 years ago
WangRunji
7240198a54
fix newline: '\r\n'
6 years ago
WangRunji
62b931d576
print hello on K210
6 years ago
WangRunji
6c5cf5689d
add rv64 user programs img
6 years ago
dzy
a75e52691d
port to newer riscv crate supporting rv64
6 years ago
WangRunji
d4b6cc1082
compile rv64 pass on macOS
6 years ago
WangRunji
02bd2b2317
remove arch/riscv64 directory
6 years ago
dzy
f954c2fd6a
Completely get rid of cargo-generated target/
6 years ago
dzy
61a3beb8ba
Start porting for rv64
6 years ago
dzy
7b0ac1b84e
Script to allow rustc-only builds without cargo.
6 years ago
dzy
25ccdf6731
Update and cleanup makefile.
...
* Change few places from riscv64 to riscv32. Previously it was rv64
because the code author does not have a 32bit toolchain and used a
64bit one instead.
* Add new board type 'none', for running on qemu.
6 years ago
Wang Runji
52a2e24021
Merge pull request #5 from equation314/user-img
...
Create multi-arch user SFS image
6 years ago
equation314
d5a6eb2020
user: fix build error
6 years ago
Wang Runji
3f2beab52d
Merge branch 'master' into user-img
6 years ago
WangRunji
6cf679b596
update README. add LICENSE
6 years ago
WangRunji
e7039945c1
move user img, remove useless files
6 years ago
WangRunji
acafe19e26
fix runtime error on aarch64
...
- InactivePageTable::activate should be separated for user & kernel (TTBR1/0)
- disable swappable for aarch64 (bug?)
- use polling getchar as serial interrupt is not implemented
6 years ago
equation314
66ac30d401
user: update make clean in kernel/
6 years ago
equation314
710b6d1a28
user: update Makefiles
6 years ago
equation314
e86229cb71
user: user rust programs are runnable
6 years ago
WangRunji
b5ced136f7
fix merge compile error
6 years ago