aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorDavid Goulet <dgoulet@torproject.org>2018-02-01 16:39:04 -0500
committerDavid Goulet <dgoulet@torproject.org>2018-02-01 16:39:04 -0500
commite1a40535eaac0cd7306770660da798a0ee247549 (patch)
treebaf0f58eb0ad0d73addfc980ba182bc758aa7f85 /src
parent5516d22a26648f2f3c05324a854cf573b4b5e39c (diff)
parentcb5654f300312a8f4c777378d68696667eff427b (diff)
downloadtor-e1a40535eaac0cd7306770660da798a0ee247549.tar.gz
tor-e1a40535eaac0cd7306770660da798a0ee247549.zip
Merge branch 'bug24700_032_01' into bug24700_033_01
Diffstat (limited to 'src')
-rw-r--r--src/or/channel.c3
-rw-r--r--src/or/scheduler.c20
-rw-r--r--src/or/scheduler_kist.c14
3 files changed, 25 insertions, 12 deletions
diff --git a/src/or/channel.c b/src/or/channel.c
index 094bf93e66..1afd451908 100644
--- a/src/or/channel.c
+++ b/src/or/channel.c
@@ -854,6 +854,9 @@ channel_init(channel_t *chan)
/* Scheduler state is idle */
chan->scheduler_state = SCHED_CHAN_IDLE;
+
+ /* Channel is not in the scheduler heap. */
+ chan->sched_heap_idx = -1;
}
/**
diff --git a/src/or/scheduler.c b/src/or/scheduler.c
index 749df5a248..931122f8d6 100644
--- a/src/or/scheduler.c
+++ b/src/or/scheduler.c
@@ -560,10 +560,12 @@ scheduler_channel_has_waiting_cells,(channel_t *chan))
* channels_pending.
*/
scheduler_set_channel_state(chan, SCHED_CHAN_PENDING);
- smartlist_pqueue_add(channels_pending,
- scheduler_compare_channels,
- offsetof(channel_t, sched_heap_idx),
- chan);
+ if (!SCHED_BUG(chan->sched_heap_idx != -1, chan)) {
+ smartlist_pqueue_add(channels_pending,
+ scheduler_compare_channels,
+ offsetof(channel_t, sched_heap_idx),
+ chan);
+ }
/* If we made a channel pending, we potentially have scheduling work to
* do. */
the_scheduler->schedule();
@@ -678,11 +680,13 @@ scheduler_channel_wants_writes(channel_t *chan)
/*
* It can write now, so it goes to channels_pending.
*/
- smartlist_pqueue_add(channels_pending,
- scheduler_compare_channels,
- offsetof(channel_t, sched_heap_idx),
- chan);
scheduler_set_channel_state(chan, SCHED_CHAN_PENDING);
+ if (!SCHED_BUG(chan->sched_heap_idx != -1, chan)) {
+ smartlist_pqueue_add(channels_pending,
+ scheduler_compare_channels,
+ offsetof(channel_t, sched_heap_idx),
+ chan);
+ }
/* We just made a channel pending, we have scheduling work to do. */
the_scheduler->schedule();
} else {
diff --git a/src/or/scheduler_kist.c b/src/or/scheduler_kist.c
index 424ef05906..43831b72be 100644
--- a/src/or/scheduler_kist.c
+++ b/src/or/scheduler_kist.c
@@ -685,7 +685,6 @@ kist_scheduler_run(void)
* after the scheduling loop is over. They can hopefully be taken care of
* in the next scheduling round.
*/
- scheduler_set_channel_state(chan, SCHED_CHAN_WAITING_TO_WRITE);
if (!to_readd) {
to_readd = smartlist_new();
}
@@ -695,8 +694,10 @@ kist_scheduler_run(void)
/* Case 4: cells to send, and still open for writes */
scheduler_set_channel_state(chan, SCHED_CHAN_PENDING);
- smartlist_pqueue_add(cp, scheduler_compare_channels,
- offsetof(channel_t, sched_heap_idx), chan);
+ if (!SCHED_BUG(chan->sched_heap_idx != -1, chan)) {
+ smartlist_pqueue_add(cp, scheduler_compare_channels,
+ offsetof(channel_t, sched_heap_idx), chan);
+ }
}
} /* End of main scheduling loop */
@@ -716,8 +717,13 @@ kist_scheduler_run(void)
SMARTLIST_FOREACH_BEGIN(to_readd, channel_t *, readd_chan) {
scheduler_set_channel_state(readd_chan, SCHED_CHAN_PENDING);
if (!smartlist_contains(cp, readd_chan)) {
- smartlist_pqueue_add(cp, scheduler_compare_channels,
+ if (!SCHED_BUG(chan->sched_heap_idx != -1, chan)) {
+ /* XXXX Note that the check above is in theory redundant with
+ * the smartlist_contains check. But let's make sure we're
+ * not messing anything up, and leave them both for now. */
+ smartlist_pqueue_add(cp, scheduler_compare_channels,
offsetof(channel_t, sched_heap_idx), readd_chan);
+ }
}
} SMARTLIST_FOREACH_END(readd_chan);
smartlist_free(to_readd);