/* * Copyright 2003 Digi International (www.digi.com) * Scott H Kilau <Scott_Kilau at digi dot com> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2, or (at your option) * any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY, EXPRESS OR IMPLIED; without even the * implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR * PURPOSE. See the GNU General Public License for more details. */ #ifndef __DIGI_H #define __DIGI_H #ifndef TIOCM_LE #define TIOCM_LE 0x01 /* line enable */ #define TIOCM_DTR 0x02 /* data terminal ready */ #define TIOCM_RTS 0x04 /* request to send */ #define TIOCM_ST 0x08 /* secondary transmit */ #define TIOCM_SR 0x10 /* secondary receive */ #define TIOCM_CTS 0x20 /* clear to send */ #define TIOCM_CAR 0x40 /* carrier detect */ #define TIOCM_RNG 0x80 /* ring indicator */ #define TIOCM_DSR 0x100 /* data set ready */ #define TIOCM_RI TIOCM_RNG /* ring (alternate) */ #define TIOCM_CD TIOCM_CAR /* carrier detect (alt) */ #endif #if !defined(TIOCMSET) #define TIOCMSET (('d' << 8) | 252) /* set modem ctrl state */ #define TIOCMGET (('d' << 8) | 253) /* set modem ctrl state */ #endif #if !defined(TIOCMBIC) #define TIOCMBIC (('d' << 8) | 254) /* set modem ctrl state */ #define TIOCMBIS (('d' << 8) | 255) /* set modem ctrl state */ #endif #define DIGI_GETA (('e' << 8) | 94) /* Read params */ #define DIGI_SETA (('e' << 8) | 95) /* Set params */ #define DIGI_SETAW (('e' << 8) | 96) /* Drain & set params */ #define DIGI_SETAF (('e' << 8) | 97) /* Drain, flush & set params */ #define DIGI_GET_NI_INFO (('d' << 8) | 250) /* Non-intelligent state info */ #define DIGI_LOOPBACK (('d' << 8) | 252) /* * Enable/disable UART * internal loopback */ #define DIGI_FAST 0x0002 /* Fast baud rates */ #define RTSPACE 0x0004 /* RTS input flow control */ #define CTSPACE 0x0008 /* CTS output flow control */ #define DIGI_COOK 0x0080 /* Cooked processing done in FEP */ #define DIGI_FORCEDCD 0x0100 /* Force carrier */ #define DIGI_ALTPIN 0x0200 /* Alternate RJ-45 pin config */ #define DIGI_PRINTER 0x0800 /* Hold port open for flow cntrl*/ #define DIGI_DTR_TOGGLE 0x2000 /* Support DTR Toggle */ #define DIGI_RTS_TOGGLE 0x8000 /* Support RTS Toggle */ #define DIGI_PLEN 28 /* String length */ #define DIGI_TSIZ 10 /* Terminal string len */ /* * Structure used with ioctl commands for DIGI parameters. */ struct digi_t { unsigned short digi_flags; /* Flags (see above) */ unsigned short digi_maxcps; /* Max printer CPS */ unsigned short digi_maxchar; /* Max chars in print queue */ unsigned short digi_bufsize; /* Buffer size */ unsigned char digi_onlen; /* Length of ON string */ unsigned char digi_offlen; /* Length of OFF string */ char digi_onstr[DIGI_PLEN]; /* Printer on string */ char digi_offstr[DIGI_PLEN]; /* Printer off string */ char digi_term[DIGI_TSIZ]; /* terminal string */ }; /* Structure to get driver status information */ struct digi_dinfo { unsigned int dinfo_nboards; /* # boards configured */ char dinfo_reserved[12]; /* for future expansion */ char dinfo_version[16]; /* driver version */ }; #define DIGI_GETDD (('d' << 8) | 248) /* get driver info */ /* * Structure used with ioctl commands for per-board information * * physsize and memsize differ when board has "windowed" memory */ struct digi_info { unsigned int info_bdnum; /* Board number (0 based) */ unsigned int info_ioport; /* io port address */ unsigned int info_physaddr; /* memory address */ unsigned int info_physsize; /* Size of host mem window */ unsigned int info_memsize; /* Amount of dual-port mem */ /* on board */ unsigned short info_bdtype; /* Board type */ unsigned short info_nports; /* number of ports */ char info_bdstate; /* board state */ char info_reserved[7]; /* for future expansion */ }; #define DIGI_GETBD (('d' << 8) | 249) /* get board info */ struct digi_getbuffer /* Struct for holding buffer use counts */ { unsigned long tx_in; unsigned long tx_out; unsigned long rxbuf; unsigned long txbuf; unsigned long txdone; }; struct digi_getcounter { unsigned long norun; /* number of UART overrun errors */ unsigned long noflow; /* number of buffer overflow errors */ unsigned long nframe; /* number of framing errors */ unsigned long nparity; /* number of parity errors */ unsigned long nbreak; /* number of breaks received */ unsigned long rbytes; /* number of received bytes */ unsigned long tbytes; /* number of bytes transmitted fully */ }; /* Board State Definitions */ #define BD_RUNNING 0x0 #define BD_NOFEP 0x5 #define DIGI_SETCUSTOMBAUD _IOW('e', 106, int) /* Set integer baud rate */ #define DIGI_GETCUSTOMBAUD _IOR('e', 107, int) /* Get integer baud rate */ #define DIGI_REALPORT_GETBUFFERS (('e' << 8) | 108) #define DIGI_REALPORT_SENDIMMEDIATE (('e' << 8) | 109) #define DIGI_REALPORT_GETCOUNTERS (('e' << 8) | 110) #define DIGI_REALPORT_GETEVENTS (('e' << 8) | 111) #define EV_OPU 0x0001 /* !<Output paused by client */ #define EV_OPS 0x0002 /* !<Output paused by regular sw flowctrl */ #define EV_IPU 0x0010 /* !<Input paused unconditionally by user */ #define EV_IPS 0x0020 /* !<Input paused by high/low water marks */ #define EV_TXB 0x0040 /* !<Transmit break pending */ /* * This structure holds data needed for the intelligent <--> nonintelligent * DPA translation */ struct ni_info { int board; int channel; int dtr; int rts; int cts; int dsr; int ri; int dcd; int curtx; int currx; unsigned short iflag; unsigned short oflag; unsigned short cflag; unsigned short lflag; unsigned int mstat; unsigned char hflow; unsigned char xmit_stopped; unsigned char recv_stopped; unsigned int baud; }; #define T_CLASSIC 0002 #define T_PCIBUS 0400 #define T_NEO_EXPRESS 0001 #define T_NEO 0000 #define TTY_FLIPBUF_SIZE 512 #endif /* DIGI_H */Overall Contributors
Person | Tokens | Prop | Commits | CommitProp |
Lidza Louina | 388 | 69.78% | 1 | 10.00% |
Giedrius Statkevičius | 100 | 17.99% | 3 | 30.00% |
Walt Feasel | 45 | 8.09% | 2 | 20.00% |
Rehas Sachdeva | 16 | 2.88% | 1 | 10.00% |
SeungHun Lee | 4 | 0.72% | 1 | 10.00% |
DaeSeok Youn | 2 | 0.36% | 1 | 10.00% |
Fernando Apesteguia | 1 | 0.18% | 1 | 10.00% |
Total | 556 | 100.00% | 10 | 100.00% |