Sun, 08 Aug 2010 19:36:31 +0200 |
wenzelm |
explicitly distinguish Output.status (essential feedback) vs. Output.report (useful markup);
|
file |
diff |
annotate
|
Thu, 22 Jul 2010 10:41:12 +0200 |
wenzelm |
tuned comments;
|
file |
diff |
annotate
|
Wed, 21 Jul 2010 13:25:14 +0200 |
wenzelm |
clarified/exported Future.worker_subgroup, which is already the default for Future.fork;
|
file |
diff |
annotate
|
Tue, 20 Jul 2010 17:35:42 +0200 |
wenzelm |
back to more strict dependencies, even for canceled groups (reverting parts of 02936e77a07c);
|
file |
diff |
annotate
|
Tue, 20 Jul 2010 14:44:33 +0200 |
wenzelm |
eliminated old-style sys_error/SYS_ERROR in favour of exception Fail -- after careful checking that there is no overlap with existing handling of that;
|
file |
diff |
annotate
|
Sun, 04 Jul 2010 21:01:22 +0200 |
wenzelm |
general Future.report -- also for Toplevel.async_state;
|
file |
diff |
annotate
|
Fri, 02 Jul 2010 20:44:17 +0200 |
wenzelm |
tuned white space;
|
file |
diff |
annotate
|
Mon, 31 May 2010 21:06:57 +0200 |
wenzelm |
modernized some structure names, keeping a few legacy aliases;
|
file |
diff |
annotate
|
Sat, 29 May 2010 15:31:15 +0200 |
wenzelm |
future result: retain plain Interrupt for vacuous group exceptions;
|
file |
diff |
annotate
|
Fri, 21 May 2010 21:28:31 +0200 |
wenzelm |
future_job: propagate current Position.thread_data to the forked job -- this is important to provide a default position, e.g. for parallelizied Goal.prove within a package (proper command transactions are wrapped via Toplevel.setmp_thread_position);
|
file |
diff |
annotate
|
Sat, 06 Feb 2010 22:06:18 +0100 |
wenzelm |
result: Single_Assignment.var;
|
file |
diff |
annotate
|
Wed, 06 Jan 2010 18:22:43 +0100 |
wenzelm |
more robust cancelation, notably of passive futures without scheduler running;
|
file |
diff |
annotate
|
Wed, 06 Jan 2010 18:14:16 +0100 |
wenzelm |
eliminated cache, which complicates the code without making a real difference (NB: deque_towards often disrupts caching, and daisy-chaining of workers already reduces queue overhead);
|
file |
diff |
annotate
|
Wed, 06 Jan 2010 15:07:56 +0100 |
wenzelm |
tasks of canceled groups are considered "ready" -- enables to purge the queue from tasks depending on unfinished promises (also improves general reactivity);
|
file |
diff |
annotate
|
Tue, 05 Jan 2010 23:38:10 +0100 |
wenzelm |
added Future.promise/fulfill -- promised futures that are fulfilled by external means;
|
file |
diff |
annotate
|
Thu, 05 Nov 2009 13:16:22 +0100 |
wenzelm |
scheduler: clarified interrupt attributes and handling;
|
file |
diff |
annotate
|
Thu, 05 Nov 2009 13:01:11 +0100 |
wenzelm |
worker_next: plain signalling via work_available only, not scheduler_event;
|
file |
diff |
annotate
|
Wed, 04 Nov 2009 21:22:35 +0100 |
wenzelm |
avoid broadcast work_available, use daisy-chained signal instead;
|
file |
diff |
annotate
|
Wed, 04 Nov 2009 20:31:36 +0100 |
wenzelm |
worker_next: treat wait for work_available as Sleeping, not Waiting;
|
file |
diff |
annotate
|
Wed, 04 Nov 2009 11:58:29 +0100 |
wenzelm |
worker activity: distinguish between waiting (formerly active) and sleeping;
|
file |
diff |
annotate
|
Wed, 04 Nov 2009 11:37:06 +0100 |
wenzelm |
tuned;
|
file |
diff |
annotate
|
Wed, 04 Nov 2009 11:30:22 +0100 |
wenzelm |
tuned thread data;
|
file |
diff |
annotate
|
Wed, 04 Nov 2009 00:29:58 +0100 |
wenzelm |
worker_next: ensure that work_available is passed on before sleeping (was occasionally lost when worker configuration changed, causing scheduler deadlock);
|
file |
diff |
annotate
|
Tue, 03 Nov 2009 19:52:09 +0100 |
wenzelm |
slightly leaner and more direct control of worker activity etc.;
|
file |
diff |
annotate
|
Thu, 22 Oct 2009 15:21:01 +0200 |
wenzelm |
use Synchronized.assign to achieve actual immutable results;
|
file |
diff |
annotate
|
Thu, 01 Oct 2009 16:27:13 +0200 |
wenzelm |
added Task_Queue.depend (again) -- light-weight version for transitive graph;
|
file |
diff |
annotate
|
Tue, 29 Sep 2009 11:49:22 +0200 |
wenzelm |
explicit indication of Unsynchronized.ref;
|
file |
diff |
annotate
|
Mon, 28 Sep 2009 12:09:18 +0200 |
wenzelm |
added fork_deps_pri;
|
file |
diff |
annotate
|
Tue, 22 Sep 2009 20:25:31 +0200 |
wenzelm |
full reserve of worker threads -- for improved CPU utilization;
|
file |
diff |
annotate
|
Sun, 20 Sep 2009 19:17:33 +0200 |
wenzelm |
tuned tracing;
|
file |
diff |
annotate
|
Sun, 20 Sep 2009 18:37:55 +0200 |
wenzelm |
scheduler backdoor: 9999 means 1 worker;
|
file |
diff |
annotate
|
Wed, 16 Sep 2009 22:46:10 +0200 |
wenzelm |
Synchronized.value does not require locking, since assigments are atomic;
|
file |
diff |
annotate
|
Thu, 27 Aug 2009 17:00:03 +0200 |
wenzelm |
tuned tracing;
|
file |
diff |
annotate
|
Sat, 01 Aug 2009 00:17:03 +0200 |
wenzelm |
future scheduler: uninterruptible cancelation;
|
file |
diff |
annotate
|
Sat, 01 Aug 2009 00:09:45 +0200 |
wenzelm |
renamed Multithreading.regular_interrupts to Multithreading.public_interrupts;
|
file |
diff |
annotate
|
Thu, 30 Jul 2009 23:37:53 +0200 |
wenzelm |
tuned tracing;
|
file |
diff |
annotate
|
Thu, 30 Jul 2009 23:06:06 +0200 |
wenzelm |
added Multithreading.sync_wait, which turns enabled interrupts to sync ones, to ensure that wait will reaquire its lock when interrupted;
|
file |
diff |
annotate
|
Tue, 28 Jul 2009 16:30:23 +0200 |
wenzelm |
eliminated separate Future.enabled -- let Future.join fail explicitly in critical section, instead of entering sequential mode silently;
|
file |
diff |
annotate
|
Tue, 28 Jul 2009 15:10:15 +0200 |
wenzelm |
future result: Synchronized.var;
|
file |
diff |
annotate
|
Tue, 28 Jul 2009 14:35:27 +0200 |
wenzelm |
Task_Queue.dequeue: explicit thread;
|
file |
diff |
annotate
|
Tue, 28 Jul 2009 14:29:25 +0200 |
wenzelm |
more precise treatment of scheduler_event: continous pulse (50ms) instead of flooding, which was burning many CPU cycles in spare threads;
|
file |
diff |
annotate
|
Tue, 28 Jul 2009 14:11:15 +0200 |
wenzelm |
interruptible_task: unified treatment of Multithreading.with_attributes (cf. 9f6461b1c9cc);
|
file |
diff |
annotate
|
Tue, 28 Jul 2009 14:04:33 +0200 |
wenzelm |
misc tuning;
|
file |
diff |
annotate
|
Mon, 27 Jul 2009 17:36:30 +0200 |
wenzelm |
interruptible: Thread.testInterrupt before changing thread attributes;
|
file |
diff |
annotate
|
Mon, 27 Jul 2009 17:12:19 +0200 |
wenzelm |
wait: absorb spurious interrupts;
|
file |
diff |
annotate
|
Mon, 27 Jul 2009 16:53:28 +0200 |
wenzelm |
scheduler: shutdown spontaneously (after some delay) if queue is empty;
|
file |
diff |
annotate
|
Mon, 27 Jul 2009 16:08:41 +0200 |
wenzelm |
join_next: do not yield, even if overloaded, to minimize "running" tasks;
|
file |
diff |
annotate
|
Mon, 27 Jul 2009 15:53:43 +0200 |
wenzelm |
tuned tracing;
|
file |
diff |
annotate
|
Mon, 27 Jul 2009 15:30:21 +0200 |
wenzelm |
cancel: improved reactivity due to more careful broadcasting;
|
file |
diff |
annotate
|
Mon, 27 Jul 2009 15:06:33 +0200 |
wenzelm |
dequeue_towards: always return active tasks;
|
file |
diff |
annotate
|
Mon, 27 Jul 2009 13:32:23 +0200 |
wenzelm |
removed unused low-level interrupts;
|
file |
diff |
annotate
|
Mon, 27 Jul 2009 12:16:58 +0200 |
wenzelm |
tuned;
|
file |
diff |
annotate
|
Mon, 27 Jul 2009 12:11:18 +0200 |
wenzelm |
more specific conditions: scheduler_event, work_available, work_finished -- considereably reduces overhead with many threads;
|
file |
diff |
annotate
|
Sat, 25 Jul 2009 00:53:47 +0200 |
wenzelm |
tuned tracing;
|
file |
diff |
annotate
|
Wed, 22 Jul 2009 10:46:35 +0200 |
wenzelm |
future_job: more robust Exn.capture outside thread attribute change;
|
file |
diff |
annotate
|
Tue, 21 Jul 2009 23:42:29 +0200 |
wenzelm |
future_job: tight scope for interrupts, to prevent shooting ourselves in the foot via cancel_group;
|
file |
diff |
annotate
|
Tue, 21 Jul 2009 20:37:31 +0200 |
wenzelm |
added worker_group;
|
file |
diff |
annotate
|
Tue, 21 Jul 2009 15:25:22 +0200 |
wenzelm |
propagate exceptions within future groups;
|
file |
diff |
annotate
|
Tue, 21 Jul 2009 13:42:48 +0200 |
wenzelm |
tuned;
|
file |
diff |
annotate
|
Tue, 21 Jul 2009 11:30:12 +0200 |
wenzelm |
tuned tracing;
|
file |
diff |
annotate
|