Skip to content

Commit dc7a38b

Browse files
committed
---
yaml --- r: 88850 b: refs/heads/snap-stage3 c: 8be66e2 h: refs/heads/master v: v3
1 parent 41dde35 commit dc7a38b

File tree

2 files changed

+21
-6
lines changed

2 files changed

+21
-6
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,7 @@
11
---
22
refs/heads/master: deeca5d586bfaa4aa60246f671a8d611d38f6248
33
refs/heads/snap-stage1: e33de59e47c5076a89eadeb38f4934f58a3618a6
4-
refs/heads/snap-stage3: 14caf00c92b40e3f62094db54f325196c8a05d5a
4+
refs/heads/snap-stage3: 8be66e212b37045b927138965a76abe3608325ca
55
refs/heads/try: b160761e35efcd1207112b3b782c06633cf441a8
66
refs/tags/release-0.1: 1f5c5126e96c79d22cb7862f75304136e204f105
77
refs/heads/ndm: f3868061cd7988080c30d6d5bf352a5a5fe2460b

branches/snap-stage3/src/libstd/comm/mod.rs

Lines changed: 20 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -238,7 +238,6 @@ use rt::local::Local;
238238
use rt::task::{Task, BlockedTask};
239239
use rt::thread::Thread;
240240
use sync::atomics::{AtomicInt, AtomicBool, SeqCst, Relaxed};
241-
use task;
242241
use vec::{ImmutableVector, OwnedVector};
243242

244243
use spsc = sync::spsc_queue;
@@ -346,6 +345,7 @@ struct Packet {
346345
selection_id: uint,
347346
select_next: *mut Packet,
348347
select_prev: *mut Packet,
348+
recv_cnt: int,
349349
}
350350

351351
///////////////////////////////////////////////////////////////////////////////
@@ -367,6 +367,7 @@ impl Packet {
367367
selection_id: 0,
368368
select_next: 0 as *mut Packet,
369369
select_prev: 0 as *mut Packet,
370+
recv_cnt: 0,
370371
}
371372
}
372373

@@ -611,8 +612,9 @@ impl<T: Send> Chan<T> {
611612
// the TLS overhead can be a bit much.
612613
n => {
613614
assert!(n >= 0);
614-
if can_resched && n > 0 && n % RESCHED_FREQ == 0 {
615-
task::deschedule();
615+
if n > 0 && n % RESCHED_FREQ == 0 {
616+
let task: ~Task = Local::take();
617+
task.maybe_yield();
616618
}
617619
true
618620
}
@@ -704,8 +706,9 @@ impl<T: Send> SharedChan<T> {
704706
DISCONNECTED => {} // oh well, we tried
705707
-1 => { (*packet).wakeup(can_resched); }
706708
n => {
707-
if can_resched && n > 0 && n % RESCHED_FREQ == 0 {
708-
task::deschedule();
709+
if n > 0 && n % RESCHED_FREQ == 0 {
710+
let task: ~Task = Local::take();
711+
task.maybe_yield();
709712
}
710713
}
711714
}
@@ -773,6 +776,18 @@ impl<T: Send> Port<T> {
773776
// This is a "best effort" situation, so if a queue is inconsistent just
774777
// don't worry about it.
775778
let this = unsafe { cast::transmute_mut(self) };
779+
780+
// See the comment about yielding on sends, but the same applies here.
781+
// If a thread is spinning in try_recv we should try
782+
unsafe {
783+
let packet = this.queue.packet();
784+
(*packet).recv_cnt += 1;
785+
if (*packet).recv_cnt % RESCHED_FREQ == 0 {
786+
let task: ~Task = Local::take();
787+
task.maybe_yield();
788+
}
789+
}
790+
776791
let ret = match this.queue {
777792
SPSC(ref mut queue) => queue.pop(),
778793
MPSC(ref mut queue) => match queue.pop() {

0 commit comments

Comments
 (0)