diff options
| author | Philipp Brüschweiler <blei42@gmail.com> | 2012-09-14 15:01:17 +0200 |
|---|---|---|
| committer | Brian Anderson <banderson@mozilla.com> | 2012-09-19 14:01:53 -0700 |
| commit | 68e755b1c26db09cf8e121bbbea2075f6116e279 (patch) | |
| tree | 8d48dc089bb9effd2090117fd6033c4ca81470d1 /src/rt/rust_kernel.cpp | |
| parent | 35a935377483823ca1fbaede5a87406b494b0488 (diff) | |
| download | rust-68e755b1c26db09cf8e121bbbea2075f6116e279.tar.gz rust-68e755b1c26db09cf8e121bbbea2075f6116e279.zip | |
core: Allocate threads on demand, not on scheduler startup
API change: rust_kernel::create_scheduler() or rust_scheduler::rust_scheduler() respecitevly now take ownership of the launch factory argument, it is needed to create new threads on demand. Also renames rustrt::sched_threads() to rustrt::rust_sched_threads() for consistency. Added rustrt::rust_max_sched_threads() to return the maximal number of scheduled threads of the current scheduler. Fixes #3493.
Diffstat (limited to 'src/rt/rust_kernel.cpp')
| -rw-r--r-- | src/rt/rust_kernel.cpp | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/src/rt/rust_kernel.cpp b/src/rt/rust_kernel.cpp index 698ee866728..669ebd55a7c 100644 --- a/src/rt/rust_kernel.cpp +++ b/src/rt/rust_kernel.cpp @@ -31,9 +31,10 @@ rust_kernel::rust_kernel(rust_env *env) : // Create the single threaded scheduler that will run on the platform's // main thread - rust_manual_sched_launcher_factory launchfac; - osmain_scheduler = create_scheduler(&launchfac, 1, false); - osmain_driver = launchfac.get_driver(); + rust_manual_sched_launcher_factory *launchfac = + new rust_manual_sched_launcher_factory(); + osmain_scheduler = create_scheduler(launchfac, 1, false); + osmain_driver = launchfac->get_driver(); sched_reaper.start(); } @@ -79,8 +80,9 @@ void rust_kernel::free(void *mem) { rust_sched_id rust_kernel::create_scheduler(size_t num_threads) { - rust_thread_sched_launcher_factory launchfac; - return create_scheduler(&launchfac, num_threads, true); + rust_thread_sched_launcher_factory *launchfac = + new rust_thread_sched_launcher_factory(); + return create_scheduler(launchfac, num_threads, true); } rust_sched_id |
