summaryrefslogtreecommitdiff
path: root/sys/scsi
diff options
context:
space:
mode:
authorkstailey <kstailey@cvs.openbsd.org>1997-04-05 22:59:14 +0000
committerkstailey <kstailey@cvs.openbsd.org>1997-04-05 22:59:14 +0000
commitb021ab4f592f4da5aacc5d0d685ec3270a0ad0c5 (patch)
treedd18f12a1f953586833f5f5e1be64e8f37a18390 /sys/scsi
parent61ba8f206c1755c8754277e40ac95c89a2dbbbb8 (diff)
fix NULL ptr deref in ss_set_window()
Diffstat (limited to 'sys/scsi')
-rw-r--r--sys/scsi/ss.c42
1 files changed, 41 insertions, 1 deletions
diff --git a/sys/scsi/ss.c b/sys/scsi/ss.c
index 554f4b6ff88..9fcf60980c1 100644
--- a/sys/scsi/ss.c
+++ b/sys/scsi/ss.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ss.c,v 1.30 1997/03/13 12:22:37 kstailey Exp $ */
+/* $OpenBSD: ss.c,v 1.31 1997/04/05 22:59:13 kstailey Exp $ */
/* $NetBSD: ss.c,v 1.10 1996/05/05 19:52:55 christos Exp $ */
/*
@@ -111,6 +111,8 @@ struct ss_quirk_inquiry_pattern {
struct quirkdata quirkdata;
};
+struct quirkdata ss_gen_quirks;
+
void ssstrategy __P((struct buf *));
void ssstart __P((void *));
void ssminphys __P((struct buf *));
@@ -349,6 +351,11 @@ ss_identify_scanner(ss, inqbuf)
printf("\n%s: %s\n", ss->sc_dev.dv_xname, ss->quirkdata->name);
} else {
printf("\n%s: generic scanner\n", ss->sc_dev.dv_xname);
+ bzero(&ss_gen_quirks, sizeof(ss_gen_quirks));
+#if 0
+ ss_gen_quirks.name = "generic";
+#endif
+ ss->quirkdata = &ss_gen_quirks;
ss->sio.scan_scanner_type = GENERIC_SCSI2;
}
}
@@ -954,3 +961,36 @@ get_buffer_status(ss, bp)
}
bp->b_bcount = MIN(_3btol(buf_sz_retn.tgt_send_buf_len), bp->b_bcount);
}
+
+#ifdef NOTYET
+int
+umax_compute_sizes(ss)
+ struct ss_softc *ss;
+{
+ ss->sio.scan_lines = ;
+ ss->sio.scan_window_size = ;
+}
+
+int
+calc_umax_row_len(dpi, ww)
+ int dpi;
+ int ww;
+{
+ int st[301];
+ int i;
+ int rowB = 0;
+
+ for (i = 1; i <= 300; i++)
+ st[i] = 1;
+
+ for (i = 1; i <= 300 - dpi; i++)
+ st[i * 300 / (300 - dpi)] = 0;
+
+ for (i = 1; i <= (ww % 1200) / 4; i++) {
+ if (st[i])
+ rowB++;
+ }
+
+ return ((ww / 1200) * dpi + rowB);
+}
+#endif