ssvar.h revision 1.1 1 1.1 mycroft /* $NetBSD: ssvar.h,v 1.1 1996/02/18 20:32:50 mycroft Exp $ */
2 1.1 mycroft
3 1.1 mycroft /*
4 1.1 mycroft * Copyright (c) 1995 Kenneth Stailey. All rights reserved.
5 1.1 mycroft * modified for configurable scanner support by Joachim Koenig
6 1.1 mycroft *
7 1.1 mycroft * Redistribution and use in source and binary forms, with or without
8 1.1 mycroft * modification, are permitted provided that the following conditions
9 1.1 mycroft * are met:
10 1.1 mycroft * 1. Redistributions of source code must retain the above copyright
11 1.1 mycroft * notice, this list of conditions and the following disclaimer.
12 1.1 mycroft * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 mycroft * notice, this list of conditions and the following disclaimer in the
14 1.1 mycroft * documentation and/or other materials provided with the distribution.
15 1.1 mycroft * 3. All advertising materials mentioning features or use of this software
16 1.1 mycroft * must display the following acknowledgement:
17 1.1 mycroft * This product includes software developed by Kenneth Stailey.
18 1.1 mycroft * 4. The name of the author may not be used to endorse or promote products
19 1.1 mycroft * derived from this software without specific prior written permission.
20 1.1 mycroft *
21 1.1 mycroft * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
22 1.1 mycroft * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
23 1.1 mycroft * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
24 1.1 mycroft * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
25 1.1 mycroft * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
26 1.1 mycroft * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27 1.1 mycroft * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28 1.1 mycroft * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29 1.1 mycroft * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
30 1.1 mycroft * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31 1.1 mycroft */
32 1.1 mycroft
33 1.1 mycroft /*
34 1.1 mycroft * SCSI scanner interface description
35 1.1 mycroft */
36 1.1 mycroft
37 1.1 mycroft /*
38 1.1 mycroft * Special handlers for impractically different scanner types.
39 1.1 mycroft * Register NULL for a function if you want to try the real SCSI code
40 1.1 mycroft * (with quirks table)
41 1.1 mycroft */
42 1.1 mycroft struct ss_special {
43 1.1 mycroft int (*set_params)();
44 1.1 mycroft int (*trigger_scanner)();
45 1.1 mycroft int (*get_params)();
46 1.1 mycroft void (*minphys)(); /* some scanners only send line-multiples */
47 1.1 mycroft int (*read)();
48 1.1 mycroft int (*rewind_scanner)();
49 1.1 mycroft int (*load_adf)();
50 1.1 mycroft int (*unload_adf)();
51 1.1 mycroft };
52 1.1 mycroft
53 1.1 mycroft /*
54 1.1 mycroft * ss_softc has to be declared here, because the device dependant
55 1.1 mycroft * modules include it
56 1.1 mycroft */
57 1.1 mycroft struct ss_softc {
58 1.1 mycroft struct device sc_dev;
59 1.1 mycroft
60 1.1 mycroft int flags;
61 1.1 mycroft #define SSF_TRIGGERED 0x01 /* read operation has been primed */
62 1.1 mycroft #define SSF_LOADED 0x02 /* parameters loaded */
63 1.1 mycroft struct scsi_link *sc_link; /* contains our targ, lun, etc. */
64 1.1 mycroft struct scan_io sio;
65 1.1 mycroft struct buf buf_queue; /* the queue of pending IO operations */
66 1.1 mycroft u_int quirks; /* scanner is only mildly twisted */
67 1.1 mycroft #define SS_Q_GET_BUFFER_SIZE 0x0001 /* poll for available data in ssread() */
68 1.1 mycroft /* truncate to byte boundry is assumed by default unless one of these is set */
69 1.1 mycroft #define SS_Q_PAD_TO_BYTE 0x0002 /* pad monochrome data to byte boundary */
70 1.1 mycroft #define SS_Q_PAD_TO_WORD 0x0004 /* pad monochrome data to word boundary */
71 1.1 mycroft #define SS_Q_THRESHOLD_FOLLOWS_BRIGHTNESS 0x0008
72 1.1 mycroft struct ss_special *special; /* special handlers for spec. devices */
73 1.1 mycroft };
74 1.1 mycroft
75 1.1 mycroft /*
76 1.1 mycroft * define the special attach routines if configured
77 1.1 mycroft */
78 1.1 mycroft void mustek_attach __P((struct ss_softc *, struct scsibus_attach_args *));
79 1.1 mycroft void scanjet_attach __P((struct ss_softc *, struct scsibus_attach_args *));
80