xref: /original-bsd/sys/hp/dev/hilioctl.h (revision 3588a932)
1 /*
2  * Copyright (c) 1988 University of Utah.
3  * Copyright (c) 1990 The Regents of the University of California.
4  * All rights reserved.
5  *
6  * This code is derived from software contributed to Berkeley by
7  * the Systems Programming Group of the University of Utah Computer
8  * Science Department.
9  *
10  * %sccs.include.redist.c%
11  *
12  * from: Utah $Hdr: hilioctl.h 1.1 90/07/09$
13  *
14  *	@(#)hilioctl.h	7.2 (Berkeley) 11/04/90
15  */
16 
17 struct _hilbell {
18 	u_char	duration;
19 	u_char	frequency;
20 };
21 
22 struct _hilbuf16 {
23 	u_char	string[16];
24 };
25 
26 struct _hilbuf11 {
27 	u_char	string[11];
28 };
29 
30 struct _hilbuf5 {
31   	u_char  string[5];
32 };
33 
34 struct _hilbuf4 {
35   	u_char  string[4];
36 };
37 
38 struct _hilbuf2 {
39 	u_char	string[2];
40 };
41 
42 struct hilqinfo {
43 	int	qid;
44 	char	*addr;
45 };
46 
47 /*
48  * HPUX ioctls (here for the benefit of the HIL driver).
49  * Named as they are under HPUX.
50  * The first set are loop device ioctls.
51  * The second set are ioctls for the 8042.
52  * Note that some are not defined as in HPUX
53  * due to the difference in the definitions of IOC_VOID.
54  */
55 #define _IOHpux(x,y)	(IOC_IN|((x)<<8)|y)	/* IOC_IN is IOC_VOID */
56 
57 #define HILID	_IOR('h',0x03, struct _hilbuf11) /* Identify & describe */
58 #define HILSC	_IOR('h',0x33, struct _hilbuf16) /* Security code */
59 #define HILRN	_IOR('h',0x30, struct _hilbuf16) /* Report name */
60 #define HILRS	_IOR('h',0x31, struct _hilbuf16) /* Report status */
61 #define HILED	_IOR('h',0x32, struct _hilbuf16) /* Extended describe*/
62 #define HILDKR  _IOHpux('h',0x3D)		/* Disable autorepeat */
63 #define HILER1  _IOHpux('h',0x3E)		/* Autorepeat 1/30 */
64 #define HILER2  _IOHpux('h',0x3F)		/* Autorepeat 1/60 */
65 #define HILP1	_IOHpux('h',0x40)		/* Prompt 1 */
66 #define HILP2	_IOHpux('h',0x41)		/* Prompt 2 */
67 #define HILP3	_IOHpux('h',0x42)		/* Prompt 3 */
68 #define HILP4	_IOHpux('h',0x43)		/* Prompt 4 */
69 #define HILP5	_IOHpux('h',0x44)		/* Prompt 5 */
70 #define HILP6	_IOHpux('h',0x45)		/* Prompt 6 */
71 #define HILP7	_IOHpux('h',0x46)		/* Prompt 7 */
72 #define HILP	_IOHpux('h',0x47)		/* Prompt */
73 #define HILA1	_IOHpux('h',0x48)		/* Acknowledge 1 */
74 #define HILA2	_IOHpux('h',0x49)		/* Acknowledge 2 */
75 #define HILA3	_IOHpux('h',0x4A)		/* Acknowledge 3 */
76 #define HILA4	_IOHpux('h',0x4B)		/* Acknowledge 4 */
77 #define HILA5	_IOHpux('h',0x4C)		/* Acknowledge 5 */
78 #define HILA6	_IOHpux('h',0x4D)		/* Acknowledge 6 */
79 #define HILA7	_IOHpux('h',0x4E)		/* Acknowledge 7 */
80 #define HILA	_IOHpux('h',0x4F)		/* Acknowledge */
81 
82 #define EFTSRD  _IOW('H',0xa0,char)		/* Set the repeat delay. */
83 #define EFTSRR  _IOW('H',0xa2,char)		/* Set the repeat rate. */
84 #define EFTSRPG _IOW('H',0xa6,char)		/* Set RPG interrupt rate. */
85 #define EFTSBP  _IOW('H',0xc4,struct _hilbuf4)	/* Send data to the beeper. */
86 #define EFTRLC  _IOR('H',0x12,char)		/* Read the language code. */
87 #define EFTRCC  _IOR('H',0x11,char)		/* Read configuration code. */
88 #define EFTRRT  _IOR('H',0x31,struct _hilbuf5)	/* Read the real time. */
89 #define EFTRT   _IOR('H',0xf4,struct _hilbuf4)	/* Read the timers for the
90 	                                              four voices. */
91 #define EFTSBI  _IOW('H',0xa3,struct _hilbuf2)	/* Set the bell information. */
92 
93 /*
94  * BSD ioctls.
95  * Mostly the same as the HPUX versions except for shared-queue ioctls.
96  */
97 #define HILIOCID	_IOR('h',0x03, struct _hilbuf11)
98 #define HILIOCSC	_IOR('h',0x33, struct _hilbuf16)
99 #define HILIOCRN	_IOR('h',0x30, struct _hilbuf16)
100 #define HILIOCRS	_IOR('h',0x31, struct _hilbuf16)
101 #define HILIOCED	_IOR('h',0x32, struct _hilbuf16)
102 #define HILIOCAROFF	_IO('h',0x3D)
103 #define HILIOCAR1	_IO('h',0x3E)
104 #define HILIOCAR2	_IO('h',0x3F)
105 #define HILIOCSBP	_IOW('H',0xc4,struct _hilbuf4)
106 #define HILIOCRRT	_IOR('H',0x31,struct _hilbuf5)
107 #define HILIOCRT	_IOR('H',0xf4,struct _hilbuf4)
108 #define HILIOCBEEP	_IOW('H',0xA3,struct _hilbell)
109 #	define	BELLDUR		80	/* tone duration in msec (10 - 2560) */
110 #	define	BELLFREQ	8	/* tone frequency (0 - 63) */
111 
112 #define HILIOCALLOCQ	_IOWR('H',0x72, struct hilqinfo)	/* allocate queue */
113 #define HILIOCFREEQ	_IOW('H',0x73, struct hilqinfo)	/* deallocate queue */
114 #define HILIOCMAPQ	_IOW('H',0x74, int)	/* map device to queue */
115 #define HILIOCUNMAPQ	_IOW('H',0x75, int)	/* unmap device from dev */
116 #define HILIOCTEST      _IOW('H',0x76, int)	/* Toggle debugging mode */
117 #define HILIOCHPUX	_IO('H',0x77)		/* use HPUX (read) semantics */
118 #define HILIOCRESET	_IO('H',0x78)		/* Reset the HIL loop. */
119 
120 /*
121  * HIL input queue.
122  * This is the circular queue (allocated by HILIOCALLOC) shared by kernel
123  * and user.  It consists of a sixteen byte header followed by space for
124  * 255 input data packets (a total of 4096 bytes).  The kernel adds packets
125  * at tail.  The user is expected to remove packets from head.  This is the
126  * only field in the header that the user should modify.
127  */
128 typedef struct hil_packet {
129 	u_char	size;		/* total packet size */
130 	u_char	dev;		/* loop device packet was generated by */
131 	long	tstamp;		/* time stamp */
132 	u_char	data[10];	/* device data */
133 } hil_packet;
134 
135 typedef struct hil_eventqueue {
136 	int	size;
137 	int	head;
138 	int	tail;
139 	int	pad;
140 } hil_eventqueue;
141 
142 typedef union hilqueue {
143 	char	hqu_size[0x1000];
144 	struct	q_data {
145 		hil_eventqueue	h_eventqueue;
146 		hil_packet	h_event[1];
147 	} q_data;
148 #define hil_evqueue	q_data.h_eventqueue
149 #define hil_event	q_data.h_event
150 } HILQ;
151 
152 #define HEVQSIZE	\
153 	((sizeof(HILQ) - sizeof(struct q_data)) / sizeof(hil_packet) + 1)
154