summaryrefslogtreecommitdiffstats
path: root/sbin/i386/cxconfig/cxconfig.c
diff options
context:
space:
mode:
Diffstat (limited to 'sbin/i386/cxconfig/cxconfig.c')
-rw-r--r--sbin/i386/cxconfig/cxconfig.c770
1 files changed, 0 insertions, 770 deletions
diff --git a/sbin/i386/cxconfig/cxconfig.c b/sbin/i386/cxconfig/cxconfig.c
deleted file mode 100644
index 1a5ca48..0000000
--- a/sbin/i386/cxconfig/cxconfig.c
+++ /dev/null
@@ -1,770 +0,0 @@
-/*
- * Cronyx-Sigma adapter configuration utility for Unix.
- *
- * Copyright (C) 1994 Cronyx Ltd.
- * Author: Serge Vakulenko, <vak@zebub.msk.su>
- *
- * This software is distributed with NO WARRANTIES, not even the implied
- * warranties for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
- *
- * Authors grant any other persons or organisations permission to use
- * or modify this software as long as this message is kept with the software,
- * all derivative works or modified versions.
- *
- * Version 1.9, Wed Oct 4 18:58:15 MSK 1995
- *
- * Usage:
- * cxconfig [-a]
- * -- print status of all channels
- * cxconfig [-a] <channel>
- * -- print status of the channel
- * cxconfig <channel> <option>...
- * -- set channel options
- */
-
-#ifndef lint
-static const char rcsid[] =
- "$FreeBSD$";
-#endif /* not lint */
-
-#include <sys/types.h>
-#include <sys/ioctl.h>
-#include <sys/socket.h>
-#include <net/if.h>
-#include <machine/cronyx.h>
-
-#include <err.h>
-#include <fcntl.h>
-#include <stdio.h>
-#include <stdlib.h>
-#include <string.h>
-#include <unistd.h>
-
-#define NBRD 3
-#define CXDEV "/dev/cronyx"
-#define atoi(a) strtol((a), (char**)0, 0)
-
-cx_options_t o;
-cx_stat_t st;
-int aflag;
-int sflag;
-
-static char *
-symbol(unsigned char sym)
-{
- static char buf[40];
-
- if (sym < ' ')
- sprintf (buf, "^%c", sym+0100);
- else if (sym == '\\')
- strcat (buf, "\\\\");
- else if (sym < 127)
- sprintf (buf, "%c", sym);
- else
- sprintf (buf, "\\%03o", sym);
- return (buf);
-}
-
-static unsigned char
-atosym(char *s)
-{
- if (*s == '^')
- return (*++s & 037);
- if (*s == '\\')
- return (strtol (++s, 0, 8));
- return (*s);
-}
-
-static void
-usage(void)
-{
- fprintf (stderr,
- "Cronyx-Sigma Adapter Configuration Utility, Version 1.0\n");
- fprintf (stderr, "Copyright (C) 1994 Cronyx Ltd.\n");
- fprintf (stderr, "usage: cxconfig [-a] [<channel> [<option>...]]\n");
- exit (1);
-}
-
-static const char *
-chantype(int type)
-{
- switch (type) {
- default:
- case T_NONE: return ("none");
- case T_ASYNC: return ("RS-232");
- case T_UNIV_RS232: return ("RS-232");
- case T_UNIV_RS449: return ("RS-232/RS-449");
- case T_UNIV_V35: return ("RS-232/V.35");
- case T_SYNC_RS232: return ("RS-232");
- case T_SYNC_V35: return ("V.35");
- case T_SYNC_RS449: return ("RS-449");
- }
-}
-
-static const char *
-chanmode(int mode)
-{
- switch (mode) {
- case M_ASYNC: return ("Async");
- case M_HDLC: return ("HDLC");
- case M_BISYNC: return ("Bisync");
- case M_X21: return ("X.21");
- default: return ("???");
- }
-}
-
-static void
-getchan(int channel)
-{
- int s = open (CXDEV, 0);
- if (s < 0)
- err (1, "%s", CXDEV);
- o.board = channel/NCHAN;
- o.channel = channel%NCHAN;
- if (ioctl (s, CXIOCGETMODE, (caddr_t)&o) < 0)
- err (1, "CXIOCGETMODE");
- close (s);
- if (o.type == T_NONE)
- errx (1, "cx%d: channel %d not configured", o.board,
- o.channel);
-}
-
-static int
-printstats(int channel, int hflag)
-{
- int s, res;
-
- s = open (CXDEV, 0);
- if (s < 0)
- err (1, "%s", CXDEV);
- st.board = channel/NCHAN;
- st.channel = channel%NCHAN;
- res = ioctl (s, CXIOCGETSTAT, (caddr_t)&st);
- close (s);
- if (res < 0)
- return (-1);
-
- if (hflag)
- printf ("Chan Rintr Tintr Mintr Ibytes Ipkts Ierrs Obytes Opkts Oerrs\n");
- printf ("cx%-2d %7ld %7ld %7ld %8ld %7ld %7ld %8ld %7ld %7ld\n",
- channel, st.rintr, st.tintr, st.mintr, st.ibytes, st.ipkts,
- st.ierrs, st.obytes, st.opkts, st.oerrs);
- return (0);
-}
-
-static void
-printallstats(void)
-{
- int b, c;
-
- printf ("Chan Rintr Tintr Mintr Ibytes Ipkts Ierrs Obytes Opkts Oerrs\n");
- for (b=0; b<NBRD; ++b)
- for (c=0; c<NCHAN; ++c)
- printstats (b*NCHAN + c, 0);
-}
-
-static void
-setchan(int channel)
-{
- int s = open (CXDEV, 0);
- if (s < 0)
- err (1, "%s", CXDEV);
- o.board = channel/NCHAN;
- o.channel = channel%NCHAN;
- if (ioctl (s, CXIOCSETMODE, (caddr_t)&o) < 0)
- err (1, "CXIOCSETMODE");
- close (s);
-}
-
-static void
-printopt(void)
-{
- /* Common channel options */
- /* channel option register 4 */
- printf ("\t");
- printf ("fifo=%d ", o.opt.cor4.thr); /* FIFO threshold */
- printf ("%cctsdown ", o.opt.cor4.cts_zd ? '+' : '-'); /* detect 1 to 0 transition on the CTS */
- printf ("%ccddown ", o.opt.cor4.cd_zd ? '+' : '-'); /* detect 1 to 0 transition on the CD */
- printf ("%cdsrdown ", o.opt.cor4.dsr_zd ? '+' : '-'); /* detect 1 to 0 transition on the DSR */
- printf ("\n");
-
- /* channel option register 5 */
- printf ("\t");
- printf ("rfifo=%d ", o.opt.cor5.rx_thr); /* receive flow control FIFO threshold */
- printf ("%cctsup ", o.opt.cor5.cts_od ? '+' : '-'); /* detect 0 to 1 transition on the CTS */
- printf ("%ccdup ", o.opt.cor5.cd_od ? '+' : '-'); /* detect 0 to 1 transition on the CD */
- printf ("%cdsrup ", o.opt.cor5.dsr_od ? '+' : '-'); /* detect 0 to 1 transition on the DSR */
- printf ("\n");
-
- /* receive clock option register */
- printf ("\t");
- printf ("%s ", o.opt.rcor.encod == ENCOD_NRZ ? "nrz" : /* signal encoding */
- o.opt.rcor.encod == ENCOD_NRZI ? "nrzi" :
- o.opt.rcor.encod == ENCOD_MANCHESTER ? "manchester" : "???");
- printf ("%cdpll ", o.opt.rcor.dpll ? '+' : '-'); /* DPLL enable */
-
- /* transmit clock option register */
- printf ("%clloop ", o.opt.tcor.llm ? '+' : '-'); /* local loopback mode */
- printf ("%cextclock ", o.opt.tcor.ext1x ? '+' : '-'); /* external 1x clock mode */
- printf ("\n");
-
- switch (o.mode) {
- case M_ASYNC: /* async mode options */
- /* channel option register 1 */
- printf ("\t");
- printf ("cs%d ", o.aopt.cor1.charlen+1); /* character length, 5..8 */
- printf ("par%s ", o.aopt.cor1.parity ? "odd" : "even"); /* parity */
- printf ("%cignpar ", o.aopt.cor1.ignpar ? '+' : '-'); /* ignore parity */
- if (o.aopt.cor1.parmode != PARM_NORMAL) /* parity mode */
- printf ("%s ", o.aopt.cor1.parmode == PARM_NOPAR ? "nopar" :
- o.aopt.cor1.parmode == PARM_FORCE ? "forcepar" : "???");
- printf ("\n");
-
- /* channel option register 2 */
- printf ("\t");
- printf ("%cdsr ", o.aopt.cor2.dsrae ? '+' : '-'); /* DSR automatic enable */
- printf ("%ccts ", o.aopt.cor2.ctsae ? '+' : '-'); /* CTS automatic enable */
- printf ("%crts ", o.aopt.cor2.rtsao ? '+' : '-'); /* RTS automatic output enable */
- printf ("%crloop ", o.aopt.cor2.rlm ? '+' : '-'); /* remote loopback mode enable */
- printf ("%cetc ", o.aopt.cor2.etc ? '+' : '-'); /* embedded transmitter cmd enable */
- printf ("%cxon ", o.aopt.cor2.ixon ? '+' : '-'); /* in-band XON/XOFF enable */
- printf ("%cxany ", o.aopt.cor2.ixany ? '+' : '-'); /* XON on any character */
- printf ("\n");
-
- /* option register 3 */
- printf ("\t");
- printf ("%s ", o.aopt.cor3.stopb == STOPB_1 ? "stopb1" : /* stop bit length */
- o.aopt.cor3.stopb == STOPB_15 ? "stopb1.5" :
- o.aopt.cor3.stopb == STOPB_2 ? "stopb2" : "???");
- printf ("%csdt ", o.aopt.cor3.scde ? '+' : '-'); /* special char detection enable */
- printf ("%cflowct ", o.aopt.cor3.flowct ? '+' : '-'); /* flow control transparency mode */
- printf ("%crdt ", o.aopt.cor3.rngde ? '+' : '-'); /* range detect enable */
- printf ("%cexdt ", o.aopt.cor3.escde ? '+' : '-'); /* extended spec. char detect enable */
- printf ("\n");
-
- /* channel option register 6 */
- printf ("\t");
- printf ("%s ", o.aopt.cor6.parerr == PERR_INTR ? "parintr" : /* parity/framing error actions */
- o.aopt.cor6.parerr == PERR_NULL ? "parnull" :
- o.aopt.cor6.parerr == PERR_IGNORE ? "parign" :
- o.aopt.cor6.parerr == PERR_DISCARD ? "pardisc" :
- o.aopt.cor6.parerr == PERR_FFNULL ? "parffnull" : "???");
- printf ("%s ", o.aopt.cor6.brk == BRK_INTR ? "brkintr" : /* action on break condition */
- o.aopt.cor6.brk == BRK_NULL ? "brknull" :
- o.aopt.cor6.brk == BRK_DISCARD ? "brkdisc" : "???");
- printf ("%cinlcr ", o.aopt.cor6.inlcr ? '+' : '-'); /* translate NL to CR on input */
- printf ("%cicrnl ", o.aopt.cor6.icrnl ? '+' : '-'); /* translate CR to NL on input */
- printf ("%cigncr ", o.aopt.cor6.igncr ? '+' : '-'); /* discard CR on input */
- printf ("\n");
-
- /* channel option register 7 */
- printf ("\t");
- printf ("%cocrnl ", o.aopt.cor7.ocrnl ? '+' : '-'); /* translate CR to NL on output */
- printf ("%conlcr ", o.aopt.cor7.onlcr ? '+' : '-'); /* translate NL to CR on output */
- printf ("%cfcerr ", o.aopt.cor7.fcerr ? '+' : '-'); /* process flow ctl err chars enable */
- printf ("%clnext ", o.aopt.cor7.lnext ? '+' : '-'); /* LNext option enable */
- printf ("%cistrip ", o.aopt.cor7.istrip ? '+' : '-'); /* strip 8-bit on input */
- printf ("\n");
-
- printf ("\t");
- printf ("schr1=%s ", symbol (o.aopt.schr1)); /* special character register 1 (XON) */
- printf ("schr2=%s ", symbol (o.aopt.schr2)); /* special character register 2 (XOFF) */
- printf ("schr3=%s ", symbol (o.aopt.schr3)); /* special character register 3 */
- printf ("schr4=%s ", symbol (o.aopt.schr4)); /* special character register 4 */
- printf ("scrl=%s ", symbol (o.aopt.scrl)); /* special character range low */
- printf ("scrh=%s ", symbol (o.aopt.scrh)); /* special character range high */
- printf ("lnext=%s ", symbol (o.aopt.lnxt)); /* LNext character */
- printf ("\n");
- break;
-
- case M_HDLC: /* hdlc mode options */
- /* hdlc channel option register 1 */
- printf ("\t");
- printf ("if%d ", o.hopt.cor1.ifflags); /* number of inter-frame flags sent */
- printf ("%s ", o.hopt.cor1.admode == ADMODE_NOADDR ? "noaddr" : /* addressing mode */
- o.hopt.cor1.admode == ADMODE_4_1 ? "addr1" :
- o.hopt.cor1.admode == ADMODE_2_2 ? "addr2" : "???");
- printf ("%cclrdet ", o.hopt.cor1.clrdet ? '+' : '-'); /* clear detect for X.21 data transfer phase */
- printf ("addrlen%d ", o.hopt.cor1.aflo + 1); /* address field length option */
- printf ("\n");
-
- /* hdlc channel option register 2 */
- printf ("\t");
- printf ("%cdsr ", o.hopt.cor2.dsrae ? '+' : '-'); /* DSR automatic enable */
- printf ("%ccts ", o.hopt.cor2.ctsae ? '+' : '-'); /* CTS automatic enable */
- printf ("%crts ", o.hopt.cor2.rtsao ? '+' : '-'); /* RTS automatic output enable */
- printf ("%ccrcinv ", o.hopt.cor2.crcninv ? '-' : '+'); /* CRC invertion option */
- printf ("%cfcsapd ", o.hopt.cor2.fcsapd ? '+' : '-'); /* FCS append */
- printf ("\n");
-
- /* hdlc channel option register 3 */
- printf ("\t");
- printf ("pad%d ", o.hopt.cor3.padcnt); /* pad character count */
- printf ("idle%s ", o.hopt.cor3.idle ? "mark" : "flag"); /* idle mode */
- printf ("%cfcs ", o.hopt.cor3.nofcs ? '-' : '+'); /* FCS disable */
- printf ("fcs-%s ", o.hopt.cor3.fcspre ? "crc-16" : "v.41"); /* FCS preset */
- printf ("syn=%s ", o.hopt.cor3.syncpat ? "0xAA" : "0x00"); /* send sync pattern */
- printf ("%csyn ", o.hopt.cor3.sndpad ? '+' : '-'); /* send pad characters before flag enable */
- printf ("\n");
-
- printf ("\t");
- printf ("rfar1=0x%02x ", o.hopt.rfar1); /* receive frame address register 1 */
- printf ("rfar2=0x%02x ", o.hopt.rfar2); /* receive frame address register 2 */
- printf ("rfar3=0x%02x ", o.hopt.rfar3); /* receive frame address register 3 */
- printf ("rfar4=0x%02x ", o.hopt.rfar4); /* receive frame address register 4 */
- printf ("crc-%s ", o.hopt.cpsr ? "16" : "v.41"); /* CRC polynomial select */
- printf ("\n");
- break;
-
- case M_BISYNC: /* bisync mode options */
- /* channel option register 1 */
- printf ("\t");
- printf ("cs%d ", o.bopt.cor1.charlen+1); /* character length, 5..8 */
- printf ("par%s ", o.bopt.cor1.parity ? "odd" : "even"); /* parity */
- printf ("%cignpar ", o.bopt.cor1.ignpar ? '+' : '-'); /* ignore parity */
- if (o.bopt.cor1.parmode != PARM_NORMAL) /* parity mode */
- printf ("%s ", o.bopt.cor1.parmode == PARM_NOPAR ? "nopar" :
- o.bopt.cor1.parmode == PARM_FORCE ? "forcepar" : "???");
- printf ("\n");
-
- /* channel option register 2 */
- printf ("\t");
- printf ("syn%d ", o.bopt.cor2.syns+2); /* number of extra SYN chars before a frame */
- printf ("%ccrcinv ", o.bopt.cor2.crcninv ? '-' : '+'); /* CRC invertion option */
- printf ("%s ", o.bopt.cor2.ebcdic ? "ebcdic" : "ascii"); /* use EBCDIC as char set (instead of ASCII) */
- printf ("%cbccapd ", o.bopt.cor2.bcc ? '+' : '-'); /* BCC append enable */
- printf ("%s ", o.bopt.cor2.lrc ? "lrc" : "crc-16"); /* longitudinal redundancy check */
- printf ("\n");
-
- /* channel option register 3 */
- printf ("\t");
- printf ("pad%d ", o.bopt.cor3.padcnt); /* pad character count */
- printf ("idle%s ", o.bopt.cor3.idle ? "mark" : "syn"); /* idle mode */
- printf ("%cfcs ", o.bopt.cor3.nofcs ? '-' : '+'); /* FCS disable */
- printf ("fcs-%s ", o.bopt.cor3.fcspre ? "crc-16" : "v.41"); /* FCS preset */
- printf ("syn=%s ", o.bopt.cor3.padpat ? "0x55" : "0xAA"); /* send sync pattern */
- printf ("%csyn ", o.bopt.cor3.sndpad ? '+' : '-'); /* send pad characters before flag enable */
- printf ("\n");
-
- /* channel option register 6 */
- printf ("\t");
- printf ("specterm=%s ", symbol (o.bopt.cor6.specterm)); /* special termination character */
-
- printf ("crc-%s ", o.bopt.cpsr ? "16" : "v.41"); /* CRC polynomial select */
- printf ("\n");
- break;
-
- case M_X21: /* x.21 mode options */
- /* channel option register 1 */
- printf ("\t");
- printf ("cs%d ", o.xopt.cor1.charlen+1); /* character length, 5..8 */
- printf ("par%s ", o.xopt.cor1.parity ? "odd" : "even"); /* parity */
- printf ("%cignpar ", o.xopt.cor1.ignpar ? '+' : '-'); /* ignore parity */
- if (o.xopt.cor1.parmode != PARM_NORMAL) /* parity mode */
- printf ("%s ", o.xopt.cor1.parmode == PARM_NOPAR ? "nopar" :
- o.xopt.cor1.parmode == PARM_FORCE ? "forcepar" : "???");
- printf ("\n");
-
- /* channel option register 2 */
- printf ("\t");
- printf ("%cetc ", o.xopt.cor2.etc ? '+' : '-'); /* embedded transmitter cmd enable */
-
- /* channel option register 3 */
- printf ("%csdt ", o.xopt.cor3.scde ? '+' : '-'); /* special char detection enable */
- printf ("%cstripsyn ", o.xopt.cor3.stripsyn ? '+' : '-'); /* treat SYN chars as special condition */
- printf ("%cssdt ", o.xopt.cor3.ssde ? '+' : '-'); /* steady state detect enable */
- printf ("syn%c ", o.xopt.cor3.syn ? '1' : '2'); /* the number of SYN chars on receive */
- printf ("\n");
-
- /* channel option register 6 */
- printf ("\t");
- printf ("syn=%s ", symbol (o.xopt.cor6.synchar)); /* syn character */
-
- printf ("schr1=%s ", symbol (o.xopt.schr1)); /* special character register 1 */
- printf ("schr2=%s ", symbol (o.xopt.schr2)); /* special character register 2 */
- printf ("schr3=%s ", symbol (o.xopt.schr3)); /* special character register 3 */
- printf ("\n");
- break;
- }
-}
-
-static void
-printchan(int channel)
-{
- printf ("cx%d (%s) %s", channel, chantype (o.type), chanmode (o.mode));
- if (o.txbaud == o.rxbaud)
- printf (" %lu", o.rxbaud);
- else
- printf (" ospeed=%lu ispeed=%lu", o.txbaud, o.rxbaud);
- if ((o.channel == 0 || o.channel == 8) &&
- (o.type == T_UNIV_V35 || o.type == T_UNIV_RS449))
- printf (" port=%s", o.iftype ? (o.type == T_UNIV_V35 ?
- "v35" : "rs449") : "rs232");
- printf (o.sopt.ext ? " ext" : o.sopt.cisco ? " cisco" : " ppp");
- printf (" %ckeepalive", o.sopt.keepalive ? '+' : '-');
- printf (" %cautorts", o.sopt.norts ? '-' : '+');
- if (*o.master)
- printf (" master=%s", o.master);
- printf ("\n");
- if (aflag)
- printopt ();
-}
-
-static void
-printall(void)
-{
- struct ifconf ifc;
- struct ifreq *ifr;
- char buf[BUFSIZ], *cp;
- int s, c;
-
- s = socket (AF_INET, SOCK_DGRAM, 0);
- if (s < 0)
- err (1, "socket");
- ifc.ifc_len = sizeof (buf);
- ifc.ifc_buf = buf;
- if (ioctl (s, SIOCGIFCONF, (caddr_t)&ifc) < 0)
- err (1, "SIOCGIFCONF");
- close (s);
- s = open (CXDEV, 0);
- if (s < 0)
- err (1, "%s", CXDEV);
-
- ifr = ifc.ifc_req;
-#define max(a,b) ((a)>(b) ? (a) : (b))
-#define size(p) max((p).sa_len, sizeof(p))
- for (cp=buf; cp<buf+ifc.ifc_len; cp+=sizeof(ifr->ifr_name)+size(ifr->ifr_addr)) {
- ifr = (struct ifreq*) cp;
- if (ifr->ifr_addr.sa_family != AF_LINK)
- continue;
- if (strncmp (ifr->ifr_name, "cx", 2) != 0)
- continue;
- c = atoi (ifr->ifr_name + 2);
- o.board = c/NCHAN;
- o.channel = c%NCHAN;
- if (ioctl (s, CXIOCGETMODE, (caddr_t)&o) < 0)
- err (1, "CXIOCGETMODE");
- printchan (c);
- }
- close (s);
-}
-
-static void
-set_interface_type(char *type)
-{
- if (o.channel != 0 && o.channel != 8) {
- printf ("interface option is applicable only for channels 0 and 8\n");
- exit (1);
- }
- if (o.type != T_UNIV_V35 && o.type != T_UNIV_RS449) {
- printf ("interface option is applicable only for universal channels\n");
- exit (1);
- }
- if (! strcasecmp (type, "port=rs232"))
- o.iftype = 0;
- else
- o.iftype = 1;
-}
-
-static void
-set_master(char *ifname)
-{
- if (o.type == T_ASYNC) {
- printf ("master option is not applicable for async channels\n");
- exit (1);
- }
- strcpy (o.master, ifname);
-}
-
-static void
-set_async_opt(char *opt)
-{
- /* channel option register 1 */
- if (! strncasecmp (opt, "cs", 2)) o.aopt.cor1.charlen = atoi (opt + 2) - 1;
- else if (! strcasecmp (opt, "parodd")) o.aopt.cor1.parity = 1;
- else if (! strcasecmp (opt, "pareven")) o.aopt.cor1.parity = 0;
- else if (! strcasecmp (opt, "-ignpar")) o.aopt.cor1.ignpar = 0;
- else if (! strcasecmp (opt, "+ignpar")) o.aopt.cor1.ignpar = 1;
- else if (! strcasecmp (opt, "nopar")) o.aopt.cor1.parmode = PARM_NOPAR;
- else if (! strcasecmp (opt, "forcepar")) o.aopt.cor1.parmode = PARM_FORCE;
-
- /* channel option register 2 */
- else if (! strcasecmp (opt, "-dsr")) o.aopt.cor2.dsrae = 0;
- else if (! strcasecmp (opt, "+dsr")) o.aopt.cor2.dsrae = 1;
- else if (! strcasecmp (opt, "-cts")) o.aopt.cor2.ctsae = 0;
- else if (! strcasecmp (opt, "+cts")) o.aopt.cor2.ctsae = 1;
- else if (! strcasecmp (opt, "-rts")) o.aopt.cor2.rtsao = 0;
- else if (! strcasecmp (opt, "+rts")) o.aopt.cor2.rtsao = 1;
- else if (! strcasecmp (opt, "-rloop")) o.aopt.cor2.rlm = 0;
- else if (! strcasecmp (opt, "+rloop")) o.aopt.cor2.rlm = 1;
- else if (! strcasecmp (opt, "-etc")) o.aopt.cor2.etc = 0;
- else if (! strcasecmp (opt, "+etc")) o.aopt.cor2.etc = 1;
- else if (! strcasecmp (opt, "-ixon")) o.aopt.cor2.ixon = 0;
- else if (! strcasecmp (opt, "+ixon")) o.aopt.cor2.ixon = 1;
- else if (! strcasecmp (opt, "-ixany")) o.aopt.cor2.ixany = 0;
- else if (! strcasecmp (opt, "+ixany")) o.aopt.cor2.ixany = 1;
-
- /* option register 3 */
- else if (! strcasecmp (opt, "stopb1")) o.aopt.cor3.stopb = STOPB_1;
- else if (! strcasecmp (opt, "stopb1.5")) o.aopt.cor3.stopb = STOPB_15;
- else if (! strcasecmp (opt, "stopb2")) o.aopt.cor3.stopb = STOPB_2;
- else if (! strcasecmp (opt, "-sdt")) o.aopt.cor3.scde = 0;
- else if (! strcasecmp (opt, "+sdt")) o.aopt.cor3.scde = 1;
- else if (! strcasecmp (opt, "-flowct")) o.aopt.cor3.flowct = 0;
- else if (! strcasecmp (opt, "+flowct")) o.aopt.cor3.flowct = 1;
- else if (! strcasecmp (opt, "-rdt")) o.aopt.cor3.rngde = 0;
- else if (! strcasecmp (opt, "+rdt")) o.aopt.cor3.rngde = 1;
- else if (! strcasecmp (opt, "-exdt")) o.aopt.cor3.escde = 0;
- else if (! strcasecmp (opt, "+exdt")) o.aopt.cor3.escde = 1;
-
- /* channel option register 6 */
- else if (! strcasecmp (opt, "parintr")) o.aopt.cor6.parerr = PERR_INTR;
- else if (! strcasecmp (opt, "parnull")) o.aopt.cor6.parerr = PERR_NULL;
- else if (! strcasecmp (opt, "parign")) o.aopt.cor6.parerr = PERR_IGNORE;
- else if (! strcasecmp (opt, "pardisc")) o.aopt.cor6.parerr = PERR_DISCARD;
- else if (! strcasecmp (opt, "parffnull")) o.aopt.cor6.parerr = PERR_FFNULL;
- else if (! strcasecmp (opt, "brkintr")) o.aopt.cor6.brk = BRK_INTR;
- else if (! strcasecmp (opt, "brknull")) o.aopt.cor6.brk = BRK_NULL;
- else if (! strcasecmp (opt, "brkdisc")) o.aopt.cor6.brk = BRK_DISCARD;
- else if (! strcasecmp (opt, "-inlcr")) o.aopt.cor6.inlcr = 0;
- else if (! strcasecmp (opt, "+inlcr")) o.aopt.cor6.inlcr = 1;
- else if (! strcasecmp (opt, "-icrnl")) o.aopt.cor6.icrnl = 0;
- else if (! strcasecmp (opt, "+icrnl")) o.aopt.cor6.icrnl = 1;
- else if (! strcasecmp (opt, "-igncr")) o.aopt.cor6.igncr = 0;
- else if (! strcasecmp (opt, "+igncr")) o.aopt.cor6.igncr = 1;
-
- /* channel option register 7 */
- else if (! strcasecmp (opt, "-ocrnl")) o.aopt.cor7.ocrnl = 0;
- else if (! strcasecmp (opt, "+ocrnl")) o.aopt.cor7.ocrnl = 1;
- else if (! strcasecmp (opt, "-onlcr")) o.aopt.cor7.onlcr = 0;
- else if (! strcasecmp (opt, "+onlcr")) o.aopt.cor7.onlcr = 1;
- else if (! strcasecmp (opt, "-fcerr")) o.aopt.cor7.fcerr = 0;
- else if (! strcasecmp (opt, "+fcerr")) o.aopt.cor7.fcerr = 1;
- else if (! strcasecmp (opt, "-lnext")) o.aopt.cor7.lnext = 0;
- else if (! strcasecmp (opt, "+lnext")) o.aopt.cor7.lnext = 1;
- else if (! strcasecmp (opt, "-istrip")) o.aopt.cor7.istrip = 0;
- else if (! strcasecmp (opt, "+istrip")) o.aopt.cor7.istrip = 1;
-
- else if (! strncasecmp (opt, "schr1=", 6)) o.aopt.schr1 = atosym (opt+6);
- else if (! strncasecmp (opt, "schr2=", 6)) o.aopt.schr2 = atosym (opt+6);
- else if (! strncasecmp (opt, "schr3=", 6)) o.aopt.schr3 = atosym (opt+6);
- else if (! strncasecmp (opt, "schr4=", 6)) o.aopt.schr4 = atosym (opt+6);
- else if (! strncasecmp (opt, "scrl=", 5)) o.aopt.scrl = atosym (opt+5);
- else if (! strncasecmp (opt, "scrh=", 5)) o.aopt.scrh = atosym (opt+5);
- else if (! strncasecmp (opt, "lnext=", 6)) o.aopt.lnxt = atosym (opt+6);
- else
- usage ();
-}
-
-static void
-set_hdlc_opt(char *opt)
-{
- /* hdlc channel option register 1 */
- if (! strncasecmp (opt, "if", 2)) o.hopt.cor1.ifflags = atoi (opt + 2);
- else if (! strcasecmp (opt, "noaddr")) o.hopt.cor1.admode = ADMODE_NOADDR;
- else if (! strcasecmp (opt, "addr1")) o.hopt.cor1.admode = ADMODE_4_1;
- else if (! strcasecmp (opt, "addr2")) o.hopt.cor1.admode = ADMODE_2_2;
- else if (! strcasecmp (opt, "-clrdet")) o.hopt.cor1.clrdet = 0;
- else if (! strcasecmp (opt, "+clrdet")) o.hopt.cor1.clrdet = 1;
- else if (! strcasecmp (opt, "addrlen1")) o.hopt.cor1.aflo = 0;
- else if (! strcasecmp (opt, "addrlen2")) o.hopt.cor1.aflo = 1;
-
- /* hdlc channel option register 2 */
- else if (! strcasecmp (opt, "-dsr")) o.hopt.cor2.dsrae = 0;
- else if (! strcasecmp (opt, "+dsr")) o.hopt.cor2.dsrae = 1;
- else if (! strcasecmp (opt, "-cts")) o.hopt.cor2.ctsae = 0;
- else if (! strcasecmp (opt, "+cts")) o.hopt.cor2.ctsae = 1;
- else if (! strcasecmp (opt, "-rts")) o.hopt.cor2.rtsao = 0;
- else if (! strcasecmp (opt, "+rts")) o.hopt.cor2.rtsao = 1;
- else if (! strcasecmp (opt, "-fcsapd")) o.hopt.cor2.fcsapd = 0;
- else if (! strcasecmp (opt, "+fcsapd")) o.hopt.cor2.fcsapd = 1;
- else if (! strcasecmp (opt, "-crcinv")) o.hopt.cor2.crcninv = 1;
- else if (! strcasecmp (opt, "+crcinv")) o.hopt.cor2.crcninv = 0;
-
- /* hdlc channel option register 3 */
- else if (! strncasecmp (opt, "pad", 3)) o.hopt.cor3.padcnt = atoi (opt + 3);
- else if (! strcasecmp (opt, "idlemark")) o.hopt.cor3.idle = 1;
- else if (! strcasecmp (opt, "idleflag")) o.hopt.cor3.idle = 0;
- else if (! strcasecmp (opt, "-fcs")) o.hopt.cor3.nofcs = 1;
- else if (! strcasecmp (opt, "+fcs")) o.hopt.cor3.nofcs = 0;
- else if (! strcasecmp (opt, "fcs-crc-16")) o.hopt.cor3.fcspre = 1;
- else if (! strcasecmp (opt, "fcs-v.41")) o.hopt.cor3.fcspre = 0;
- else if (! strcasecmp (opt, "syn=0xaa")) o.hopt.cor3.syncpat = 1;
- else if (! strcasecmp (opt, "syn=0x00")) o.hopt.cor3.syncpat = 0;
- else if (! strcasecmp (opt, "-syn")) o.hopt.cor3.sndpad = 0;
- else if (! strcasecmp (opt, "+syn")) o.hopt.cor3.sndpad = 1;
-
- else if (! strncasecmp (opt, "rfar1=", 6)) o.hopt.rfar1 = atoi (opt + 6);
- else if (! strncasecmp (opt, "rfar2=", 6)) o.hopt.rfar2 = atoi (opt + 6);
- else if (! strncasecmp (opt, "rfar3=", 6)) o.hopt.rfar3 = atoi (opt + 6);
- else if (! strncasecmp (opt, "rfar4=", 6)) o.hopt.rfar4 = atoi (opt + 6);
- else if (! strcasecmp (opt, "crc-16")) o.hopt.cpsr = 1;
- else if (! strcasecmp (opt, "crc-v.41")) o.hopt.cpsr = 0;
- else usage ();
-}
-
-static void
-set_bisync_opt(char *opt __unused)
-{
- usage ();
-}
-
-static void
-set_x21_opt(char *opt __unused)
-{
- usage ();
-}
-
-int
-main(int argc, char **argv)
-{
- int channel;
-
- for (--argc, ++argv; argc>0 && **argv=='-'; --argc, ++argv)
- if (! strcasecmp (*argv, "-a"))
- ++aflag;
- else if (! strcasecmp (*argv, "-s"))
- ++sflag;
- else
- usage ();
-
- if (argc <= 0) {
- if (sflag)
- printallstats ();
- else
- printall ();
- return (0);
- }
-
- if (argv[0][0]=='c' && argv[0][1]=='x')
- *argv += 2;
- if (**argv<'0' || **argv>'9')
- usage ();
- channel = atoi (*argv);
- --argc, ++argv;
-
- if (sflag) {
- if (printstats (channel, 1) < 0)
- printf ("channel cx%d not available\n", channel);
- return (0);
- }
-
- getchan (channel);
-
- if (argc <= 0) {
- printchan (channel);
- return (0);
- }
-
- for (; argc>0; --argc, ++argv)
- if (**argv == '(')
- continue;
- else if (! strncasecmp (*argv, "ispeed=", 7))
- o.rxbaud = atoi (*argv+7);
- else if (! strncasecmp (*argv, "ospeed=", 7))
- o.txbaud = atoi (*argv+7);
- else if (! strcasecmp (*argv, "async"))
- o.mode = M_ASYNC;
- else if (! strcasecmp (*argv, "hdlc"))
- o.mode = M_HDLC;
- else if (! strcasecmp (*argv, "bisync") ||
- ! strcasecmp (*argv, "bsc"))
- o.mode = M_BISYNC;
- else if (! strcasecmp (*argv, "x.21") ||
- ! strcasecmp (*argv, "x21"))
- o.mode = M_X21;
- else if (**argv>='0' && **argv<='9')
- o.txbaud = o.rxbaud = atoi (*argv);
- else if (! strcasecmp (*argv, "cisco")) {
- o.sopt.cisco = 1;
- o.sopt.ext = 0;
- } else if (! strcasecmp (*argv, "ppp")) {
- o.sopt.cisco = 0;
- o.sopt.ext = 0;
- } else if (! strcasecmp (*argv, "ext"))
- o.sopt.ext = 1;
- else if (! strcasecmp (*argv, "+keepalive"))
- o.sopt.keepalive = 1;
- else if (! strcasecmp (*argv, "-keepalive"))
- o.sopt.keepalive = 0;
- else if (! strcasecmp (*argv, "+autorts"))
- o.sopt.norts = 0;
- else if (! strcasecmp (*argv, "-autorts"))
- o.sopt.norts = 1;
- else if (! strcasecmp (*argv, "port=rs232") ||
- ! strcasecmp (*argv, "port=rs449") ||
- ! strcasecmp (*argv, "port=v35"))
- set_interface_type (*argv);
- else if (! strncasecmp (*argv, "master=",7))
- set_master (*argv+7);
-
- /*
- * Common channel options
- */
- /* channel option register 4 */
- else if (! strcasecmp (*argv, "-ctsdown"))
- o.opt.cor4.cts_zd = 0;
- else if (! strcasecmp (*argv, "+ctsdown"))
- o.opt.cor4.cts_zd = 1;
- else if (! strcasecmp (*argv, "-cddown"))
- o.opt.cor4.cd_zd = 0;
- else if (! strcasecmp (*argv, "+cddown"))
- o.opt.cor4.cd_zd = 1;
- else if (! strcasecmp (*argv, "-dsrdown"))
- o.opt.cor4.dsr_zd = 0;
- else if (! strcasecmp (*argv, "+dsrdown"))
- o.opt.cor4.dsr_zd = 1;
- else if (! strncasecmp (*argv, "fifo=", 5))
- o.opt.cor4.thr = atoi (*argv + 5);
-
- /* channel option register 5 */
- else if (! strcasecmp (*argv, "-ctsup"))
- o.opt.cor5.cts_od = 0;
- else if (! strcasecmp (*argv, "+ctsup"))
- o.opt.cor5.cts_od = 1;
- else if (! strcasecmp (*argv, "-cdup"))
- o.opt.cor5.cd_od = 0;
- else if (! strcasecmp (*argv, "+cdup"))
- o.opt.cor5.cd_od = 1;
- else if (! strcasecmp (*argv, "-dsrup"))
- o.opt.cor5.dsr_od = 0;
- else if (! strcasecmp (*argv, "+dsrup"))
- o.opt.cor5.dsr_od = 1;
- else if (! strncasecmp (*argv, "rfifo=", 6))
- o.opt.cor5.rx_thr = atoi (*argv + 6);
-
- /* receive clock option register */
- else if (! strcasecmp (*argv, "nrz"))
- o.opt.rcor.encod = ENCOD_NRZ;
- else if (! strcasecmp (*argv, "nrzi"))
- o.opt.rcor.encod = ENCOD_NRZI;
- else if (! strcasecmp (*argv, "manchester"))
- o.opt.rcor.encod = ENCOD_MANCHESTER;
- else if (! strcasecmp (*argv, "-dpll"))
- o.opt.rcor.dpll = 0;
- else if (! strcasecmp (*argv, "+dpll"))
- o.opt.rcor.dpll = 1;
-
- /* transmit clock option register */
- else if (! strcasecmp (*argv, "-lloop"))
- o.opt.tcor.llm = 0;
- else if (! strcasecmp (*argv, "+lloop"))
- o.opt.tcor.llm = 1;
- else if (! strcasecmp (*argv, "-extclock"))
- o.opt.tcor.ext1x = 0;
- else if (! strcasecmp (*argv, "+extclock"))
- o.opt.tcor.ext1x = 1;
-
- /*
- * Mode dependent channel options
- */
- else switch (o.mode) {
- case M_ASYNC: set_async_opt (*argv); break;
- case M_HDLC: set_hdlc_opt (*argv); break;
- case M_BISYNC: set_bisync_opt (*argv); break;
- case M_X21: set_x21_opt (*argv); break;
- }
-
- setchan (channel);
- return (0);
-}
OpenPOWER on IntegriCloud