diff options
author | ko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2017-06-26 05:30:07 +0000 |
---|---|---|
committer | ko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2017-06-26 05:30:07 +0000 |
commit | facd0883cb7523b6ff67f3a2bfa0a2627f1d5ba5 (patch) | |
tree | eb5684e859514f25f63bddcfa2b798325eb1efab /cont.c | |
parent | d39dd5ede309049cf4c5237f3129294761a9f417 (diff) | |
download | ruby-facd0883cb7523b6ff67f3a2bfa0a2627f1d5ba5.tar.gz |
Do not store/restore Thread#status on fiber switching.
* cont.c (cont_restore_thread): On Fiber switching, thread status shold be
THREAD_RUNNABLE so that we don't need to store/restore this field.
* cont.c (cont_save_thread): ditto.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@59174 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'cont.c')
-rw-r--r-- | cont.c | 4 |
1 files changed, 2 insertions, 2 deletions
@@ -413,7 +413,7 @@ cont_save_thread(rb_context_t *cont, rb_thread_t *th) sth->local_storage = th->local_storage; sth->safe_level = th->safe_level; sth->raised_flag = th->raised_flag; - sth->status = th->status; + VM_ASSERT(th->status == THREAD_RUNNABLE); sth->tag = th->tag; sth->protect_tag = th->protect_tag; sth->errinfo = th->errinfo; @@ -560,7 +560,7 @@ cont_restore_thread(rb_context_t *cont) th->ec.cfp = sth->ec.cfp; th->safe_level = sth->safe_level; th->raised_flag = sth->raised_flag; - th->status = sth->status; + VM_ASSERT(sth->status == THREAD_RUNNABLE); th->tag = sth->tag; th->protect_tag = sth->protect_tag; th->errinfo = sth->errinfo; |