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

deallocate tasks when dropping a scheduler #442

Open
hawkw opened this issue Jun 7, 2023 · 3 comments
Open

deallocate tasks when dropping a scheduler #442

hawkw opened this issue Jun 7, 2023 · 3 comments
Assignees
Labels
crate/maitake Related to the `maitake` crate

Comments

@hawkw
Copy link
Owner

hawkw commented Jun 7, 2023

dropping an Arced scheduler should drop any tasks that have been spawned on that scheduler.

this is easy when the tasks have been woken, as we can simply drain the run queue. however, we don't have a way to "find" tasks bound to the scheduler that are not in the run queue. we probably need a linked list of all tasks bound to a scheduler, so that they can all be found even if they have not yet been woken.

the StaticScheduler and LocalStaticScheduler types cannot be dropped. therefore, they will never need to drop all their owned tasks. we should avoid introducing any new overhead for handling task dropping for those scheduler types.

@hawkw hawkw self-assigned this Jun 7, 2023
@hawkw hawkw added the crate/maitake Related to the `maitake` crate label Jun 7, 2023
@hawkw
Copy link
Owner Author

hawkw commented Jan 25, 2024

i don't want to add a linked list of all owned tasks that requires locking a Mutex on spawn to bind the task... we should consider adding a linked list variant where pushes don't need a &mut borrow, so tasks can be registered concurrently with a read lock.

this could also be useful for optimizing some synchronization primitives.

@hawkw
Copy link
Owner Author

hawkw commented Jan 25, 2024

OTTOH since an owned-task list is per-scheduler, real contention only occurs in the face of external spawns from other cores...

on the other hand, an owned task list would be potentially be contended in the face of work-stealing.

@hawkw
Copy link
Owner Author

hawkw commented Jan 25, 2024

on the third hand, random-access removals from an owned-tasks list only occur on task completion, which is always happening from "inside" the scheduler; this is quite different from sync primitive waitlists, where a cancelled future can remove itself at any time. and, because newly-spawned tasks are in a run queue, scheduler shutdown can drop them when it drains the run queue, so tasks don't need to be added to an owned task list when they're spawned. instead, they only need to be added to owned tasks the first time they yield. so, the owned tasks list can be owned exclusively by the scheduler itself.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
crate/maitake Related to the `maitake` crate
Projects
None yet
Development

No branches or pull requests

1 participant