summaryrefslogtreecommitdiffstats
path: root/sys-utils/lp.h
blob: 7fa83dde289477f13b77bd35190b3a5a5a63c7c5 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
/* Line printer stuff mostly follows the original Centronics printers. See
   IEEE Std.1284-1994 Standard Signaling Method for a Bi-directional Parallel
   Peripheral Interface for Personal Computers for 5 modes of data transfer. */

/* Parallel port registers: data (0x3bc, 0x378, 0x278), status=data+1, control=data+2 */

/* Parallel port status register (read only):
bit 7: NBSY	(1: ready, 0: busy or error or off-line)
bit 6: NACK	(if NBSY=1, then 1; if NBSY=0 then 1: sending data, 0: ready with data)
bit 5:  PAP	(1: out-of-paper)
bit 4: OFON	(1: on-line)
bit 3: NFEH	(1: OK, 0: printer error)
bits 2-0: 07

On out-of-paper: PAP=1, OFON=0, NFEH=1.

"When reading the busy status, read twice in a row and use the value
obtained from the second read. This improves the reliability on some
parallel ports when the busy line may not be connected and is floating."
"On some Okidata printers when the busy signal switches from high to low,
the printer sends a 50 ns glitch on the paper out signal line. Before
declaring a paper out condition, check the status again."
(The Undocumented PC, F. van Gilluwe, p. 711)
*/

/* Parallel port control register (read/write):
bit 4:  IRQ	(1: we want an interrupt when NACK goes from 1 to 0)
bit 3:  DSL	(1: activate printer)
bit 2: NINI	(0: initialise printer)
bit 1:  ALF	(1: printer performs automatic linefeed after each line)
bit 0:  STR	(0->1: generate a Strobe pulse: transport data to printer)
*/

/* Parallel port timing:
   1. wait for NBSY=1
   2. outb(data byte, data port)
   3. wait for at least 0.5us
   4. read control port, OR with STR=0x1, output to control port - purpose:
      generate strobe pulse; this will make the busy line go high
   5. wait for at least 0.5us
   6. read control port, AND with !STR, output to control port
   7. wait for at least 0.5us
   8. in a loop: read status register until NACK bit is 0 or NBSY=1
      (the printer will keep NACK=0 for at least 0.5us, then NACK=NBSY=1).
*/


/* lp ioctls */
#define LPCHAR   0x0601  /* specify the number of times we ask for the status
			    (waiting for ready) before giving up with a timeout
			    The duration may mainly depend on the timing of an inb. */
#define LPTIME   0x0602  /* time to sleep after each timeout (in units of 0.01 sec) */
#define LPABORT  0x0604  /* call with TRUE arg to abort on error,
			    FALSE to retry.  Default is retry.  */
#define LPSETIRQ 0x0605  /* call with new IRQ number,
			    or 0 for polling (no IRQ) */
#define LPGETIRQ 0x0606  /* get the current IRQ number */
#define LPWAIT   0x0608  /* #of loops to wait before taking strobe high */
#define LPCAREFUL   0x0609  /* call with TRUE arg to require out-of-paper, off-
			    line, and error indicators good on all writes,
			    FALSE to ignore them.  Default is ignore. */
#define LPABORTOPEN 0x060a  /* call with TRUE arg to abort open() on error,
			    FALSE to ignore error.  Default is ignore.  */
#define LPGETSTATUS 0x060b  /* return LP_S(minor) */
#define LPRESET     0x060c  /* reset printer */
#define LPGETFLAGS  0x060e  /* get status flags */

#define LPSTRICT    0x060f  /* enable/disable strict compliance (2.0.36) */
                            /* Strict: wait until !READY before taking strobe low;
			       this may be bad for the Epson Stylus 800.
			       Not strict: wait a constant time as given by LPWAIT */
#define LPTRUSTIRQ  0x060f  /* set/unset the LP_TRUST_IRQ flag (2.1.131) */

/* 
 * bit defines for 8255 status port
 * base + 1
 * accessed with LP_S(minor), which gets the byte...
 */
#define LP_PBUSY	0x80  /* inverted input, active high */
#define LP_PACK		0x40  /* unchanged input, active low */
#define LP_POUTPA	0x20  /* unchanged input, active high */
#define LP_PSELECD	0x10  /* unchanged input, active high */
#define LP_PERRORP	0x08  /* unchanged input, active low */