fix merge for aarch64. now it works!

toolchain_update
WangRunji 6 years ago
parent 2daf8c188d
commit b1bdac7d0f

@ -27,3 +27,18 @@ pub unsafe fn restore(flags: usize) {
pub unsafe fn restore(flags: usize) { pub unsafe fn restore(flags: usize) {
asm!("csrs 0x100, $0" :: "r"(flags)); asm!("csrs 0x100, $0" :: "r"(flags));
} }
#[inline(always)]
#[cfg(target_arch = "aarch64")]
pub unsafe fn disable_and_store() -> usize {
let daif: u32;
asm!("mrs $0, DAIF": "=r"(daif) ::: "volatile");
asm!("msr daifset, #2");
daif as usize
}
#[inline(always)]
#[cfg(target_arch = "aarch64")]
pub unsafe fn restore(flags: usize) {
asm!("msr DAIF, $0" :: "r"(flags as u32) :: "volatile");
}

@ -4,7 +4,7 @@
# make justrun Run the last build # make justrun Run the last build
# make doc Generate docs # make doc Generate docs
# make asm Open the deassemble file of the last build # make asm Open the deassemble file of the last build
# make elf-h Open 'objdump -h' of the last build # make header Open 'objdump -h' of the last build
# make clean Clean # make clean Clean
# #
# Options: # Options:
@ -18,7 +18,6 @@
arch ?= riscv32 arch ?= riscv32
board ?= raspi3 board ?= raspi3
prefix ?= $(arch)-none-elf
mode ?= debug mode ?= debug
LOG ?= debug LOG ?= debug
smp ?= 4 smp ?= 4
@ -83,12 +82,22 @@ endif
### prefix ### ### prefix ###
ld := $(prefix)-ld ifeq ($(arch), x86_64)
objdump := $(prefix)-objdump ifeq ($(uname), Darwin)
objcopy := $(prefix)-objcopy prefix := x86_64-elf-
cc := $(prefix)-gcc endif
as := $(prefix)-as else ifeq ($(arch), riscv32)
gdb := $(prefix)-gdb prefix := riscv64-unknown-elf-
else ifeq ($(arch), aarch64)
prefix ?= aarch64-none-elf-
endif
ld := $(prefix)ld
objdump := $(prefix)objdump
objcopy := $(prefix)objcopy
cc := $(prefix)gcc
as := $(prefix)as
gdb := $(prefix)gdb
.PHONY: all clean run build asm doc justrun kernel .PHONY: all clean run build asm doc justrun kernel
@ -144,7 +153,7 @@ else
cp bbl ../../kernel/$@ cp bbl ../../kernel/$@
endif endif
else ifeq ($(arch), aarch64) else ifeq ($(arch), aarch64)
$(objcopy) $(kernel) --strip-all -O binary $@ @$(objcopy) $(kernel) --strip-all -O binary $@
endif endif
kernel: kernel:

@ -1,11 +1,11 @@
use arch::interrupt::TrapFrame; use crate::arch::interrupt::TrapFrame;
use super::bcm2837::timer::Timer; use bcm2837::timer::Timer;
use super::bcm2837::interrupt::{Controller, Interrupt}; use bcm2837::interrupt::{Controller, Interrupt};
pub fn handle_irq(tf: &mut TrapFrame) { pub fn handle_irq(tf: &mut TrapFrame) {
let controller = Timer::new(); let controller = Timer::new();
if controller.is_pending() { if controller.is_pending() {
super::timer::set_next(); super::timer::set_next();
::trap::timer(); crate::trap::timer();
} }
} }

@ -1,7 +1,5 @@
//! Raspberry PI 3 Model B/B+ //! Raspberry PI 3 Model B/B+
extern crate bcm2837;
pub mod irq; pub mod irq;
pub mod timer; pub mod timer;
pub mod serial; pub mod serial;

@ -1,5 +1,4 @@
use super::bcm2837::mini_uart::MiniUart; use bcm2837::mini_uart::MiniUart;
use core::fmt; use core::fmt;
use spin::Mutex; use spin::Mutex;

@ -1,5 +1,6 @@
use super::bcm2837::timer; use bcm2837::timer;
use super::bcm2837::interrupt::{Controller, Interrupt}; use bcm2837::interrupt::{Controller, Interrupt};
use log::*;
pub fn init() { pub fn init() {
timer::init(); timer::init();

@ -0,0 +1,8 @@
pub fn halt() {
unsafe { asm!("wfi" :::: "volatile") }
}
pub fn id() -> usize {
// TODO: cpu id
0
}

@ -148,4 +148,10 @@ impl Context {
}, },
}.push_at(kstack_top) }.push_at(kstack_top)
} }
/// Called at a new user context
/// To get the init TrapFrame in sys_exec
pub unsafe fn get_init_tf(&self) -> TrapFrame {
(*(self.0 as *const InitStack)).tf.clone()
}
} }

@ -1,8 +1,9 @@
//! Trap handler //! Trap handler
use arch::board::irq::handle_irq; use crate::arch::board::irq::handle_irq;
use super::context::TrapFrame; use super::context::TrapFrame;
use super::syndrome::Syndrome; use super::syndrome::Syndrome;
use log::*;
global_asm!(include_str!("trap.S")); global_asm!(include_str!("trap.S"));
global_asm!(include_str!("vector.S")); global_asm!(include_str!("vector.S"));
@ -46,13 +47,12 @@ pub extern "C" fn rust_trap(info: Info, esr: u32, tf: &mut TrapFrame) {
match syndrome { match syndrome {
Syndrome::Brk(brk) => handle_break(brk, tf), Syndrome::Brk(brk) => handle_break(brk, tf),
Syndrome::Svc(_) => handle_syscall(tf), Syndrome::Svc(_) => handle_syscall(tf),
_ => ::trap::error(tf), _ => crate::trap::error(tf),
} }
} }
Kind::Irq => handle_irq(tf), Kind::Irq => handle_irq(tf),
_ => ::trap::error(tf), _ => crate::trap::error(tf),
} }
::trap::before_return();
trace!("Interrupt end"); trace!("Interrupt end");
} }
@ -63,7 +63,7 @@ fn handle_break(num: u16, tf: &mut TrapFrame) {
fn handle_syscall(tf: &mut TrapFrame) { fn handle_syscall(tf: &mut TrapFrame) {
// svc instruction has been skipped in syscall (ref: J1.1.2, page 6152) // svc instruction has been skipped in syscall (ref: J1.1.2, page 6152)
let ret = ::syscall::syscall( let ret = crate::syscall::syscall(
tf.x1to29[7] as usize, tf.x1to29[7] as usize,
[ [
tf.x0, tf.x0,

@ -4,7 +4,7 @@ mod handler;
mod context; mod context;
mod syndrome; mod syndrome;
use super::cortex_a::regs::*; use cortex_a::regs::*;
pub use self::context::*; pub use self::context::*;
pub use self::handler::*; pub use self::handler::*;

@ -1,8 +1,9 @@
//! Memory initialization for aarch64. //! Memory initialization for aarch64.
use ucore_memory::PAGE_SIZE; use ucore_memory::PAGE_SIZE;
use super::atags::atags::Atags; use atags::atags::Atags;
use super::super::HEAP_ALLOCATOR; use crate::HEAP_ALLOCATOR;
use log::*;
/// Memory initialization. /// Memory initialization.
pub fn init() { pub fn init() {

@ -1,13 +1,11 @@
//! Entrance and initialization for aarch64. //! Entrance and initialization for aarch64.
extern crate atags;
extern crate cortex_a;
pub mod io; pub mod io;
pub mod paging; pub mod paging;
pub mod memory; pub mod memory;
pub mod interrupt; pub mod interrupt;
pub mod consts; pub mod consts;
pub mod cpu;
#[cfg(feature = "board_raspi3")] #[cfg(feature = "board_raspi3")]
#[path = "board/raspi3/mod.rs"] #[path = "board/raspi3/mod.rs"]
@ -15,16 +13,87 @@ pub mod board;
pub use self::board::timer; pub use self::board::timer;
global_asm!(include_str!("boot/boot.S"));
/// The entry point of kernel /// The entry point of kernel
#[no_mangle] // don't mangle the name of this function #[no_mangle] // don't mangle the name of this function
pub extern "C" fn rust_main() -> ! { pub extern "C" fn rust_main() -> ! {
// Init board to enable serial port. // Init board to enable serial port.
board::init(); board::init();
::logging::init(); // FIXME crate::logging::init(); // FIXME
interrupt::init(); interrupt::init();
memory::init(); memory::init();
timer::init(); timer::init();
::kmain();
use crate::process::{processor, ContextImpl};
crate::process::init();
processor().manager().add(ContextImpl::new_kernel(kernel_proc2, 2333), 0);
processor().manager().add(ContextImpl::new_user_test(kernel_proc3), 0);
crate::kmain();
} }
global_asm!(include_str!("boot/boot.S")); extern fn kernel_proc2(arg: usize) -> ! {
use alloc::format;
test_shell(&format!("proc2-{}>> ", arg));
}
extern fn kernel_proc3(arg: usize) -> ! {
use alloc::format;
test_shell(&format!("proc3-{}$ ", arg));
}
const LOGO: &str = r#"
____ __ ____ _____
/ __ \ __ __ _____ / /_ / __ \/ ___/
/ /_/ // / / // ___// __// / / /\__ \
/ _, _// /_/ /(__ )/ /_ / /_/ /___/ /
/_/ |_| \__,_//____/ \__/ \____//____/
"#;
pub fn show_logo() {
println!("{}", LOGO);
}
#[inline(always)]
fn sys_call(id: usize, arg0: usize, arg1: usize, arg2: usize, arg3: usize, arg4: usize, arg5: usize) -> i32 {
let ret: i32;
unsafe {
asm!("svc 0"
: "={x0}" (ret)
: "{x8}" (id), "{x0}" (arg0), "{x1}" (arg1), "{x2}" (arg2), "{x3}" (arg3), "{x4}" (arg4), "{x5}" (arg5)
: "memory"
: "volatile");
}
ret
}
pub fn test_shell(prefix: &str) -> ! {
show_logo();
loop {
print!("{}", prefix);
loop {
let c = io::getchar();
match c {
'\u{7f}' => {
print!("\u{7f}");
}
'c' => unsafe {
print!("sys_putc: ");
sys_call(30, 'A' as usize, 0, 0, 0, 0, 0);
},
't' => unsafe {
println!("sys_get_time: {}", sys_call(17, 0, 0, 0, 0, 0, 0));
},
' '...'\u{7e}' => {
print!("{}", c);
}
'\n' | '\r' => {
print!("\n");
break;
}
_ => {}
}
}
}
}

@ -7,7 +7,7 @@ type VirtAddr = usize;
type PhysAddr = usize; type PhysAddr = usize;
use alloc::alloc::{alloc, Layout}; use alloc::alloc::{alloc, Layout};
use memory::{active_table, alloc_frame, alloc_stack, dealloc_frame}; use crate::memory::{active_table, alloc_frame, dealloc_frame};
/// TODO /// TODO
pub struct ActivePageTable { pub struct ActivePageTable {
@ -19,6 +19,10 @@ impl ActivePageTable {
pub unsafe fn new() -> Self { pub unsafe fn new() -> Self {
unimplemented!() unimplemented!()
} }
pub fn token() -> usize {
unimplemented!()
}
} }
impl PageTable for ActivePageTable { impl PageTable for ActivePageTable {
@ -31,7 +35,7 @@ impl PageTable for ActivePageTable {
unimplemented!() unimplemented!()
} }
fn get_entry(&mut self, addr: VirtAddr) -> &mut Self::Entry { fn get_entry(&mut self, addr: VirtAddr) -> Option<&mut Self::Entry> {
unimplemented!() unimplemented!()
} }
@ -200,7 +204,7 @@ impl InactivePageTable for InactivePageTable0 {
unimplemented!() unimplemented!()
} }
unsafe fn with(&self, f: impl FnOnce()) { unsafe fn with<T>(&self, f: impl FnOnce() -> T) -> T {
unimplemented!() unimplemented!()
} }
@ -215,8 +219,4 @@ impl InactivePageTable for InactivePageTable0 {
fn dealloc_frame(target: PhysAddr) { fn dealloc_frame(target: PhysAddr) {
dealloc_frame(target) dealloc_frame(target)
} }
fn alloc_stack() -> Stack {
alloc_stack()
}
} }

@ -34,6 +34,8 @@ lazy_static! {
}; };
#[cfg(target_arch = "x86_64")] #[cfg(target_arch = "x86_64")]
let device = Box::new(ide::IDE::new(1)); let device = Box::new(ide::IDE::new(1));
#[cfg(target_arch = "aarch64")]
let device = unimplemented!();
let sfs = SimpleFileSystem::open(device).expect("failed to open SFS"); let sfs = SimpleFileSystem::open(device).expect("failed to open SFS");
sfs.root_inode() sfs.root_inode()

@ -51,13 +51,18 @@ impl ContextImpl {
}) })
} }
pub fn new_user_test(entry: extern fn(usize) -> !) -> Self { /// Temp for aarch64
let ms = MemorySet::new(); pub fn new_user_test(entry: extern fn(usize) -> !) -> Box<Context> {
let user_stack = ::memory::alloc_stack(); let memory_set = MemorySet::new();
Context { let kstack = KernelStack::new();
arch: unsafe { ArchContext::new_user_thread(entry as usize, user_stack.top - 8, ms.kstack_top(), false, ms.token()) }, let ustack = KernelStack::new();
memory_set: ms, Box::new(ContextImpl {
} arch: unsafe { ArchContext::new_user_thread(entry as usize, ustack.top(), kstack.top(), false, memory_set.token()) },
memory_set,
kstack,
files: BTreeMap::default(),
cwd: String::new(),
})
} }
/// Make a new user thread from ELF data /// Make a new user thread from ELF data

@ -9,6 +9,7 @@ use core::sync::atomic::*;
use log::*; use log::*;
pub mod context; pub mod context;
pub fn init() { pub fn init() {
// NOTE: max_time_slice <= 5 to ensure 'priority' test pass // NOTE: max_time_slice <= 5 to ensure 'priority' test pass
let scheduler = Box::new(scheduler::RRScheduler::new(5)); let scheduler = Box::new(scheduler::RRScheduler::new(5));
@ -26,6 +27,7 @@ pub fn init() {
for i in 0..4 { for i in 0..4 {
manager.add(ContextImpl::new_kernel(idle, i), 0); manager.add(ContextImpl::new_kernel(idle, i), 0);
} }
#[cfg(not(target_arch = "aarch64"))]
crate::shell::run_user_shell(); crate::shell::run_user_shell();
info!("process init end"); info!("process init end");

Loading…
Cancel
Save