File tree Expand file tree Collapse file tree 2 files changed +15
-1
lines changed Expand file tree Collapse file tree 2 files changed +15
-1
lines changed Original file line number Diff line number Diff line change 1
1
---
2
- refs/heads/master: 80f92f5c5fedadd131842977c0b9b21806f3902f
2
+ refs/heads/master: 91bed14ca8085887a26d029d785d853ad2587718
3
3
refs/heads/snap-stage1: e33de59e47c5076a89eadeb38f4934f58a3618a6
4
4
refs/heads/snap-stage3: b8601a3d8b91ad3b653d143307611f2f5c75617e
5
5
refs/heads/try: db814977d07bd798feb24f6b74c00800ef458a13
Original file line number Diff line number Diff line change @@ -832,6 +832,20 @@ impl Scheduler {
832
832
}
833
833
834
834
pub fn maybe_yield ( mut ~self , cur : ~GreenTask ) {
835
+ // It's possible for sched tasks to possibly call this function, and it
836
+ // just means that they're likely sending on channels (which
837
+ // occasionally call this function). Sched tasks follow different paths
838
+ // when executing yield_now(), which may possibly trip the assertion
839
+ // below. For this reason, we just have sched tasks bail out soon.
840
+ //
841
+ // Sched tasks have no need to yield anyway because as soon as they
842
+ // return they'll yield to other threads by falling back to the event
843
+ // loop. Additionally, we completely control sched tasks, so we can make
844
+ // sure that they never execute more than enough code.
845
+ if cur. is_sched ( ) {
846
+ return cur. put_with_sched ( self )
847
+ }
848
+
835
849
// The number of times to do the yield check before yielding, chosen
836
850
// arbitrarily.
837
851
rtassert ! ( self . yield_check_count > 0 ) ;
You can’t perform that action at this time.
0 commit comments