Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add testcases for cpu affinity and wait queue #2

Merged
merged 8 commits into from
Oct 17, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ jobs:
- name: Check code format
run: cargo fmt --all -- --check
- name: Clippy
continue-on-error: ${{ matrix.rust-toolchain == 'nightly' }}
run: cargo clippy --all-features

build-rust-apps:
Expand Down Expand Up @@ -63,6 +64,10 @@ jobs:
run: make ARCH=${{ matrix.arch }} A=rust/task/tls
- name: Build rust/task/irq
run: make ARCH=${{ matrix.arch }} A=rust/task/irq
- name: Build rust/task/affinity
run: make ARCH=${{ matrix.arch }} A=rust/task/affinity
- name: Build rust/task/wait_queue
run: make ARCH=${{ matrix.arch }} A=rust/task/wait_queue
- name: Build rust/fs/shell
run: make ARCH=${{ matrix.arch }} A=rust/fs/shell
- name: Build rust/net/echoserver
Expand Down Expand Up @@ -163,6 +168,7 @@ jobs:
with:
toolchain: ${{ matrix.rust-toolchain }}
- name: Build apps for std
continue-on-error: ${{ matrix.rust-toolchain == 'nightly' }}
run: |
./scripts/get_deps.sh
cargo build --all --exclude arceos-display
2 changes: 2 additions & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,8 @@ members = [
"rust/task/priority",
"rust/task/tls",
"rust/task/irq",
"rust/task/affinity",
"rust/task/wait_queue",
]
exclude = [".arceos"]

Expand Down
13 changes: 13 additions & 0 deletions rust/task/affinity/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
[package]
name = "affinity"
version = "0.1.0"
edition = "2021"
authors = ["Keyang Hu <[email protected]>"]
description = "A simple demo to test the cpu affinity of tasks under ArceOS"

[features]
sched_rr = ["axstd?/sched_rr"]
sched_cfs = ["axstd?/sched_cfs"]

[dependencies]
axstd = { workspace = true, features = ["multitask"], optional = true }
37 changes: 37 additions & 0 deletions rust/task/affinity/expect_info_smp4_cfs.out
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
smp = 4
build_mode = release
log_level = info

CPU 0 started
Found physcial memory regions:
.text (READ | EXECUTE | RESERVED)
.rodata (READ | RESERVED)
.data .tdata .tbss .percpu (READ | WRITE | RESERVED)
.percpu (READ | WRITE | RESERVED)
boot stack (READ | WRITE | RESERVED)
.bss (READ | WRITE | RESERVED)
free memory (READ | WRITE | FREE)
Initialize global memory allocator...
Initialize platform devices...
Initialize scheduling...
use Completely Fair scheduler.
Initialize interrupt handlers...
CPU 0 init OK
CPU 1 started
CPU 2 started
CPU 3 started
CPU 1 init OK
CPU 2 init OK
CPU 3 init OK
Hello, main task!
Hello, task (0)! id = ThreadId([0-9]\+)
Hello, task (1)! id = ThreadId([0-9]\+)
Hello, task (2)! id = ThreadId([0-9]\+)
Hello, task (3)! id = ThreadId([0-9]\+)
Hello, task (4)! id = ThreadId([0-9]\+)
Hello, task (5)! id = ThreadId([0-9]\+)
Hello, task (6)! id = ThreadId([0-9]\+)
Hello, task (7)! id = ThreadId([0-9]\+)
Hello, task (8)! id = ThreadId([0-9]\+)
Hello, task (9)! id = ThreadId([0-9]\+)
Task affinity tests run OK!
36 changes: 36 additions & 0 deletions rust/task/affinity/expect_info_smp4_fifo.out
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
smp = 4
build_mode = release
log_level = info

CPU 0 started
Found physcial memory regions:
.text (READ | EXECUTE | RESERVED)
.rodata (READ | RESERVED)
.data .tdata .tbss .percpu (READ | WRITE | RESERVED)
.percpu (READ | WRITE | RESERVED)
boot stack (READ | WRITE | RESERVED)
.bss (READ | WRITE | RESERVED)
free memory (READ | WRITE | FREE)
Initialize global memory allocator...
Initialize platform devices...
Initialize scheduling...
use FIFO scheduler.
CPU 0 init OK
CPU 1 started
CPU 2 started
CPU 3 started
CPU 1 init OK
CPU 2 init OK
CPU 3 init OK
Hello, main task!
Hello, task (0)! id = ThreadId([0-9]\+)
Hello, task (1)! id = ThreadId([0-9]\+)
Hello, task (2)! id = ThreadId([0-9]\+)
Hello, task (3)! id = ThreadId([0-9]\+)
Hello, task (4)! id = ThreadId([0-9]\+)
Hello, task (5)! id = ThreadId([0-9]\+)
Hello, task (6)! id = ThreadId([0-9]\+)
Hello, task (7)! id = ThreadId([0-9]\+)
Hello, task (8)! id = ThreadId([0-9]\+)
Hello, task (9)! id = ThreadId([0-9]\+)
Task affinity tests run OK!
37 changes: 37 additions & 0 deletions rust/task/affinity/expect_info_smp4_rr.out
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
smp = 4
build_mode = release
log_level = info

CPU 0 started
Found physcial memory regions:
.text (READ | EXECUTE | RESERVED)
.rodata (READ | RESERVED)
.data .tdata .tbss .percpu (READ | WRITE | RESERVED)
.percpu (READ | WRITE | RESERVED)
boot stack (READ | WRITE | RESERVED)
.bss (READ | WRITE | RESERVED)
free memory (READ | WRITE | FREE)
Initialize global memory allocator...
Initialize platform devices...
Initialize scheduling...
use Round-robin scheduler.
Initialize interrupt handlers...
CPU 0 init OK
CPU 1 started
CPU 2 started
CPU 3 started
CPU 1 init OK
CPU 2 init OK
CPU 3 init OK
Hello, main task!
Hello, task (0)! id = ThreadId([0-9]\+)
Hello, task (1)! id = ThreadId([0-9]\+)
Hello, task (2)! id = ThreadId([0-9]\+)
Hello, task (3)! id = ThreadId([0-9]\+)
Hello, task (4)! id = ThreadId([0-9]\+)
Hello, task (5)! id = ThreadId([0-9]\+)
Hello, task (6)! id = ThreadId([0-9]\+)
Hello, task (7)! id = ThreadId([0-9]\+)
Hello, task (8)! id = ThreadId([0-9]\+)
Hello, task (9)! id = ThreadId([0-9]\+)
Task affinity tests run OK!
72 changes: 72 additions & 0 deletions rust/task/affinity/src/main.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
#![cfg_attr(feature = "axstd", no_std)]
#![cfg_attr(feature = "axstd", no_main)]

#[macro_use]
#[cfg(feature = "axstd")]
extern crate axstd as std;

use std::sync::atomic::{AtomicUsize, Ordering};
use std::thread;

#[cfg(feature = "axstd")]
use std::os::arceos::api::config::SMP;
#[cfg(feature = "axstd")]
use std::os::arceos::api::task::{ax_set_current_affinity, AxCpuMask};
#[cfg(feature = "axstd")]
use std::os::arceos::modules::axhal::cpu::this_cpu_id;

const KERNEL_STACK_SIZE: usize = 0x40000; // 256 KiB

const NUM_TASKS: usize = 10;
const NUM_TIMES: usize = 100;
static FINISHED_TASKS: AtomicUsize = AtomicUsize::new(0);

#[allow(clippy::modulo_one)]
#[cfg_attr(feature = "axstd", no_mangle)]
fn main() {
println!("Hello, main task!");
for i in 0..NUM_TASKS {
let cpu_id = i % SMP;
thread::spawn(move || {
// Initialize cpu affinity here.
#[cfg(feature = "axstd")]
assert!(
ax_set_current_affinity(AxCpuMask::one_shot(cpu_id)).is_ok(),
"Initialize CPU affinity failed!"
);

println!("Hello, task ({})! id = {:?}", i, thread::current().id());
for _t in 0..NUM_TIMES {
// Test CPU affinity here.
#[cfg(feature = "axstd")]
assert_eq!(this_cpu_id(), cpu_id, "CPU affinity tests failed!");
thread::yield_now();
}

// Change cpu affinity here.
#[cfg(feature = "axstd")]
{
let mut cpumask = AxCpuMask::full();
cpumask.set(cpu_id, false);
assert!(
ax_set_current_affinity(cpumask).is_ok(),
"Change CPU affinity failed!"
);
}

for _t in 0..NUM_TIMES {
// Test CPU affinity here.
#[cfg(feature = "axstd")]
assert_ne!(this_cpu_id(), cpu_id, "CPU affinity changes failed!");
thread::yield_now();
}
let _ = FINISHED_TASKS.fetch_add(1, Ordering::Relaxed);
});
}

while FINISHED_TASKS.load(Ordering::Relaxed) < NUM_TASKS {
thread::yield_now();
}

println!("Task affinity tests run OK!");
}
3 changes: 3 additions & 0 deletions rust/task/affinity/test_cmd
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
test_one "SMP=4 LOG=info" "expect_info_smp4_fifo.out"
test_one "SMP=4 LOG=info FEATURES=sched_rr" "expect_info_smp4_rr.out"
test_one "SMP=4 LOG=info FEATURES=sched_cfs" "expect_info_smp4_cfs.out"
4 changes: 2 additions & 2 deletions rust/task/parallel/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ fn barrier() {
static BARRIER_COUNT: AtomicUsize = AtomicUsize::new(0);

BARRIER_COUNT.fetch_add(1, Ordering::Relaxed);
api::ax_wait_queue_wait(
api::ax_wait_queue_wait_until(
&BARRIER_WQ,
|| BARRIER_COUNT.load(Ordering::Relaxed) == NUM_TASKS,
None,
Expand Down Expand Up @@ -60,7 +60,7 @@ fn main() {
#[cfg(feature = "axstd")]
{
// equals to sleep(500ms)
let timeout = api::ax_wait_queue_wait(
let timeout = api::ax_wait_queue_wait_until(
&AxWaitQueueHandle::new(),
|| false,
Some(std::time::Duration::from_millis(500)),
Expand Down
9 changes: 9 additions & 0 deletions rust/task/wait_queue/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
[package]
name = "wait_queue"
version = "0.1.0"
edition = "2021"
authors = ["Keyang Hu <[email protected]>"]
description = "A simple demo to test the wait queue for tasks under ArceOS"

[dependencies]
axstd = { workspace = true, features = ["multitask", "irq"], optional = true }
33 changes: 33 additions & 0 deletions rust/task/wait_queue/expect_info_smp1_fifo.out
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
smp = 1
build_mode = release
log_level = info

Primary CPU 0 started,
Found physcial memory regions:
.text (READ | EXECUTE | RESERVED)
.rodata (READ | RESERVED)
.data .tdata .tbss .percpu (READ | WRITE | RESERVED)
.percpu (READ | WRITE | RESERVED)
boot stack (READ | WRITE | RESERVED)
.bss (READ | WRITE | RESERVED)
free memory (READ | WRITE | FREE)
Initialize global memory allocator...
Initialize platform devices...
Initialize scheduling...
use FIFO scheduler.
Initialize interrupt handlers...
Primary CPU 0 init OK.
Hello, main task
wait_queue: test_wait()
wait_queue: test_wait() OK!
wait_timeout_until: tests begin
wait_timeout_until: test tasks woken up by notification, spawn 16 tasks...
wait_timeout_until: sleep for 100ms to let all tasks start
wait_timeout_until: wake up all tasks who are waiting for timeout through notification
wait_timeout_until: tasks woken up by notification test OK!
wait_timeout_until: test tasks woken up by timeout, spawn 16 tasks...
wait_timeout_until: wait for all tasks to finish
wait_timeout_until: tasks woken up by timeout test OK!
wait_timeout_until: test tasks woken up by notification or timeout, spawn 16 tasks...
wait_timeout_until: test tasks woken up by notification or timeout, test OK!
Shutting down...
39 changes: 39 additions & 0 deletions rust/task/wait_queue/expect_info_smp4_cfs.out
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
smp = 4
build_mode = release
log_level = info

CPU 0 started
Found physcial memory regions:
.text (READ | EXECUTE | RESERVED)
.rodata (READ | RESERVED)
.data .tdata .tbss .percpu (READ | WRITE | RESERVED)
.percpu (READ | WRITE | RESERVED)
boot stack (READ | WRITE | RESERVED)
.bss (READ | WRITE | RESERVED)
free memory (READ | WRITE | FREE)
Initialize global memory allocator...
Initialize platform devices...
Initialize scheduling...
use Completely Fair scheduler.
Initialize interrupt handlers...
CPU 0 init OK
CPU 1 started
CPU 2 started
CPU 3 started
CPU 1 init OK
CPU 2 init OK
CPU 3 init OK
Hello, main task
wait_queue: test_wait()
wait_queue: test_wait() OK!
wait_timeout_until: tests begin
wait_timeout_until: test tasks woken up by notification, spawn 16 tasks...
wait_timeout_until: sleep for 100ms to let all tasks start
wait_timeout_until: wake up all tasks who are waiting for timeout through notification
wait_timeout_until: tasks woken up by notification test OK!
wait_timeout_until: test tasks woken up by timeout, spawn 16 tasks...
wait_timeout_until: wait for all tasks to finish
wait_timeout_until: tasks woken up by timeout test OK!
wait_timeout_until: test tasks woken up by notification or timeout, spawn 16 tasks...
wait_timeout_until: test tasks woken up by notification or timeout, test OK!
Shutting down...
39 changes: 39 additions & 0 deletions rust/task/wait_queue/expect_info_smp4_fifo.out
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
smp = 4
build_mode = release
log_level = info

CPU 0 started
Found physcial memory regions:
.text (READ | EXECUTE | RESERVED)
.rodata (READ | RESERVED)
.data .tdata .tbss .percpu (READ | WRITE | RESERVED)
.percpu (READ | WRITE | RESERVED)
boot stack (READ | WRITE | RESERVED)
.bss (READ | WRITE | RESERVED)
free memory (READ | WRITE | FREE)
Initialize global memory allocator...
Initialize platform devices...
Initialize scheduling...
use FIFO scheduler.
Initialize interrupt handlers...
CPU 0 init OK
CPU 1 started
CPU 2 started
CPU 3 started
CPU 1 init OK
CPU 2 init OK
CPU 3 init OK
Hello, main task
wait_queue: test_wait()
wait_queue: test_wait() OK!
wait_timeout_until: tests begin
wait_timeout_until: test tasks woken up by notification, spawn 16 tasks...
wait_timeout_until: sleep for 100ms to let all tasks start
wait_timeout_until: wake up all tasks who are waiting for timeout through notification
wait_timeout_until: tasks woken up by notification test OK!
wait_timeout_until: test tasks woken up by timeout, spawn 16 tasks...
wait_timeout_until: wait for all tasks to finish
wait_timeout_until: tasks woken up by timeout test OK!
wait_timeout_until: test tasks woken up by notification or timeout, spawn 16 tasks...
wait_timeout_until: test tasks woken up by notification or timeout, test OK!
Shutting down...
Loading
Loading