fix: assorted small priority queue fixes

master
Sean McBride 5 years ago
parent 2d03fe390b
commit bfe19dce69

@ -25,7 +25,6 @@ priority_queue_append(struct priority_queue *self, void *new_item)
if (self->first_free >= MAX) return -1; if (self->first_free >= MAX) return -1;
self->items[self->first_free++] = new_item; self->items[self->first_free++] = new_item;
// self->first_free++;
return 0; return 0;
} }
@ -144,7 +143,6 @@ priority_queue_length(struct priority_queue *self)
{ {
assert(self != NULL); assert(self != NULL);
ck_spinlock_fas_lock(&self->lock); ck_spinlock_fas_lock(&self->lock);
assert(ck_spinlock_fas_locked(&self->lock));
int length = self->first_free - 1; int length = self->first_free - 1;
ck_spinlock_fas_unlock(&self->lock); ck_spinlock_fas_unlock(&self->lock);
return length; return length;
@ -163,7 +161,6 @@ priority_queue_enqueue(struct priority_queue *self, void *value, char *name)
int pre_length = self->first_free - 1; int pre_length = self->first_free - 1;
/* Start of Critical Section */
if (priority_queue_append(self, value) == -1) { if (priority_queue_append(self, value) == -1) {
printf("Priority Queue is full"); printf("Priority Queue is full");
fflush(stdout); fflush(stdout);
@ -183,7 +180,6 @@ priority_queue_enqueue(struct priority_queue *self, void *value, char *name)
} else { } else {
priority_queue_percolate_up(self); priority_queue_percolate_up(self);
} }
/* End of Critical Section */
ck_spinlock_fas_unlock(&self->lock); ck_spinlock_fas_unlock(&self->lock);
return 0; return 0;
} }
@ -240,8 +236,7 @@ priority_queue_dequeue(struct priority_queue *self, char *name)
if (priority_queue_is_empty(self)) return NULL; if (priority_queue_is_empty(self)) return NULL;
ck_spinlock_fas_lock(&self->lock); ck_spinlock_fas_lock(&self->lock);
assert(ck_spinlock_fas_locked(&self->lock));
/* Start of Critical Section */
void *min = NULL; void *min = NULL;
if (!priority_queue_is_empty(self)) { if (!priority_queue_is_empty(self)) {
min = self->items[1]; min = self->items[1];
@ -251,17 +246,25 @@ priority_queue_dequeue(struct priority_queue *self, char *name)
if (self->first_free > 2) priority_queue_percolate_down(self, 1); if (self->first_free > 2) priority_queue_percolate_down(self, 1);
/* Update the highest priority */ /* Update the highest priority */
self->highest_priority = !priority_queue_is_empty(self) ? self->get_priority(self->items[1]) if (!priority_queue_is_empty(self)) {
: ULONG_MAX; self->highest_priority = self->get_priority(self->items[1]);
} else {
self->highest_priority = ULONG_MAX;
}
} }
ck_spinlock_fas_unlock(&self->lock); ck_spinlock_fas_unlock(&self->lock);
/* End of Critical Section */
return min; return min;
} }
/**
* Peek at the priority of the highest priority task without having to take the lock
* Because this is a min-heap PQ, the highest priority is the lowest 64-bit integer
* This is used to store an absolute deadline
* @returns value of highest priority value in queue or ULONG_MAX if empty
*/
uint64_t uint64_t
priority_queue_peek(struct priority_queue *self) priority_queue_peek(struct priority_queue *self)
{ {
uint64_t highest_priority = self->highest_priority; return self->highest_priority;
return highest_priority;
} }
Loading…
Cancel
Save