Skip to content

Commit

Permalink
* thread.c, vm_core.h: add manual priority support
Browse files Browse the repository at this point in the history
  using time slice.  if you enable USE_NATIVE_THREAD_PRIORITY
  macro, this mechanism is ignored.  [ruby-dev:33124]
* thread_pthread.c, thread_win32.c: ditto.
* test/ruby/test_thread.rb: fix test parameter.



git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@18570 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
  • Loading branch information
ko1 committed Aug 13, 2008
1 parent 81719af commit 16612b3
Show file tree
Hide file tree
Showing 6 changed files with 59 additions and 2 deletions.
10 changes: 10 additions & 0 deletions ChangeLog
Original file line number Diff line number Diff line change
@@ -1,3 +1,13 @@
Wed Aug 13 16:40:57 2008 Koichi Sasada <[email protected]>

* thread.c, vm_core.h: add manual priority support
using time slice. if you enable USE_NATIVE_THREAD_PRIORITY
macro, this mechanism is ignored. [ruby-dev:33124]

* thread_pthread.c, thread_win32.c: ditto.

* test/ruby/test_thread.rb: fix test parameter.

Wed Aug 13 16:02:14 2008 Shugo Maeda <[email protected]>

* object.c (rb_obj_untrusted): new method Object#untrusted?.
Expand Down
2 changes: 1 addition & 1 deletion test/ruby/test_thread.rb
Original file line number Diff line number Diff line change
Expand Up @@ -126,7 +126,7 @@ def test_priority
sleep 0.5
t1.kill
t2.kill
assert(c1 > c2 * 2, "[ruby-dev:33124]")
assert(c1 > c2 * 1.5, "[ruby-dev:33124]")
end

def test_new
Expand Down
39 changes: 38 additions & 1 deletion thread.c
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,12 @@
#include "vm.h"
#include "gc.h"

#ifndef USE_NATIVE_THREAD_PRIORITY
#define USE_NATIVE_THREAD_PRIORITY 0
#define RUBY_THREAD_PRIORITY_MAX 3
#define RUBY_THREAD_PRIORITY_MIN -3
#endif

#ifndef THREAD_DEBUG
#define THREAD_DEBUG 0
#endif
Expand Down Expand Up @@ -996,8 +1002,26 @@ rb_thread_execute_interrupts(rb_thread_t *th)
}

if (timer_interrupt) {
#if USE_NATIVE_THREAD_PRIORITY
EXEC_EVENT_HOOK(th, RUBY_EVENT_SWITCH, th->cfp->self, 0, 0);
rb_thread_schedule();
#else
if (th->slice > 0) {
th->slice--;
}
else {
reschedule:
EXEC_EVENT_HOOK(th, RUBY_EVENT_SWITCH, th->cfp->self, 0, 0);
rb_thread_schedule();
if (th->slice < 0) {
th->slice++;
goto reschedule;
}
else {
th->slice = th->priority;
}
}
#endif
}
}
}
Expand Down Expand Up @@ -1847,12 +1871,25 @@ rb_thread_priority_set(VALUE thread, VALUE prio)
{
rb_thread_t *th;
GetThreadPtr(thread, th);
int priority;

rb_secure(4);

#if USE_NATIVE_THREAD_PRIORITY
th->priority = NUM2INT(prio);
native_thread_apply_priority(th);
return prio;
#else
priority = NUM2INT(prio);
if (priority > RUBY_THREAD_PRIORITY_MAX) {
priority = RUBY_THREAD_PRIORITY_MAX;
}
else if (priority < RUBY_THREAD_PRIORITY_MIN) {
priority = RUBY_THREAD_PRIORITY_MIN;
}
th->priority = priority;
th->slice = priority;
#endif
return INT2NUM(th->priority);
}

/* for IO */
Expand Down
5 changes: 5 additions & 0 deletions thread_pthread.c
Original file line number Diff line number Diff line change
Expand Up @@ -443,6 +443,9 @@ native_thread_join(pthread_t th)
}
}


#if USE_NATIVE_THREAD_PRIORITY

static void
native_thread_apply_priority(rb_thread_t *th)
{
Expand All @@ -469,6 +472,8 @@ native_thread_apply_priority(rb_thread_t *th)
#endif
}

#endif /* USE_NATIVE_THREAD_PRIORITY */

static void
ubf_pthread_cond_signal(void *ptr)
{
Expand Down
4 changes: 4 additions & 0 deletions thread_win32.c
Original file line number Diff line number Diff line change
Expand Up @@ -499,6 +499,8 @@ native_thread_join(HANDLE th)
w32_wait_events(&th, 1, 0, 0);
}

#if USE_NATIVE_THREAD_PRIORITY

static void
native_thread_apply_priority(rb_thread_t *th)
{
Expand All @@ -516,6 +518,8 @@ native_thread_apply_priority(rb_thread_t *th)
SetThreadPriority(th->thread_id, priority);
}

#endif /* USE_NATIVE_THREAD_PRIORITY */

static void
ubf_handle(void *ptr)
{
Expand Down
1 change: 1 addition & 0 deletions vm_core.h
Original file line number Diff line number Diff line change
Expand Up @@ -432,6 +432,7 @@ struct rb_thread_struct
rb_thread_id_t thread_id;
enum rb_thread_status status;
int priority;
int slice;

native_thread_data_t native_thread_data;

Expand Down

0 comments on commit 16612b3

Please sign in to comment.