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.3 (Berkeley) 03/19/92 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 HILID 0x400c6803*/ 59 #define HILSC _IOR('h',0x33, struct _hilbuf16) /* Security code */ 60 #define HILRN _IOR('h',0x30, struct _hilbuf16) /* Report name */ 61 #define HILRS _IOR('h',0x31, struct _hilbuf16) /* Report status */ 62 #define HILED _IOR('h',0x32, struct _hilbuf16) /* Extended describe*/ 63 #define HILDKR _IOHpux('h',0x3D) /* Disable autorepeat */ 64 #define HILER1 _IOHpux('h',0x3E) /* Autorepeat 1/30 */ 65 #define HILER2 _IOHpux('h',0x3F) /* Autorepeat 1/60 */ 66 #define HILP1 _IOHpux('h',0x40) /* Prompt 1 */ 67 #define HILP2 _IOHpux('h',0x41) /* Prompt 2 */ 68 #define HILP3 _IOHpux('h',0x42) /* Prompt 3 */ 69 #define HILP4 _IOHpux('h',0x43) /* Prompt 4 */ 70 #define HILP5 _IOHpux('h',0x44) /* Prompt 5 */ 71 #define HILP6 _IOHpux('h',0x45) /* Prompt 6 */ 72 #define HILP7 _IOHpux('h',0x46) /* Prompt 7 */ 73 #define HILP _IOHpux('h',0x47) /* Prompt */ 74 #define HILA1 _IOHpux('h',0x48) /* Acknowledge 1 */ 75 #define HILA2 _IOHpux('h',0x49) /* Acknowledge 2 */ 76 #define HILA3 _IOHpux('h',0x4A) /* Acknowledge 3 */ 77 #define HILA4 _IOHpux('h',0x4B) /* Acknowledge 4 */ 78 #define HILA5 _IOHpux('h',0x4C) /* Acknowledge 5 */ 79 #define HILA6 _IOHpux('h',0x4D) /* Acknowledge 6 */ 80 #define HILA7 _IOHpux('h',0x4E) /* Acknowledge 7 */ 81 #define HILA _IOHpux('h',0x4F) /* Acknowledge */ 82 83 #define EFTSRD _IOW('H',0xa0,char) /* Set the repeat delay. */ 84 #define EFTSRR _IOW('H',0xa2,char) /* Set the repeat rate. */ 85 #define EFTSRPG _IOW('H',0xa6,char) /* Set RPG interrupt rate. */ 86 #define EFTSBP _IOW('H',0xc4,struct _hilbuf4) /* Send data to the beeper. */ 87 #define EFTRLC _IOR('H',0x12,char) /* Read the language code. */ 88 #define EFTRCC _IOR('H',0x11,char) /* Read configuration code. */ 89 #define EFTRRT _IOR('H',0x31,struct _hilbuf5)/* Read the real time. */ 90 /*#define EFTRRT 0x40064831*/ 91 #define EFTRT _IOR('H',0xf4,struct _hilbuf4) /* Read the timers for the 92 four voices. */ 93 #define EFTSBI _IOW('H',0xa3,struct _hilbuf2) /* Set the bell information. */ 94 95 /* 96 * BSD ioctls. 97 * Mostly the same as the HPUX versions except for shared-queue ioctls. 98 */ 99 #define HILIOCID _IOR('h',0x03, struct _hilbuf11) 100 #define HILIOCSC _IOR('h',0x33, struct _hilbuf16) 101 #define HILIOCRN _IOR('h',0x30, struct _hilbuf16) 102 #define HILIOCRS _IOR('h',0x31, struct _hilbuf16) 103 #define HILIOCED _IOR('h',0x32, struct _hilbuf16) 104 #define HILIOCAROFF _IO('h',0x3D) 105 #define HILIOCAR1 _IO('h',0x3E) 106 #define HILIOCAR2 _IO('h',0x3F) 107 #define HILIOCSBP _IOW('H',0xc4,struct _hilbuf4) 108 #define HILIOCRRT _IOR('H',0x31,struct _hilbuf5) 109 #define HILIOCRT _IOR('H',0xf4,struct _hilbuf4) 110 #define HILIOCBEEP _IOW('H',0xA3,struct _hilbell) 111 # define BELLDUR 80 /* tone duration in msec (10 - 2560) */ 112 # define BELLFREQ 8 /* tone frequency (0 - 63) */ 113 114 #define HILIOCALLOCQ _IOWR('H',0x72, struct hilqinfo) /* allocate queue */ 115 #define HILIOCFREEQ _IOW('H',0x73, struct hilqinfo) /* deallocate queue */ 116 #define HILIOCMAPQ _IOW('H',0x74, int) /* map device to queue */ 117 #define HILIOCUNMAPQ _IOW('H',0x75, int) /* unmap device from dev */ 118 #define HILIOCTEST _IOW('H',0x76, int) /* Toggle debugging mode */ 119 #define HILIOCHPUX _IO('H',0x77) /* use HPUX (read) semantics */ 120 #define HILIOCRESET _IO('H',0x78) /* Reset the HIL loop. */ 121 122 /* 123 * HIL input queue. 124 * This is the circular queue (allocated by HILIOCALLOC) shared by kernel 125 * and user. It consists of a sixteen byte header followed by space for 126 * 255 input data packets (a total of 4096 bytes). The kernel adds packets 127 * at tail. The user is expected to remove packets from head. This is the 128 * only field in the header that the user should modify. 129 */ 130 typedef struct hil_packet { 131 u_char size; /* total packet size */ 132 u_char dev; /* loop device packet was generated by */ 133 long tstamp; /* time stamp */ 134 u_char data[10]; /* device data */ 135 } hil_packet; 136 137 typedef struct hil_eventqueue { 138 int size; 139 int head; 140 int tail; 141 int pad; 142 } hil_eventqueue; 143 144 typedef union hilqueue { 145 char hqu_size[0x1000]; 146 struct q_data { 147 hil_eventqueue h_eventqueue; 148 hil_packet h_event[1]; 149 } q_data; 150 #define hil_evqueue q_data.h_eventqueue 151 #define hil_event q_data.h_event 152 } HILQ; 153 154 #define HEVQSIZE \ 155 ((sizeof(HILQ) - sizeof(struct q_data)) / sizeof(hil_packet) + 1) 156