summaryrefslogtreecommitdiff
path: root/sys/arch/hp300/dev/scsivar.h
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/hp300/dev/scsivar.h')
-rw-r--r--sys/arch/hp300/dev/scsivar.h66
1 files changed, 46 insertions, 20 deletions
diff --git a/sys/arch/hp300/dev/scsivar.h b/sys/arch/hp300/dev/scsivar.h
index a9226295744..ecc618d4de3 100644
--- a/sys/arch/hp300/dev/scsivar.h
+++ b/sys/arch/hp300/dev/scsivar.h
@@ -1,7 +1,8 @@
-/* $OpenBSD: scsivar.h,v 1.3 1997/01/12 15:13:02 downsj Exp $ */
-/* $NetBSD: scsivar.h,v 1.5 1995/12/02 18:22:14 thorpej Exp $ */
+/* $OpenBSD: scsivar.h,v 1.4 1997/02/03 04:47:45 downsj Exp $ */
+/* $NetBSD: scsivar.h,v 1.6 1997/01/30 09:08:56 thorpej Exp $ */
/*
+ * Copyright (c) 1997 Jason R. Thorpe. All rights reserved.
* Copyright (c) 1990, 1993
* The Regents of the University of California. All rights reserved.
*
@@ -39,23 +40,48 @@
* @(#)scsivar.h 8.1 (Berkeley) 6/10/93
*/
-struct scsi_softc {
- struct hp_ctlr *sc_hc;
- struct devqueue sc_dq;
- struct devqueue sc_sq;
- u_char sc_flags;
- u_char sc_sync;
- u_char sc_scsi_addr;
- u_char sc_scsiid; /* XXX unencoded copy of sc_scsi_addr */
- u_char sc_stat[2];
- u_char sc_msg[7];
+#include <sys/queue.h>
+
+/*
+ * A SCSI job queue entry. Target drivers each have of of these,
+ * used to queue requests with the initiator.
+ */
+struct scsiqueue {
+ TAILQ_ENTRY(scsiqueue) sq_list; /* entry on queue */
+ void *sq_softc; /* target's softc */
+ int sq_target; /* target on bus */
+ int sq_lun; /* lun on target */
+
+ /*
+ * Callbacks used to start and stop the target driver.
+ */
+ void (*sq_start) __P((void *));
+ void (*sq_go) __P((void *));
+ void (*sq_intr) __P((void *, int));
};
-/* sc_flags */
-#define SCSI_IO 0x80 /* DMA I/O in progress */
-#define SCSI_DMA32 0x40 /* 32-bit DMA should be used */
-#define SCSI_HAVEDMA 0x04 /* controller has DMA channel */
-#ifdef DEBUG
-#define SCSI_PAD 0x02 /* 'padded' transfer in progress */
-#endif
-#define SCSI_ALIVE 0x01 /* controller initialized */
+struct scsi_inquiry;
+struct scsi_fmt_cdb;
+
+struct oscsi_attach_args {
+ int osa_target; /* target */
+ int osa_lun; /* logical unit */
+ /* inquiry data */
+ struct scsi_inquiry *osa_inqbuf;
+};
+
+int scsi_probe_device __P((int, int, int, struct scsi_inquiry *, int));
+int scsi_print __P((void *, const char *));
+
+void scsireset __P((int));
+int scsireq __P((struct device *, struct scsiqueue *));
+void scsifree __P((struct device *, struct scsiqueue *));
+int scsigo __P((int, int, int, struct buf *, struct scsi_fmt_cdb *, int));
+int scsi_request_sense __P((int, int, int, u_char *, u_int));
+int scsiustart __P((int));
+int scsi_tt_write __P((int, int, int, u_char *, u_int, daddr_t, int));
+int scsi_tt_oddio __P((int, int, int, u_char *, u_int, int, int));
+int scsi_immed_command __P((int, int, int, struct scsi_fmt_cdb *,
+ u_char *, u_int, int));
+void scsi_str __P((char *, char *, size_t));
+int scsi_test_unit_rdy __P((int, int, int));