summaryrefslogtreecommitdiff
path: root/sys/dev/ata/atascsi.c
diff options
context:
space:
mode:
authorDavid Gwynne <dlg@cvs.openbsd.org>2007-02-19 12:04:02 +0000
committerDavid Gwynne <dlg@cvs.openbsd.org>2007-02-19 12:04:02 +0000
commitd8c36eb7b3ac43753d22eb50fb34cc00b7aeb14a (patch)
tree3d4f575470ae494f6d264fa15d0bc3d0cfc9c59c /sys/dev/ata/atascsi.c
parent37ebaf159aba995950aaa1567e12448c3fbf63b8 (diff)
code to set up a global pool for allocating ata_xfers out of, and for
accessing that pool.
Diffstat (limited to 'sys/dev/ata/atascsi.c')
-rw-r--r--sys/dev/ata/atascsi.c54
1 files changed, 51 insertions, 3 deletions
diff --git a/sys/dev/ata/atascsi.c b/sys/dev/ata/atascsi.c
index 11d3fad099a..69aaad24b3e 100644
--- a/sys/dev/ata/atascsi.c
+++ b/sys/dev/ata/atascsi.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: atascsi.c,v 1.5 2007/02/19 11:57:45 dlg Exp $ */
+/* $OpenBSD: atascsi.c,v 1.6 2007/02/19 12:04:01 dlg Exp $ */
/*
* Copyright (c) 2007 David Gwynne <dlg@openbsd.org>
@@ -23,6 +23,7 @@
#include <sys/malloc.h>
#include <sys/device.h>
#include <sys/proc.h>
+#include <sys/pool.h>
#include <sys/queue.h>
#include <scsi/scsi_all.h>
@@ -43,8 +44,6 @@ struct atascsi {
struct scsibus_softc *as_scsibus;
};
-int atascsi_probe(struct atascsi *, int);
-
int atascsi_cmd(struct scsi_xfer *);
/* template */
@@ -60,6 +59,8 @@ struct scsi_device atascsi_device = {
NULL, NULL, NULL, NULL
};
+int atascsi_probe(struct atascsi *, int);
+
int atascsi_disk_cmd(struct scsi_xfer *);
int atascsi_disk_inq(struct scsi_xfer *);
int atascsi_disk_capacity(struct scsi_xfer *);
@@ -70,6 +71,16 @@ int atascsi_atapi_cmd(struct scsi_xfer *);
int atascsi_stuffup(struct scsi_xfer *);
+
+int ata_running = 0;
+struct pool ata_xfer_pool;
+
+void ata_init(void);
+void ata_destroy(void);
+
+struct ata_xfer *ata_get_xfer(int);
+void ata_put_xfer(struct ata_xfer *);
+
struct atascsi *
atascsi_attach(struct device *self, struct atascsi_attach_args *aaa)
{
@@ -249,3 +260,40 @@ atascsi_stuffup(struct scsi_xfer *xs)
splx(s);
return (COMPLETE);
}
+
+void
+ata_init(void)
+{
+ if (ata_running++)
+ return;
+
+ pool_init(&ata_xfer_pool, sizeof(struct ata_xfer), 0, 0, 0, "xapl",
+ NULL);
+}
+
+void
+ata_destroy(void)
+{
+ if (--ata_running)
+ return;
+
+ pool_destroy(&ata_xfer_pool);
+}
+
+struct ata_xfer *
+ata_get_xfer(int nosleep)
+{
+ struct ata_xfer *xa;
+
+ xa = pool_get(&ata_xfer_pool, nosleep ? PR_NOWAIT : PR_WAITOK);
+
+ return (xa);
+}
+
+void
+ata_put_xfer(struct ata_xfer *xa)
+{
+ pool_put(&ata_xfer_pool, xa);
+}
+
+