summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/kern/kern_bufq.c52
-rw-r--r--sys/sys/buf.h4
2 files changed, 26 insertions, 30 deletions
diff --git a/sys/kern/kern_bufq.c b/sys/kern/kern_bufq.c
index 1e6530a6ac0..b02ff2c951b 100644
--- a/sys/kern/kern_bufq.c
+++ b/sys/kern/kern_bufq.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: kern_bufq.c,v 1.17 2010/09/01 19:30:59 kettenis Exp $ */
+/* $OpenBSD: kern_bufq.c,v 1.18 2010/09/02 07:05:39 matthew Exp $ */
/*
* Copyright (c) 2010 Thordur I. Bjornsson <thib@openbsd.org>
*
@@ -47,15 +47,6 @@ struct buf *bufq_disksort_dequeue(void *);
void bufq_disksort_requeue(void *, struct buf *);
int bufq_disksort_peek(void *);
-struct bufq_impl bufq_impl_disksort = {
- bufq_disksort_create,
- bufq_disksort_destroy,
- bufq_disksort_queue,
- bufq_disksort_dequeue,
- bufq_disksort_requeue,
- bufq_disksort_peek
-};
-
void *bufq_fifo_create(void);
void bufq_fifo_destroy(void *);
void bufq_fifo_queue(void *, struct buf *);
@@ -63,18 +54,23 @@ struct buf *bufq_fifo_dequeue(void *);
void bufq_fifo_requeue(void *, struct buf *);
int bufq_fifo_peek(void *);
-struct bufq_impl bufq_impl_fifo = {
- bufq_fifo_create,
- bufq_fifo_destroy,
- bufq_fifo_queue,
- bufq_fifo_dequeue,
- bufq_fifo_requeue,
- bufq_fifo_peek
-};
-
-struct bufq_impl *bufq_impls[BUFQ_HOWMANY] = {
- &bufq_impl_disksort,
- &bufq_impl_fifo
+const struct bufq_impl bufq_impls[BUFQ_HOWMANY] = {
+ {
+ bufq_disksort_create,
+ bufq_disksort_destroy,
+ bufq_disksort_queue,
+ bufq_disksort_dequeue,
+ bufq_disksort_requeue,
+ bufq_disksort_peek
+ },
+ {
+ bufq_fifo_create,
+ bufq_fifo_destroy,
+ bufq_fifo_queue,
+ bufq_fifo_dequeue,
+ bufq_fifo_requeue,
+ bufq_fifo_peek
+ }
};
int
@@ -85,7 +81,7 @@ bufq_init(struct bufq *bq, int type)
mtx_init(&bq->bufq_mtx, IPL_BIO);
bq->bufq_type = type;
- bq->bufq_impl = bufq_impls[type];
+ bq->bufq_impl = &bufq_impls[type];
bq->bufq_data = bq->bufq_impl->impl_create();
if (bq->bufq_data == NULL) {
/*
@@ -120,7 +116,7 @@ bufq_switch(struct bufq *bq, int type)
if (ret)
return (0);
- data = bufq_impls[type]->impl_create();
+ data = bufq_impls[type].impl_create();
if (data == NULL)
return (ENOMEM);
@@ -129,19 +125,19 @@ bufq_switch(struct bufq *bq, int type)
odata = bq->bufq_data;
otype = bq->bufq_type;
- while ((bp = bufq_impls[otype]->impl_dequeue(odata)) != NULL)
- bufq_impls[type]->impl_queue(data, bp);
+ while ((bp = bufq_impls[otype].impl_dequeue(odata)) != NULL)
+ bufq_impls[type].impl_queue(data, bp);
bq->bufq_data = data;
bq->bufq_type = type;
- bq->bufq_impl = bufq_impls[type];
+ bq->bufq_impl = &bufq_impls[type];
} else {
otype = type;
odata = data;
}
mtx_leave(&bq->bufq_mtx);
- bufq_impls[otype]->impl_destroy(odata);
+ bufq_impls[otype].impl_destroy(odata);
return (0);
}
diff --git a/sys/sys/buf.h b/sys/sys/buf.h
index 7ff8938bb9b..83daac3d772 100644
--- a/sys/sys/buf.h
+++ b/sys/sys/buf.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: buf.h,v 1.71 2010/09/01 01:38:12 dlg Exp $ */
+/* $OpenBSD: buf.h,v 1.72 2010/09/02 07:05:39 matthew Exp $ */
/* $NetBSD: buf.h,v 1.25 1997/04/09 21:12:17 mycroft Exp $ */
/*
@@ -76,7 +76,7 @@ struct bufq {
u_int bufq_outstanding;
int bufq_stop;
int bufq_type;
- struct bufq_impl *bufq_impl;
+ const struct bufq_impl *bufq_impl;
};
int bufq_init(struct bufq *, int);