Skip to content

Commit

Permalink
move signal handle into ruxtask and fix sys_rt_rigaction
Browse files Browse the repository at this point in the history
  • Loading branch information
lhw committed Dec 15, 2024
1 parent 2dba7dc commit 6f4bf66
Show file tree
Hide file tree
Showing 9 changed files with 108 additions and 38 deletions.
2 changes: 1 addition & 1 deletion api/ruxos_posix_api/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ multitask = ["ruxfeat/multitask", "ruxtask/multitask", "dep:ruxfutex"]
fd = ["alloc"]
fs = ["dep:ruxfs", "ruxfeat/fs", "fd"]
net = ["dep:ruxnet", "ruxfeat/net", "fd"]
signal = ["ruxruntime/signal", "ruxhal/signal"]
signal = ["ruxruntime/signal", "ruxhal/signal", "ruxtask/signal"]
pipe = ["fd"]
select = ["fd"]
epoll = ["fd"]
Expand Down
20 changes: 17 additions & 3 deletions api/ruxos_posix_api/src/imp/rt_sig.rs
Original file line number Diff line number Diff line change
Expand Up @@ -95,10 +95,24 @@ pub unsafe fn sys_rt_sigaction(
old: *mut ctypes::sigaction,
_sigsetsize: ctypes::size_t,
) -> c_int {
debug!("sys_rt_sigaction <= sig: {}", sig);
debug!(
"sys_rt_sigaction <= sig: {} sa {:x} old {:x}",
sig, sa as u64, old as u64
);
syscall_body!(sys_rt_sigaction, {
if sa as u64 == 0 || old as u64 == 0 {
Err(LinuxError::EFAULT)
if sa as u64 == 0 && old as u64 == 0 {
sys_sigaction(sig as _, None, None);
Ok(0)
} else if sa as u64 != 0 && old as u64 == 0 {
let sa = unsafe { *sa };
let sa = k_sigaction::from(sa);
sys_sigaction(sig as _, Some(&sa), None);
Ok(0)
} else if sa as u64 == 0 && old as u64 != 0 {
let old = unsafe { *old };
let mut old_sa = k_sigaction::from(old);
sys_sigaction(sig as _, None, Some(&mut old_sa));
Ok(0)
} else {
let sa = unsafe { *sa };
let old = unsafe { *old };
Expand Down
2 changes: 1 addition & 1 deletion api/ruxos_posix_api/src/imp/signal.rs
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ use crate::ctypes::k_sigaction;
use crate::ctypes::{self, pid_t};

use axerrno::LinuxError;
use ruxruntime::{rx_sigaction, Signal};
use ruxtask::{rx_sigaction, Signal};

/// Set signal handler
pub fn sys_sigaction(
Expand Down
4 changes: 1 addition & 3 deletions modules/ruxruntime/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -39,8 +39,6 @@ extern crate axlog;

#[cfg(all(target_os = "none", not(test)))]
mod lang_items;
#[cfg(feature = "signal")]
mod signal;

#[cfg(not(feature = "musl"))]
mod trap;
Expand All @@ -52,7 +50,7 @@ mod mp;
pub use self::mp::rust_main_secondary;

#[cfg(feature = "signal")]
pub use self::signal::{rx_sigaction, Signal};
use ruxtask::signal::{rx_sigaction, Signal};

#[cfg(feature = "alloc")]
extern crate alloc;
Expand Down
1 change: 1 addition & 0 deletions modules/ruxtask/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ musl = []
preempt = ["irq", "percpu?/preempt", "kernel_guard/preempt"]
paging = []
fs = []
signal = []

sched_fifo = ["multitask"]
sched_rr = ["multitask", "preempt"]
Expand Down
8 changes: 8 additions & 0 deletions modules/ruxtask/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,8 @@ cfg_if::cfg_if! {
pub mod task;
mod api;
mod wait_queue;
#[cfg(feature = "signal")]
pub mod signal;
#[cfg(feature = "paging")]
pub mod vma;
// #[cfg(feature = "fs")]
Expand Down Expand Up @@ -79,8 +81,14 @@ cfg_if::cfg_if! {
pub use self::api::*;
pub use self::api::{sleep, sleep_until, yield_now};
pub use task::TaskState;
#[cfg(feature = "signal")]
pub use self::signal::{rx_sigaction, Signal};
} else {
mod api_s;
#[cfg(feature = "signal")]
pub mod signal;
pub use self::api_s::{sleep, sleep_until, yield_now};
#[cfg(feature = "signal")]
pub use self::signal::{rx_sigaction, Signal};
}
}
46 changes: 32 additions & 14 deletions modules/ruxruntime/src/signal.rs → modules/ruxtask/src/signal.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
* See the Mulan PSL v2 for more details.
*/

use crate::current;
#[cfg(feature = "irq")]
use core::sync::atomic::AtomicI64;
use core::{
Expand Down Expand Up @@ -85,6 +86,17 @@ impl TrapHandler for SignalHandler {
}

impl Signal {
///crate new Signal struct
pub fn new() -> Self {
Self {
#[cfg(feature = "irq")]
signal: AtomicI64::new(0),
sigaction: [rx_sigaction::new(); 32],
// Default::default() is not const
timer_value: [Duration::from_nanos(0); 3],
timer_interval: [Duration::from_nanos(0); 3],
}
}
/// Set signal
/// signum: signal number, if signum < 0, just return current signal
/// on: true: enable signal, false: disable signal
Expand All @@ -94,7 +106,9 @@ impl Signal {
if signum >= 32 {
return None;
}
let mut old = unsafe { SIGNAL_IF.signal.load(Ordering::Acquire) };
let binding = current();
let mut current_signal_if = binding.signal_if.lock();
let mut old = unsafe { current_signal_if.signal.load(Ordering::Acquire) };
if signum >= 0 {
loop {
let new = if on {
Expand All @@ -104,7 +118,7 @@ impl Signal {
};

match unsafe {
SIGNAL_IF.signal.compare_exchange_weak(
current_signal_if.signal.compare_exchange_weak(
old,
new,
Ordering::AcqRel,
Expand All @@ -126,35 +140,37 @@ impl Signal {
sigaction: Option<*const rx_sigaction>,
oldact: Option<*mut rx_sigaction>,
) {
if signum >= unsafe { SIGNAL_IF.sigaction }.len() as u8 {
let binding = current();
let mut current_signal_if = binding.signal_if.lock();
if signum >= unsafe { current_signal_if.sigaction }.len() as u8 {
return;
}
if let Some(oldact) = oldact {
unsafe {
*oldact = SIGNAL_IF.sigaction[signum as usize];
*oldact = current_signal_if.sigaction[signum as usize];
}
}
match sigaction {
Some(s) => unsafe {
SIGNAL_IF.sigaction[signum as usize] = *s;
},
None => unsafe {
SIGNAL_IF.sigaction[signum as usize].sa_handler.unwrap()(signum as c_int)
current_signal_if.sigaction[signum as usize] = *s;
},
None => {},
}
}
/// Set timer
/// which: timer type
/// new_value: new timer value
/// old_value: old timer value
pub fn timer_deadline(which: usize, new_deadline: Option<u64>) -> Option<u64> {
if which >= unsafe { SIGNAL_IF.timer_value }.len() {
let binding = current();
let mut current_signal_if = binding.signal_if.lock();
if which >= unsafe { current_signal_if.timer_value }.len() {
return None;
}
let old = unsafe { SIGNAL_IF.timer_value }[which];
let old = unsafe { current_signal_if.timer_value }[which];
if let Some(s) = new_deadline {
unsafe {
SIGNAL_IF.timer_value[which] = Duration::from_nanos(s);
current_signal_if.timer_value[which] = Duration::from_nanos(s);
}
}
Some(old.as_nanos() as u64)
Expand All @@ -164,13 +180,15 @@ impl Signal {
/// new_interval: new timer interval
/// old_interval: old timer interval
pub fn timer_interval(which: usize, new_interval: Option<u64>) -> Option<u64> {
if which >= unsafe { SIGNAL_IF.timer_interval }.len() {
let binding = current();
let mut current_signal_if = binding.signal_if.lock();
if which >= unsafe { current_signal_if.timer_interval }.len() {
return None;
}
let old = unsafe { SIGNAL_IF.timer_interval }[which];
let old = unsafe { current_signal_if.timer_interval }[which];
if let Some(s) = new_interval {
unsafe {
SIGNAL_IF.timer_interval[which] = Duration::from_nanos(s);
current_signal_if.timer_interval[which] = Duration::from_nanos(s);
}
}
Some(old.as_nanos() as u64)
Expand Down
36 changes: 30 additions & 6 deletions modules/ruxtask/src/task.rs
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,8 @@ use crate::current;
use crate::tsd::{DestrFunction, KEYS, TSD};
#[cfg(feature = "paging")]
use crate::vma::MmapStruct;
#[cfg(feature = "signal")]
use crate::Signal;
use crate::{AxRunQueue, AxTask, AxTaskRef, WaitQueue};

/// A unique identifier for a thread.
Expand Down Expand Up @@ -81,6 +83,7 @@ pub struct TaskInner {
exit_code: AtomicI32,
wait_for_exit: WaitQueue,

stack_map_addr: SpinNoIrq<VirtAddr>,
kstack: SpinNoIrq<Arc<Option<TaskStack>>>,
ctx: UnsafeCell<TaskContext>,

Expand All @@ -90,6 +93,9 @@ pub struct TaskInner {
#[cfg(not(feature = "musl"))]
tsd: TSD,

#[cfg(feature = "signal")]
pub signal_if: Arc<SpinNoIrq<Signal>>,

// set tid
#[cfg(feature = "musl")]
set_tid: AtomicU64,
Expand Down Expand Up @@ -235,6 +241,7 @@ impl TaskInner {
preempt_disable_count: AtomicUsize::new(0),
exit_code: AtomicI32::new(0),
wait_for_exit: WaitQueue::new(),
stack_map_addr: SpinNoIrq::new(VirtAddr::from(0)), // should be set later
kstack: SpinNoIrq::new(Arc::new(None)),
ctx: UnsafeCell::new(TaskContext::new()),
#[cfg(feature = "tls")]
Expand All @@ -243,6 +250,8 @@ impl TaskInner {
tsd: spinlock::SpinNoIrq::new([core::ptr::null_mut(); ruxconfig::PTHREAD_KEY_MAX]),
#[cfg(feature = "musl")]
set_tid: AtomicU64::new(0),
#[cfg(feature = "signal")]
signal_if: current().signal_if.clone(),
#[cfg(feature = "musl")]
tl: AtomicU64::new(0),
#[cfg(feature = "paging")]
Expand Down Expand Up @@ -279,11 +288,14 @@ impl TaskInner {
preempt_disable_count: AtomicUsize::new(0),
exit_code: AtomicI32::new(0),
wait_for_exit: WaitQueue::new(),
stack_map_addr: SpinNoIrq::new(VirtAddr::from(0)),
kstack: SpinNoIrq::new(Arc::new(None)),
ctx: UnsafeCell::new(TaskContext::new()),
#[cfg(feature = "tls")]
tls: TlsArea::new_with_addr(tls),
set_tid,
#[cfg(feature = "signal")]
signal_if: current().signal_if.clone(),
// clear child tid
tl,
#[cfg(feature = "paging")]
Expand All @@ -299,6 +311,7 @@ impl TaskInner {

pub fn set_stack_top(&self, begin: usize, size: usize) {
debug!("set_stack_top: begin={:#x}, size={:#x}", begin, size);
*self.stack_map_addr.lock() = VirtAddr::from(begin);
*self.kstack.lock() = Arc::new(Some(TaskStack {
ptr: NonNull::new(begin as *mut u8).unwrap(),
layout: Layout::from_size_align(size, PAGE_SIZE_4K).unwrap(),
Expand Down Expand Up @@ -406,14 +419,14 @@ impl TaskInner {

// Note: the stack region is mapped to the same position as the parent process's stack, be careful when update the stack region for the forked process.
let (_, prev_flag, _) = cloned_page_table
.query(current_stack.end())
.query(*current().stack_map_addr.lock())
.expect("failed to query stack region when forking");
cloned_page_table
.unmap_region(current_stack.end(), align_up_4k(stack_size))
.unmap_region(*current().stack_map_addr.lock(), align_up_4k(stack_size))
.expect("failed to unmap stack region when forking");
cloned_page_table
.map_region(
current_stack.end(),
*current().stack_map_addr.lock(),
stack_paddr,
stack_size,
prev_flag,
Expand Down Expand Up @@ -477,10 +490,11 @@ impl TaskInner {
need_resched: AtomicBool::new(current_task.need_resched.load(Ordering::Relaxed)),
#[cfg(feature = "preempt")]
preempt_disable_count: AtomicUsize::new(
current_task.preempt_disable_count.load(Ordering::Relaxed),
current_task.preempt_disable_count.load(Ordering::Acquire),
),
exit_code: AtomicI32::new(0),
wait_for_exit: WaitQueue::new(),
stack_map_addr: SpinNoIrq::new(*current().stack_map_addr.lock()),
kstack: SpinNoIrq::new(Arc::new(Some(new_stack))),
ctx: UnsafeCell::new(TaskContext::new()),
#[cfg(feature = "tls")]
Expand All @@ -489,6 +503,8 @@ impl TaskInner {
tsd: spinlock::SpinNoIrq::new([core::ptr::null_mut(); ruxconfig::PTHREAD_KEY_MAX]),
#[cfg(feature = "musl")]
set_tid: AtomicU64::new(0),
#[cfg(feature = "signal")]
signal_if: Arc::new(spinlock::SpinNoIrq::new(Signal::new())),
#[cfg(feature = "musl")]
tl: AtomicU64::new(0),
#[cfg(feature = "paging")]
Expand All @@ -515,6 +531,7 @@ impl TaskInner {
.lock()
.insert(new_pid.as_u64(), task_ref.clone());

warn!("forked task: save_current_content {}", task_ref.id_name());
unsafe {
// copy the stack content from current stack to new stack
(*task_ref.ctx_mut_ptr()).save_current_content(
Expand Down Expand Up @@ -554,6 +571,7 @@ impl TaskInner {
preempt_disable_count: AtomicUsize::new(0),
exit_code: AtomicI32::new(0),
wait_for_exit: WaitQueue::new(),
stack_map_addr: SpinNoIrq::new(VirtAddr::from(0)), // set in set_stack_top
kstack: SpinNoIrq::new(Arc::new(None)),
ctx: UnsafeCell::new(TaskContext::new()),
#[cfg(feature = "tls")]
Expand All @@ -562,6 +580,8 @@ impl TaskInner {
tsd: spinlock::SpinNoIrq::new([core::ptr::null_mut(); ruxconfig::PTHREAD_KEY_MAX]),
#[cfg(feature = "musl")]
set_tid: AtomicU64::new(0),
#[cfg(feature = "signal")]
signal_if: Arc::new(spinlock::SpinNoIrq::new(Signal::new())),
#[cfg(feature = "musl")]
tl: AtomicU64::new(0),
#[cfg(feature = "paging")]
Expand Down Expand Up @@ -590,6 +610,7 @@ impl TaskInner {
let bindings = PROCESS_MAP.lock();
let (&_parent_id, &ref task_ref) = bindings.first_key_value().unwrap();
let idle_kstack = TaskStack::alloc(align_up_4k(IDLE_STACK_SIZE));
let idle_kstack_top = idle_kstack.top();

let mut t = Self {
parent_process: Some(Arc::downgrade(task_ref)),
Expand All @@ -609,14 +630,17 @@ impl TaskInner {
preempt_disable_count: AtomicUsize::new(0),
exit_code: AtomicI32::new(0),
wait_for_exit: WaitQueue::new(),
kstack: SpinNoIrq::new(Arc::new(None)),
stack_map_addr: SpinNoIrq::new(idle_kstack.end()),
kstack: SpinNoIrq::new(Arc::new(Some(idle_kstack))),
ctx: UnsafeCell::new(TaskContext::new()),
#[cfg(feature = "tls")]
tls: TlsArea::alloc(),
#[cfg(not(feature = "musl"))]
tsd: spinlock::SpinNoIrq::new([core::ptr::null_mut(); ruxconfig::PTHREAD_KEY_MAX]),
#[cfg(feature = "musl")]
set_tid: AtomicU64::new(0),
#[cfg(feature = "signal")]
signal_if: task_ref.signal_if.clone(),
#[cfg(feature = "musl")]
tl: AtomicU64::new(0),
#[cfg(feature = "paging")]
Expand All @@ -633,7 +657,7 @@ impl TaskInner {
debug!("new idle task: {}", t.id_name());
t.ctx
.get_mut()
.init(task_entry as usize, idle_kstack.top(), tls);
.init(task_entry as usize, idle_kstack_top, tls);

let task_ref = Arc::new(AxTask::new(t));

Expand Down
Loading

0 comments on commit 6f4bf66

Please sign in to comment.