From b2280748ad5087b5dab54dd4e423053ffe1f2387 Mon Sep 17 00:00:00 2001 From: Martin Mares Date: Wed, 3 Mar 1999 19:33:54 +0000 Subject: Introduced protocol priority (all 'normal' protocols should use the default zero priority). No more "kernel syncer initialized before device routes" problems. --- nest/proto.c | 23 ++++++++++++++++++++--- 1 file changed, 20 insertions(+), 3 deletions(-) (limited to 'nest/proto.c') diff --git a/nest/proto.c b/nest/proto.c index 21f3630..76120fa 100644 --- a/nest/proto.c +++ b/nest/proto.c @@ -37,6 +37,22 @@ static char *c_states[] = { "HUNGRY", "FEEDING", "HAPPY", "FLUSHING" }; static void proto_flush_all(void *); +static void +proto_enqueue(list *l, struct proto *p) +{ + int pri = p->proto->priority; + + if (!pri) + add_tail(l, &p->n); + else + { + struct proto *q = HEAD(*l); + while (q->n.next && q->proto->priority >= pri) + q = (struct proto *) q->n.next; + insert_node(&p->n, q->n.prev); + } +} + static void proto_relink(struct proto *p) { @@ -54,7 +70,7 @@ proto_relink(struct proto *p) default: l = &inactive_proto_list; } - add_tail(l, &p->n); + proto_enqueue(l, p); } void * @@ -146,7 +162,7 @@ protos_commit(struct config *c) q = p->init(x); q->proto_state = PS_DOWN; q->core_state = FS_HUNGRY; - add_tail(&initial_proto_list, &q->n); + proto_enqueue(&initial_proto_list, q); } debug("\n"); } @@ -224,7 +240,8 @@ protos_dump_all(void) WALK_LIST(p, proto_list) { - debug(" protocol %s: state %s/%s\n", p->name, p_states[p->proto_state], c_states[p->core_state]); + debug(" protocol %s (pri=%d): state %s/%s\n", p->name, p->proto->priority, + p_states[p->proto_state], c_states[p->core_state]); if (p->disabled) debug("\tDISABLED\n"); else if (p->proto->dump) -- cgit v1.2.3