rt-thread-official/include
Shell 2f6d98bfcb feat: smp_call: added signaling call_req
This patch introduces `rt_smp_call_request` API to handle queued
requests across cores with user provided data buffer, which provides a
way to request IPI through a non-blocking pattern.

It also resolved several issues in the old implementation:
- Multiple requests from different cores can not be queued in the work
  object of the target core.
- Data racing on `rt_smp_work` of same core. If multiple requests came
  in turns, or if the call is used by the target cpu, while a new
  request is coming, the value will be overwrite.
- Memory vulnerability. The rt_smp_event is allocated on stack, though
  the caller may not wait until the call is done.
- API naming problem. Actually we don't provide a way to issue an IPI to
  ANY core in mask. What the API do is aligned to MANY pattern.
- FUNC_IPI registering to PIC.

Changes:
- Declared and configured the new `RT_SMP_CALL_IPI` to support
  functional IPIs for task requests across cores.
- Replaced the single `rt_smp_work` array with `call_req_cores` to
  manage per-core call requests safely.
- Added `_call_req_take` and `_call_req_release` functions for atomic
  handling of request lifetimes, preventing data race conditions.
- Replaced single event handling with a queue-based approach
  (`call_queue`) for efficient multi-request processing per core.
- Introduced `rt_smp_call_ipi_handler` to process queued requests,
  reducing IPI contention by only sending new requests when needed.
- Implemented `_smp_call_remote_request` to handle remote requests
  with specific flags, enabling more flexible core-to-core task
  signaling.
- Refined `rt_smp_call_req_init` to initialize and track requests
  with atomic usage flags, mitigating potential memory vulnerabilities.

Signed-off-by: Shell <smokewood@qq.com>
2024-11-03 10:08:45 +08:00
..
klibc [klibc] add kerrno.h 2024-09-23 21:30:37 +08:00
rtatomic.h feat: rtatomic: lockless single linked list 2024-11-03 10:08:45 +08:00
rtcompiler.h Fixed an issue in mdk where macro definitions are not supported in the C99 specification 2024-03-20 22:43:55 +08:00
rtdbg.h [debug] 整理debug宏并增加RT_DEBUGING_CONTEXT (#7805) 2023-07-22 10:36:42 +08:00
rtdef.h feat: smp_call: added signaling call_req 2024-11-03 10:08:45 +08:00
rthw.h feat: kernel/libcpu: fit into ilp32d 2024-09-01 15:12:34 -04:00
rtklibc.h [klibc] add kerrno.h 2024-09-23 21:30:37 +08:00
rtm.h [rtdef] use lower-case to define attributes (#6728) 2022-12-11 13:12:03 -05:00
rtsched.h feat: remove RT_USING_SCHED_THREAD_CTX 2024-10-19 15:19:41 -04:00
rtservice.h feat: Added rt_interrupt_context* family for nested interrupt handling 2024-11-03 10:08:45 +08:00
rtthread.h feat: Added rt_interrupt_context* family for nested interrupt handling 2024-11-03 10:08:45 +08:00
rttypes.h feat: rtatomic: lockless single linked list 2024-11-03 10:08:45 +08:00