summaryrefslogtreecommitdiffstats
path: root/contrib/ipfilter/ipsend/dlcommon.c
diff options
context:
space:
mode:
authorcy <cy@FreeBSD.org>2013-07-19 05:41:57 +0000
committercy <cy@FreeBSD.org>2013-07-19 05:41:57 +0000
commit672af8808c0e7c15f330b401482f9271c2eb3fa6 (patch)
tree225b5acf68c01bc6a260b386c2b2dbf4fa2839e3 /contrib/ipfilter/ipsend/dlcommon.c
parent71e82d94e82560b20789833f60056506de34de8b (diff)
downloadFreeBSD-src-672af8808c0e7c15f330b401482f9271c2eb3fa6.zip
FreeBSD-src-672af8808c0e7c15f330b401482f9271c2eb3fa6.tar.gz
As per the developers handbook (5.3.1 step 1), prepare the vendor trees for
import of new ipfilter vendor sources by flattening them. To keep the tags consistent with dist, the tags are also flattened. Approved by: glebius (Mentor)
Diffstat (limited to 'contrib/ipfilter/ipsend/dlcommon.c')
-rw-r--r--contrib/ipfilter/ipsend/dlcommon.c1381
1 files changed, 0 insertions, 1381 deletions
diff --git a/contrib/ipfilter/ipsend/dlcommon.c b/contrib/ipfilter/ipsend/dlcommon.c
deleted file mode 100644
index 8994138..0000000
--- a/contrib/ipfilter/ipsend/dlcommon.c
+++ /dev/null
@@ -1,1381 +0,0 @@
-/*
- * Common (shared) DLPI test routines.
- * Mostly pretty boring boilerplate sorta stuff.
- * These can be split into individual library routines later
- * but it's just convenient to keep them in a single file
- * while they're being developed.
- *
- * Not supported:
- * Connection Oriented stuff
- * QOS stuff
- */
-
-/*
-typedef unsigned long ulong;
-*/
-
-
-#include <sys/types.h>
-#include <sys/stream.h>
-#include <sys/stropts.h>
-#ifdef __osf__
-# include <sys/dlpihdr.h>
-#else
-# include <sys/dlpi.h>
-#endif
-#include <sys/signal.h>
-#include <stdio.h>
-#include <string.h>
-#include "dltest.h"
-
-#define CASERET(s) case s: return ("s")
-
-char *dlprim();
-char *dlstate();
-char *dlerrno();
-char *dlpromisclevel();
-char *dlservicemode();
-char *dlstyle();
-char *dlmactype();
-
-
-void
-dlinforeq(fd)
-int fd;
-{
- dl_info_req_t info_req;
- struct strbuf ctl;
- int flags;
-
- info_req.dl_primitive = DL_INFO_REQ;
-
- ctl.maxlen = 0;
- ctl.len = sizeof (info_req);
- ctl.buf = (char *) &info_req;
-
- flags = RS_HIPRI;
-
- if (putmsg(fd, &ctl, (struct strbuf*) NULL, flags) < 0)
- syserr("dlinforeq: putmsg");
-}
-
-void
-dlinfoack(fd, bufp)
-int fd;
-char *bufp;
-{
- union DL_primitives *dlp;
- struct strbuf ctl;
- int flags;
-
- ctl.maxlen = MAXDLBUF;
- ctl.len = 0;
- ctl.buf = bufp;
-
- strgetmsg(fd, &ctl, (struct strbuf*)NULL, &flags, "dlinfoack");
-
- dlp = (union DL_primitives *) ctl.buf;
-
- expecting(DL_INFO_ACK, dlp);
-
- if (ctl.len < sizeof (dl_info_ack_t))
- err("dlinfoack: response ctl.len too short: %d", ctl.len);
-
- if (flags != RS_HIPRI)
- err("dlinfoack: DL_INFO_ACK was not M_PCPROTO");
-
- if (ctl.len < sizeof (dl_info_ack_t))
- err("dlinfoack: short response ctl.len: %d", ctl.len);
-}
-
-void
-dlattachreq(fd, ppa)
-int fd;
-u_long ppa;
-{
- dl_attach_req_t attach_req;
- struct strbuf ctl;
- int flags;
-
- attach_req.dl_primitive = DL_ATTACH_REQ;
- attach_req.dl_ppa = ppa;
-
- ctl.maxlen = 0;
- ctl.len = sizeof (attach_req);
- ctl.buf = (char *) &attach_req;
-
- flags = 0;
-
- if (putmsg(fd, &ctl, (struct strbuf*) NULL, flags) < 0)
- syserr("dlattachreq: putmsg");
-}
-
-void
-dlenabmultireq(fd, addr, length)
-int fd;
-char *addr;
-int length;
-{
- long buf[MAXDLBUF];
- union DL_primitives *dlp;
- struct strbuf ctl;
- int flags;
-
- dlp = (union DL_primitives*) buf;
-
- dlp->enabmulti_req.dl_primitive = DL_ENABMULTI_REQ;
- dlp->enabmulti_req.dl_addr_length = length;
- dlp->enabmulti_req.dl_addr_offset = sizeof (dl_enabmulti_req_t);
-
- (void) memcpy((char*)OFFADDR(buf, sizeof (dl_enabmulti_req_t)), addr, length);
-
- ctl.maxlen = 0;
- ctl.len = sizeof (dl_enabmulti_req_t) + length;
- ctl.buf = (char*) buf;
-
- flags = 0;
-
- if (putmsg(fd, &ctl, (struct strbuf*) NULL, flags) < 0)
- syserr("dlenabmultireq: putmsg");
-}
-
-void
-dldisabmultireq(fd, addr, length)
-int fd;
-char *addr;
-int length;
-{
- long buf[MAXDLBUF];
- union DL_primitives *dlp;
- struct strbuf ctl;
- int flags;
-
- dlp = (union DL_primitives*) buf;
-
- dlp->disabmulti_req.dl_primitive = DL_ENABMULTI_REQ;
- dlp->disabmulti_req.dl_addr_length = length;
- dlp->disabmulti_req.dl_addr_offset = sizeof (dl_disabmulti_req_t);
-
- (void) memcpy((char*)OFFADDR(buf, sizeof (dl_disabmulti_req_t)), addr, length);
-
- ctl.maxlen = 0;
- ctl.len = sizeof (dl_disabmulti_req_t) + length;
- ctl.buf = (char*) buf;
-
- flags = 0;
-
- if (putmsg(fd, &ctl, (struct strbuf*) NULL, flags) < 0)
- syserr("dldisabmultireq: putmsg");
-}
-
-void
-dlpromisconreq(fd, level)
-int fd;
-u_long level;
-{
- dl_promiscon_req_t promiscon_req;
- struct strbuf ctl;
- int flags;
-
- promiscon_req.dl_primitive = DL_PROMISCON_REQ;
- promiscon_req.dl_level = level;
-
- ctl.maxlen = 0;
- ctl.len = sizeof (promiscon_req);
- ctl.buf = (char *) &promiscon_req;
-
- flags = 0;
-
- if (putmsg(fd, &ctl, (struct strbuf*) NULL, flags) < 0)
- syserr("dlpromiscon: putmsg");
-
-}
-
-void
-dlpromiscoff(fd, level)
-int fd;
-u_long level;
-{
- dl_promiscoff_req_t promiscoff_req;
- struct strbuf ctl;
- int flags;
-
- promiscoff_req.dl_primitive = DL_PROMISCOFF_REQ;
- promiscoff_req.dl_level = level;
-
- ctl.maxlen = 0;
- ctl.len = sizeof (promiscoff_req);
- ctl.buf = (char *) &promiscoff_req;
-
- flags = 0;
-
- if (putmsg(fd, &ctl, (struct strbuf*) NULL, flags) < 0)
- syserr("dlpromiscoff: putmsg");
-}
-
-void
-dlphysaddrreq(fd, addrtype)
-int fd;
-u_long addrtype;
-{
- dl_phys_addr_req_t phys_addr_req;
- struct strbuf ctl;
- int flags;
-
- phys_addr_req.dl_primitive = DL_PHYS_ADDR_REQ;
- phys_addr_req.dl_addr_type = addrtype;
-
- ctl.maxlen = 0;
- ctl.len = sizeof (phys_addr_req);
- ctl.buf = (char *) &phys_addr_req;
-
- flags = 0;
-
- if (putmsg(fd, &ctl, (struct strbuf*) NULL, flags) < 0)
- syserr("dlphysaddrreq: putmsg");
-}
-
-void
-dlsetphysaddrreq(fd, addr, length)
-int fd;
-char *addr;
-int length;
-{
- long buf[MAXDLBUF];
- union DL_primitives *dlp;
- struct strbuf ctl;
- int flags;
-
- dlp = (union DL_primitives*) buf;
-
- dlp->set_physaddr_req.dl_primitive = DL_ENABMULTI_REQ;
- dlp->set_physaddr_req.dl_addr_length = length;
- dlp->set_physaddr_req.dl_addr_offset = sizeof (dl_set_phys_addr_req_t);
-
- (void) memcpy((char*)OFFADDR(buf, sizeof (dl_set_phys_addr_req_t)), addr, length);
-
- ctl.maxlen = 0;
- ctl.len = sizeof (dl_set_phys_addr_req_t) + length;
- ctl.buf = (char*) buf;
-
- flags = 0;
-
- if (putmsg(fd, &ctl, (struct strbuf*) NULL, flags) < 0)
- syserr("dlsetphysaddrreq: putmsg");
-}
-
-void
-dldetachreq(fd)
-int fd;
-{
- dl_detach_req_t detach_req;
- struct strbuf ctl;
- int flags;
-
- detach_req.dl_primitive = DL_DETACH_REQ;
-
- ctl.maxlen = 0;
- ctl.len = sizeof (detach_req);
- ctl.buf = (char *) &detach_req;
-
- flags = 0;
-
- if (putmsg(fd, &ctl, (struct strbuf*) NULL, flags) < 0)
- syserr("dldetachreq: putmsg");
-}
-
-void
-dlbindreq(fd, sap, max_conind, service_mode, conn_mgmt, xidtest)
-int fd;
-u_long sap;
-u_long max_conind;
-u_long service_mode;
-u_long conn_mgmt;
-u_long xidtest;
-{
- dl_bind_req_t bind_req;
- struct strbuf ctl;
- int flags;
-
- bind_req.dl_primitive = DL_BIND_REQ;
- bind_req.dl_sap = sap;
- bind_req.dl_max_conind = max_conind;
- bind_req.dl_service_mode = service_mode;
- bind_req.dl_conn_mgmt = conn_mgmt;
- bind_req.dl_xidtest_flg = xidtest;
-
- ctl.maxlen = 0;
- ctl.len = sizeof (bind_req);
- ctl.buf = (char *) &bind_req;
-
- flags = 0;
-
- if (putmsg(fd, &ctl, (struct strbuf*) NULL, flags) < 0)
- syserr("dlbindreq: putmsg");
-}
-
-void
-dlunitdatareq(fd, addrp, addrlen, minpri, maxpri, datap, datalen)
-int fd;
-u_char *addrp;
-int addrlen;
-u_long minpri, maxpri;
-u_char *datap;
-int datalen;
-{
- long buf[MAXDLBUF];
- union DL_primitives *dlp;
- struct strbuf data, ctl;
-
- dlp = (union DL_primitives*) buf;
-
- dlp->unitdata_req.dl_primitive = DL_UNITDATA_REQ;
- dlp->unitdata_req.dl_dest_addr_length = addrlen;
- dlp->unitdata_req.dl_dest_addr_offset = sizeof (dl_unitdata_req_t);
- dlp->unitdata_req.dl_priority.dl_min = minpri;
- dlp->unitdata_req.dl_priority.dl_max = maxpri;
-
- (void) memcpy(OFFADDR(dlp, sizeof (dl_unitdata_req_t)), addrp, addrlen);
-
- ctl.maxlen = 0;
- ctl.len = sizeof (dl_unitdata_req_t) + addrlen;
- ctl.buf = (char *) buf;
-
- data.maxlen = 0;
- data.len = datalen;
- data.buf = (char *) datap;
-
- if (putmsg(fd, &ctl, &data, 0) < 0)
- syserr("dlunitdatareq: putmsg");
-}
-
-void
-dlunbindreq(fd)
-int fd;
-{
- dl_unbind_req_t unbind_req;
- struct strbuf ctl;
- int flags;
-
- unbind_req.dl_primitive = DL_UNBIND_REQ;
-
- ctl.maxlen = 0;
- ctl.len = sizeof (unbind_req);
- ctl.buf = (char *) &unbind_req;
-
- flags = 0;
-
- if (putmsg(fd, &ctl, (struct strbuf*) NULL, flags) < 0)
- syserr("dlunbindreq: putmsg");
-}
-
-void
-dlokack(fd, bufp)
-int fd;
-char *bufp;
-{
- union DL_primitives *dlp;
- struct strbuf ctl;
- int flags;
-
- ctl.maxlen = MAXDLBUF;
- ctl.len = 0;
- ctl.buf = bufp;
-
- strgetmsg(fd, &ctl, (struct strbuf*)NULL, &flags, "dlokack");
-
- dlp = (union DL_primitives *) ctl.buf;
-
- expecting(DL_OK_ACK, dlp);
-
- if (ctl.len < sizeof (dl_ok_ack_t))
- err("dlokack: response ctl.len too short: %d", ctl.len);
-
- if (flags != RS_HIPRI)
- err("dlokack: DL_OK_ACK was not M_PCPROTO");
-
- if (ctl.len < sizeof (dl_ok_ack_t))
- err("dlokack: short response ctl.len: %d", ctl.len);
-}
-
-void
-dlerrorack(fd, bufp)
-int fd;
-char *bufp;
-{
- union DL_primitives *dlp;
- struct strbuf ctl;
- int flags;
-
- ctl.maxlen = MAXDLBUF;
- ctl.len = 0;
- ctl.buf = bufp;
-
- strgetmsg(fd, &ctl, (struct strbuf*)NULL, &flags, "dlerrorack");
-
- dlp = (union DL_primitives *) ctl.buf;
-
- expecting(DL_ERROR_ACK, dlp);
-
- if (ctl.len < sizeof (dl_error_ack_t))
- err("dlerrorack: response ctl.len too short: %d", ctl.len);
-
- if (flags != RS_HIPRI)
- err("dlerrorack: DL_OK_ACK was not M_PCPROTO");
-
- if (ctl.len < sizeof (dl_error_ack_t))
- err("dlerrorack: short response ctl.len: %d", ctl.len);
-}
-
-void
-dlbindack(fd, bufp)
-int fd;
-char *bufp;
-{
- union DL_primitives *dlp;
- struct strbuf ctl;
- int flags;
-
- ctl.maxlen = MAXDLBUF;
- ctl.len = 0;
- ctl.buf = bufp;
-
- strgetmsg(fd, &ctl, (struct strbuf*)NULL, &flags, "dlbindack");
-
- dlp = (union DL_primitives *) ctl.buf;
-
- expecting(DL_BIND_ACK, dlp);
-
- if (flags != RS_HIPRI)
- err("dlbindack: DL_OK_ACK was not M_PCPROTO");
-
- if (ctl.len < sizeof (dl_bind_ack_t))
- err("dlbindack: short response ctl.len: %d", ctl.len);
-}
-
-void
-dlphysaddrack(fd, bufp)
-int fd;
-char *bufp;
-{
- union DL_primitives *dlp;
- struct strbuf ctl;
- int flags;
-
- ctl.maxlen = MAXDLBUF;
- ctl.len = 0;
- ctl.buf = bufp;
-
- strgetmsg(fd, &ctl, (struct strbuf*)NULL, &flags, "dlphysaddrack");
-
- dlp = (union DL_primitives *) ctl.buf;
-
- expecting(DL_PHYS_ADDR_ACK, dlp);
-
- if (flags != RS_HIPRI)
- err("dlbindack: DL_OK_ACK was not M_PCPROTO");
-
- if (ctl.len < sizeof (dl_phys_addr_ack_t))
- err("dlphysaddrack: short response ctl.len: %d", ctl.len);
-}
-
-void
-sigalrm()
-{
- (void) err("sigalrm: TIMEOUT");
-}
-
-strgetmsg(fd, ctlp, datap, flagsp, caller)
-int fd;
-struct strbuf *ctlp, *datap;
-int *flagsp;
-char *caller;
-{
- int rc;
- static char errmsg[80];
-
- /*
- * Start timer.
- */
- (void) signal(SIGALRM, sigalrm);
- if (alarm(MAXWAIT) < 0) {
- (void) sprintf(errmsg, "%s: alarm", caller);
- syserr(errmsg);
- }
-
- /*
- * Set flags argument and issue getmsg().
- */
- *flagsp = 0;
- if ((rc = getmsg(fd, ctlp, datap, flagsp)) < 0) {
- (void) sprintf(errmsg, "%s: getmsg", caller);
- syserr(errmsg);
- }
-
- /*
- * Stop timer.
- */
- if (alarm(0) < 0) {
- (void) sprintf(errmsg, "%s: alarm", caller);
- syserr(errmsg);
- }
-
- /*
- * Check for MOREDATA and/or MORECTL.
- */
- if ((rc & (MORECTL | MOREDATA)) == (MORECTL | MOREDATA))
- err("%s: MORECTL|MOREDATA", caller);
- if (rc & MORECTL)
- err("%s: MORECTL", caller);
- if (rc & MOREDATA)
- err("%s: MOREDATA", caller);
-
- /*
- * Check for at least sizeof (long) control data portion.
- */
- if (ctlp->len < sizeof (long))
- err("getmsg: control portion length < sizeof (long): %d", ctlp->len);
-}
-
-expecting(prim, dlp)
-int prim;
-union DL_primitives *dlp;
-{
- if (dlp->dl_primitive != (u_long)prim) {
- printdlprim(dlp);
- err("expected %s got %s", dlprim(prim),
- dlprim(dlp->dl_primitive));
- exit(1);
- }
-}
-
-/*
- * Print any DLPI msg in human readable format.
- */
-printdlprim(dlp)
-union DL_primitives *dlp;
-{
- switch (dlp->dl_primitive) {
- case DL_INFO_REQ:
- printdlinforeq(dlp);
- break;
-
- case DL_INFO_ACK:
- printdlinfoack(dlp);
- break;
-
- case DL_ATTACH_REQ:
- printdlattachreq(dlp);
- break;
-
- case DL_OK_ACK:
- printdlokack(dlp);
- break;
-
- case DL_ERROR_ACK:
- printdlerrorack(dlp);
- break;
-
- case DL_DETACH_REQ:
- printdldetachreq(dlp);
- break;
-
- case DL_BIND_REQ:
- printdlbindreq(dlp);
- break;
-
- case DL_BIND_ACK:
- printdlbindack(dlp);
- break;
-
- case DL_UNBIND_REQ:
- printdlunbindreq(dlp);
- break;
-
- case DL_SUBS_BIND_REQ:
- printdlsubsbindreq(dlp);
- break;
-
- case DL_SUBS_BIND_ACK:
- printdlsubsbindack(dlp);
- break;
-
- case DL_SUBS_UNBIND_REQ:
- printdlsubsunbindreq(dlp);
- break;
-
- case DL_ENABMULTI_REQ:
- printdlenabmultireq(dlp);
- break;
-
- case DL_DISABMULTI_REQ:
- printdldisabmultireq(dlp);
- break;
-
- case DL_PROMISCON_REQ:
- printdlpromisconreq(dlp);
- break;
-
- case DL_PROMISCOFF_REQ:
- printdlpromiscoffreq(dlp);
- break;
-
- case DL_UNITDATA_REQ:
- printdlunitdatareq(dlp);
- break;
-
- case DL_UNITDATA_IND:
- printdlunitdataind(dlp);
- break;
-
- case DL_UDERROR_IND:
- printdluderrorind(dlp);
- break;
-
- case DL_UDQOS_REQ:
- printdludqosreq(dlp);
- break;
-
- case DL_PHYS_ADDR_REQ:
- printdlphysaddrreq(dlp);
- break;
-
- case DL_PHYS_ADDR_ACK:
- printdlphysaddrack(dlp);
- break;
-
- case DL_SET_PHYS_ADDR_REQ:
- printdlsetphysaddrreq(dlp);
- break;
-
- default:
- err("printdlprim: unknown primitive type 0x%x",
- dlp->dl_primitive);
- break;
- }
-}
-
-/* ARGSUSED */
-printdlinforeq(dlp)
-union DL_primitives *dlp;
-{
- (void) printf("DL_INFO_REQ\n");
-}
-
-printdlinfoack(dlp)
-union DL_primitives *dlp;
-{
- u_char addr[MAXDLADDR];
- u_char brdcst[MAXDLADDR];
-
- addrtostring(OFFADDR(dlp, dlp->info_ack.dl_addr_offset),
- dlp->info_ack.dl_addr_length, addr);
- addrtostring(OFFADDR(dlp, dlp->info_ack.dl_brdcst_addr_offset),
- dlp->info_ack.dl_brdcst_addr_length, brdcst);
-
- (void) printf("DL_INFO_ACK: max_sdu %d min_sdu %d\n",
- dlp->info_ack.dl_max_sdu,
- dlp->info_ack.dl_min_sdu);
- (void) printf("addr_length %d mac_type %s current_state %s\n",
- dlp->info_ack.dl_addr_length,
- dlmactype(dlp->info_ack.dl_mac_type),
- dlstate(dlp->info_ack.dl_current_state));
- (void) printf("sap_length %d service_mode %s qos_length %d\n",
- dlp->info_ack.dl_sap_length,
- dlservicemode(dlp->info_ack.dl_service_mode),
- dlp->info_ack.dl_qos_length);
- (void) printf("qos_offset %d qos_range_length %d qos_range_offset %d\n",
- dlp->info_ack.dl_qos_offset,
- dlp->info_ack.dl_qos_range_length,
- dlp->info_ack.dl_qos_range_offset);
- (void) printf("provider_style %s addr_offset %d version %d\n",
- dlstyle(dlp->info_ack.dl_provider_style),
- dlp->info_ack.dl_addr_offset,
- dlp->info_ack.dl_version);
- (void) printf("brdcst_addr_length %d brdcst_addr_offset %d\n",
- dlp->info_ack.dl_brdcst_addr_length,
- dlp->info_ack.dl_brdcst_addr_offset);
- (void) printf("addr %s\n", addr);
- (void) printf("brdcst_addr %s\n", brdcst);
-}
-
-printdlattachreq(dlp)
-union DL_primitives *dlp;
-{
- (void) printf("DL_ATTACH_REQ: ppa %d\n",
- dlp->attach_req.dl_ppa);
-}
-
-printdlokack(dlp)
-union DL_primitives *dlp;
-{
- (void) printf("DL_OK_ACK: correct_primitive %s\n",
- dlprim(dlp->ok_ack.dl_correct_primitive));
-}
-
-printdlerrorack(dlp)
-union DL_primitives *dlp;
-{
- (void) printf("DL_ERROR_ACK: error_primitive %s errno %s unix_errno %d: %s\n",
- dlprim(dlp->error_ack.dl_error_primitive),
- dlerrno(dlp->error_ack.dl_errno),
- dlp->error_ack.dl_unix_errno,
- strerror(dlp->error_ack.dl_unix_errno));
-}
-
-printdlenabmultireq(dlp)
-union DL_primitives *dlp;
-{
- u_char addr[MAXDLADDR];
-
- addrtostring(OFFADDR(dlp, dlp->enabmulti_req.dl_addr_offset),
- dlp->enabmulti_req.dl_addr_length, addr);
-
- (void) printf("DL_ENABMULTI_REQ: addr_length %d addr_offset %d\n",
- dlp->enabmulti_req.dl_addr_length,
- dlp->enabmulti_req.dl_addr_offset);
- (void) printf("addr %s\n", addr);
-}
-
-printdldisabmultireq(dlp)
-union DL_primitives *dlp;
-{
- u_char addr[MAXDLADDR];
-
- addrtostring(OFFADDR(dlp, dlp->disabmulti_req.dl_addr_offset),
- dlp->disabmulti_req.dl_addr_length, addr);
-
- (void) printf("DL_DISABMULTI_REQ: addr_length %d addr_offset %d\n",
- dlp->disabmulti_req.dl_addr_length,
- dlp->disabmulti_req.dl_addr_offset);
- (void) printf("addr %s\n", addr);
-}
-
-printdlpromisconreq(dlp)
-union DL_primitives *dlp;
-{
- (void) printf("DL_PROMISCON_REQ: level %s\n",
- dlpromisclevel(dlp->promiscon_req.dl_level));
-}
-
-printdlpromiscoffreq(dlp)
-union DL_primitives *dlp;
-{
- (void) printf("DL_PROMISCOFF_REQ: level %s\n",
- dlpromisclevel(dlp->promiscoff_req.dl_level));
-}
-
-printdlphysaddrreq(dlp)
-union DL_primitives *dlp;
-{
- (void) printf("DL_PHYS_ADDR_REQ: addr_type 0x%x\n",
- dlp->physaddr_req.dl_addr_type);
-}
-
-printdlphysaddrack(dlp)
-union DL_primitives *dlp;
-{
- u_char addr[MAXDLADDR];
-
- addrtostring(OFFADDR(dlp, dlp->physaddr_ack.dl_addr_offset),
- dlp->physaddr_ack.dl_addr_length, addr);
-
- (void) printf("DL_PHYS_ADDR_ACK: addr_length %d addr_offset %d\n",
- dlp->physaddr_ack.dl_addr_length,
- dlp->physaddr_ack.dl_addr_offset);
- (void) printf("addr %s\n", addr);
-}
-
-printdlsetphysaddrreq(dlp)
-union DL_primitives *dlp;
-{
- u_char addr[MAXDLADDR];
-
- addrtostring(OFFADDR(dlp, dlp->set_physaddr_req.dl_addr_offset),
- dlp->set_physaddr_req.dl_addr_length, addr);
-
- (void) printf("DL_SET_PHYS_ADDR_REQ: addr_length %d addr_offset %d\n",
- dlp->set_physaddr_req.dl_addr_length,
- dlp->set_physaddr_req.dl_addr_offset);
- (void) printf("addr %s\n", addr);
-}
-
-/* ARGSUSED */
-printdldetachreq(dlp)
-union DL_primitives *dlp;
-{
- (void) printf("DL_DETACH_REQ\n");
-}
-
-printdlbindreq(dlp)
-union DL_primitives *dlp;
-{
- (void) printf("DL_BIND_REQ: sap %d max_conind %d\n",
- dlp->bind_req.dl_sap,
- dlp->bind_req.dl_max_conind);
- (void) printf("service_mode %s conn_mgmt %d xidtest_flg 0x%x\n",
- dlservicemode(dlp->bind_req.dl_service_mode),
- dlp->bind_req.dl_conn_mgmt,
- dlp->bind_req.dl_xidtest_flg);
-}
-
-printdlbindack(dlp)
-union DL_primitives *dlp;
-{
- u_char addr[MAXDLADDR];
-
- addrtostring(OFFADDR(dlp, dlp->bind_ack.dl_addr_offset),
- dlp->bind_ack.dl_addr_length, addr);
-
- (void) printf("DL_BIND_ACK: sap %d addr_length %d addr_offset %d\n",
- dlp->bind_ack.dl_sap,
- dlp->bind_ack.dl_addr_length,
- dlp->bind_ack.dl_addr_offset);
- (void) printf("max_conind %d xidtest_flg 0x%x\n",
- dlp->bind_ack.dl_max_conind,
- dlp->bind_ack.dl_xidtest_flg);
- (void) printf("addr %s\n", addr);
-}
-
-/* ARGSUSED */
-printdlunbindreq(dlp)
-union DL_primitives *dlp;
-{
- (void) printf("DL_UNBIND_REQ\n");
-}
-
-printdlsubsbindreq(dlp)
-union DL_primitives *dlp;
-{
- u_char sap[MAXDLADDR];
-
- addrtostring(OFFADDR(dlp, dlp->subs_bind_req.dl_subs_sap_offset),
- dlp->subs_bind_req.dl_subs_sap_length, sap);
-
- (void) printf("DL_SUBS_BIND_REQ: subs_sap_offset %d sub_sap_len %d\n",
- dlp->subs_bind_req.dl_subs_sap_offset,
- dlp->subs_bind_req.dl_subs_sap_length);
- (void) printf("sap %s\n", sap);
-}
-
-printdlsubsbindack(dlp)
-union DL_primitives *dlp;
-{
- u_char sap[MAXDLADDR];
-
- addrtostring(OFFADDR(dlp, dlp->subs_bind_ack.dl_subs_sap_offset),
- dlp->subs_bind_ack.dl_subs_sap_length, sap);
-
- (void) printf("DL_SUBS_BIND_ACK: subs_sap_offset %d sub_sap_length %d\n",
- dlp->subs_bind_ack.dl_subs_sap_offset,
- dlp->subs_bind_ack.dl_subs_sap_length);
- (void) printf("sap %s\n", sap);
-}
-
-printdlsubsunbindreq(dlp)
-union DL_primitives *dlp;
-{
- u_char sap[MAXDLADDR];
-
- addrtostring(OFFADDR(dlp, dlp->subs_unbind_req.dl_subs_sap_offset),
- dlp->subs_unbind_req.dl_subs_sap_length, sap);
-
- (void) printf("DL_SUBS_UNBIND_REQ: subs_sap_offset %d sub_sap_length %d\n",
- dlp->subs_unbind_req.dl_subs_sap_offset,
- dlp->subs_unbind_req.dl_subs_sap_length);
- (void) printf("sap %s\n", sap);
-}
-
-printdlunitdatareq(dlp)
-union DL_primitives *dlp;
-{
- u_char addr[MAXDLADDR];
-
- addrtostring(OFFADDR(dlp, dlp->unitdata_req.dl_dest_addr_offset),
- dlp->unitdata_req.dl_dest_addr_length, addr);
-
- (void) printf("DL_UNITDATA_REQ: dest_addr_length %d dest_addr_offset %d\n",
- dlp->unitdata_req.dl_dest_addr_length,
- dlp->unitdata_req.dl_dest_addr_offset);
- (void) printf("dl_priority.min %d dl_priority.max %d\n",
- dlp->unitdata_req.dl_priority.dl_min,
- dlp->unitdata_req.dl_priority.dl_max);
- (void) printf("addr %s\n", addr);
-}
-
-printdlunitdataind(dlp)
-union DL_primitives *dlp;
-{
- u_char dest[MAXDLADDR];
- u_char src[MAXDLADDR];
-
- addrtostring(OFFADDR(dlp, dlp->unitdata_ind.dl_dest_addr_offset),
- dlp->unitdata_ind.dl_dest_addr_length, dest);
- addrtostring(OFFADDR(dlp, dlp->unitdata_ind.dl_src_addr_offset),
- dlp->unitdata_ind.dl_src_addr_length, src);
-
- (void) printf("DL_UNITDATA_IND: dest_addr_length %d dest_addr_offset %d\n",
- dlp->unitdata_ind.dl_dest_addr_length,
- dlp->unitdata_ind.dl_dest_addr_offset);
- (void) printf("src_addr_length %d src_addr_offset %d\n",
- dlp->unitdata_ind.dl_src_addr_length,
- dlp->unitdata_ind.dl_src_addr_offset);
- (void) printf("group_address 0x%x\n",
- dlp->unitdata_ind.dl_group_address);
- (void) printf("dest %s\n", dest);
- (void) printf("src %s\n", src);
-}
-
-printdluderrorind(dlp)
-union DL_primitives *dlp;
-{
- u_char addr[MAXDLADDR];
-
- addrtostring(OFFADDR(dlp, dlp->uderror_ind.dl_dest_addr_offset),
- dlp->uderror_ind.dl_dest_addr_length, addr);
-
- (void) printf("DL_UDERROR_IND: dest_addr_length %d dest_addr_offset %d\n",
- dlp->uderror_ind.dl_dest_addr_length,
- dlp->uderror_ind.dl_dest_addr_offset);
- (void) printf("unix_errno %d errno %s\n",
- dlp->uderror_ind.dl_unix_errno,
- dlerrno(dlp->uderror_ind.dl_errno));
- (void) printf("addr %s\n", addr);
-}
-
-printdltestreq(dlp)
-union DL_primitives *dlp;
-{
- u_char addr[MAXDLADDR];
-
- addrtostring(OFFADDR(dlp, dlp->test_req.dl_dest_addr_offset),
- dlp->test_req.dl_dest_addr_length, addr);
-
- (void) printf("DL_TEST_REQ: flag 0x%x dest_addr_length %d dest_addr_offset %d\n",
- dlp->test_req.dl_flag,
- dlp->test_req.dl_dest_addr_length,
- dlp->test_req.dl_dest_addr_offset);
- (void) printf("dest_addr %s\n", addr);
-}
-
-printdltestind(dlp)
-union DL_primitives *dlp;
-{
- u_char dest[MAXDLADDR];
- u_char src[MAXDLADDR];
-
- addrtostring(OFFADDR(dlp, dlp->test_ind.dl_dest_addr_offset),
- dlp->test_ind.dl_dest_addr_length, dest);
- addrtostring(OFFADDR(dlp, dlp->test_ind.dl_src_addr_offset),
- dlp->test_ind.dl_src_addr_length, src);
-
- (void) printf("DL_TEST_IND: flag 0x%x dest_addr_length %d dest_addr_offset %d\n",
- dlp->test_ind.dl_flag,
- dlp->test_ind.dl_dest_addr_length,
- dlp->test_ind.dl_dest_addr_offset);
- (void) printf("src_addr_length %d src_addr_offset %d\n",
- dlp->test_ind.dl_src_addr_length,
- dlp->test_ind.dl_src_addr_offset);
- (void) printf("dest_addr %s\n", dest);
- (void) printf("src_addr %s\n", src);
-}
-
-printdltestres(dlp)
-union DL_primitives *dlp;
-{
- u_char dest[MAXDLADDR];
-
- addrtostring(OFFADDR(dlp, dlp->test_res.dl_dest_addr_offset),
- dlp->test_res.dl_dest_addr_length, dest);
-
- (void) printf("DL_TEST_RES: flag 0x%x dest_addr_length %d dest_addr_offset %d\n",
- dlp->test_res.dl_flag,
- dlp->test_res.dl_dest_addr_length,
- dlp->test_res.dl_dest_addr_offset);
- (void) printf("dest_addr %s\n", dest);
-}
-
-printdltestcon(dlp)
-union DL_primitives *dlp;
-{
- u_char dest[MAXDLADDR];
- u_char src[MAXDLADDR];
-
- addrtostring(OFFADDR(dlp, dlp->test_con.dl_dest_addr_offset),
- dlp->test_con.dl_dest_addr_length, dest);
- addrtostring(OFFADDR(dlp, dlp->test_con.dl_src_addr_offset),
- dlp->test_con.dl_src_addr_length, src);
-
- (void) printf("DL_TEST_CON: flag 0x%x dest_addr_length %d dest_addr_offset %d\n",
- dlp->test_con.dl_flag,
- dlp->test_con.dl_dest_addr_length,
- dlp->test_con.dl_dest_addr_offset);
- (void) printf("src_addr_length %d src_addr_offset %d\n",
- dlp->test_con.dl_src_addr_length,
- dlp->test_con.dl_src_addr_offset);
- (void) printf("dest_addr %s\n", dest);
- (void) printf("src_addr %s\n", src);
-}
-
-printdlxidreq(dlp)
-union DL_primitives *dlp;
-{
- u_char dest[MAXDLADDR];
-
- addrtostring(OFFADDR(dlp, dlp->xid_req.dl_dest_addr_offset),
- dlp->xid_req.dl_dest_addr_length, dest);
-
- (void) printf("DL_XID_REQ: flag 0x%x dest_addr_length %d dest_addr_offset %d\n",
- dlp->xid_req.dl_flag,
- dlp->xid_req.dl_dest_addr_length,
- dlp->xid_req.dl_dest_addr_offset);
- (void) printf("dest_addr %s\n", dest);
-}
-
-printdlxidind(dlp)
-union DL_primitives *dlp;
-{
- u_char dest[MAXDLADDR];
- u_char src[MAXDLADDR];
-
- addrtostring(OFFADDR(dlp, dlp->xid_ind.dl_dest_addr_offset),
- dlp->xid_ind.dl_dest_addr_length, dest);
- addrtostring(OFFADDR(dlp, dlp->xid_ind.dl_src_addr_offset),
- dlp->xid_ind.dl_src_addr_length, src);
-
- (void) printf("DL_XID_IND: flag 0x%x dest_addr_length %d dest_addr_offset %d\n",
- dlp->xid_ind.dl_flag,
- dlp->xid_ind.dl_dest_addr_length,
- dlp->xid_ind.dl_dest_addr_offset);
- (void) printf("src_addr_length %d src_addr_offset %d\n",
- dlp->xid_ind.dl_src_addr_length,
- dlp->xid_ind.dl_src_addr_offset);
- (void) printf("dest_addr %s\n", dest);
- (void) printf("src_addr %s\n", src);
-}
-
-printdlxidres(dlp)
-union DL_primitives *dlp;
-{
- u_char dest[MAXDLADDR];
-
- addrtostring(OFFADDR(dlp, dlp->xid_res.dl_dest_addr_offset),
- dlp->xid_res.dl_dest_addr_length, dest);
-
- (void) printf("DL_XID_RES: flag 0x%x dest_addr_length %d dest_addr_offset %d\n",
- dlp->xid_res.dl_flag,
- dlp->xid_res.dl_dest_addr_length,
- dlp->xid_res.dl_dest_addr_offset);
- (void) printf("dest_addr %s\n", dest);
-}
-
-printdlxidcon(dlp)
-union DL_primitives *dlp;
-{
- u_char dest[MAXDLADDR];
- u_char src[MAXDLADDR];
-
- addrtostring(OFFADDR(dlp, dlp->xid_con.dl_dest_addr_offset),
- dlp->xid_con.dl_dest_addr_length, dest);
- addrtostring(OFFADDR(dlp, dlp->xid_con.dl_src_addr_offset),
- dlp->xid_con.dl_src_addr_length, src);
-
- (void) printf("DL_XID_CON: flag 0x%x dest_addr_length %d dest_addr_offset %d\n",
- dlp->xid_con.dl_flag,
- dlp->xid_con.dl_dest_addr_length,
- dlp->xid_con.dl_dest_addr_offset);
- (void) printf("src_addr_length %d src_addr_offset %d\n",
- dlp->xid_con.dl_src_addr_length,
- dlp->xid_con.dl_src_addr_offset);
- (void) printf("dest_addr %s\n", dest);
- (void) printf("src_addr %s\n", src);
-}
-
-printdludqosreq(dlp)
-union DL_primitives *dlp;
-{
- (void) printf("DL_UDQOS_REQ: qos_length %d qos_offset %d\n",
- dlp->udqos_req.dl_qos_length,
- dlp->udqos_req.dl_qos_offset);
-}
-
-/*
- * Return string.
- */
-addrtostring(addr, length, s)
-u_char *addr;
-u_long length;
-u_char *s;
-{
- int i;
-
- for (i = 0; i < length; i++) {
- (void) sprintf((char*) s, "%x:", addr[i] & 0xff);
- s = s + strlen((char*)s);
- }
- if (length)
- *(--s) = '\0';
-}
-
-/*
- * Return length
- */
-stringtoaddr(sp, addr)
-char *sp;
-char *addr;
-{
- int n = 0;
- char *p;
- int val;
-
- p = sp;
- while (p = strtok(p, ":")) {
- if (sscanf(p, "%x", &val) != 1)
- err("stringtoaddr: invalid input string: %s", sp);
- if (val > 0xff)
- err("stringtoaddr: invalid input string: %s", sp);
- *addr++ = val;
- n++;
- p = NULL;
- }
-
- return (n);
-}
-
-
-static char
-hexnibble(c)
-char c;
-{
- static char hextab[] = {
- '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
- 'a', 'b', 'c', 'd', 'e', 'f'
- };
-
- return (hextab[c & 0x0f]);
-}
-
-char*
-dlprim(prim)
-u_long prim;
-{
- static char primbuf[80];
-
- switch ((int)prim) {
- CASERET(DL_INFO_REQ);
- CASERET(DL_INFO_ACK);
- CASERET(DL_ATTACH_REQ);
- CASERET(DL_DETACH_REQ);
- CASERET(DL_BIND_REQ);
- CASERET(DL_BIND_ACK);
- CASERET(DL_UNBIND_REQ);
- CASERET(DL_OK_ACK);
- CASERET(DL_ERROR_ACK);
- CASERET(DL_SUBS_BIND_REQ);
- CASERET(DL_SUBS_BIND_ACK);
- CASERET(DL_UNITDATA_REQ);
- CASERET(DL_UNITDATA_IND);
- CASERET(DL_UDERROR_IND);
- CASERET(DL_UDQOS_REQ);
- CASERET(DL_CONNECT_REQ);
- CASERET(DL_CONNECT_IND);
- CASERET(DL_CONNECT_RES);
- CASERET(DL_CONNECT_CON);
- CASERET(DL_TOKEN_REQ);
- CASERET(DL_TOKEN_ACK);
- CASERET(DL_DISCONNECT_REQ);
- CASERET(DL_DISCONNECT_IND);
- CASERET(DL_RESET_REQ);
- CASERET(DL_RESET_IND);
- CASERET(DL_RESET_RES);
- CASERET(DL_RESET_CON);
- default:
- (void) sprintf(primbuf, "unknown primitive 0x%x", prim);
- return (primbuf);
- }
-}
-
-
-char*
-dlstate(state)
-u_long state;
-{
- static char statebuf[80];
-
- switch (state) {
- CASERET(DL_UNATTACHED);
- CASERET(DL_ATTACH_PENDING);
- CASERET(DL_DETACH_PENDING);
- CASERET(DL_UNBOUND);
- CASERET(DL_BIND_PENDING);
- CASERET(DL_UNBIND_PENDING);
- CASERET(DL_IDLE);
- CASERET(DL_UDQOS_PENDING);
- CASERET(DL_OUTCON_PENDING);
- CASERET(DL_INCON_PENDING);
- CASERET(DL_CONN_RES_PENDING);
- CASERET(DL_DATAXFER);
- CASERET(DL_USER_RESET_PENDING);
- CASERET(DL_PROV_RESET_PENDING);
- CASERET(DL_RESET_RES_PENDING);
- CASERET(DL_DISCON8_PENDING);
- CASERET(DL_DISCON9_PENDING);
- CASERET(DL_DISCON11_PENDING);
- CASERET(DL_DISCON12_PENDING);
- CASERET(DL_DISCON13_PENDING);
- CASERET(DL_SUBS_BIND_PND);
- default:
- (void) sprintf(statebuf, "unknown state 0x%x", state);
- return (statebuf);
- }
-}
-
-char*
-dlerrno(errno)
-u_long errno;
-{
- static char errnobuf[80];
-
- switch (errno) {
- CASERET(DL_ACCESS);
- CASERET(DL_BADADDR);
- CASERET(DL_BADCORR);
- CASERET(DL_BADDATA);
- CASERET(DL_BADPPA);
- CASERET(DL_BADPRIM);
- CASERET(DL_BADQOSPARAM);
- CASERET(DL_BADQOSTYPE);
- CASERET(DL_BADSAP);
- CASERET(DL_BADTOKEN);
- CASERET(DL_BOUND);
- CASERET(DL_INITFAILED);
- CASERET(DL_NOADDR);
- CASERET(DL_NOTINIT);
- CASERET(DL_OUTSTATE);
- CASERET(DL_SYSERR);
- CASERET(DL_UNSUPPORTED);
- CASERET(DL_UNDELIVERABLE);
- CASERET(DL_NOTSUPPORTED);
- CASERET(DL_TOOMANY);
- CASERET(DL_NOTENAB);
- CASERET(DL_BUSY);
- CASERET(DL_NOAUTO);
- CASERET(DL_NOXIDAUTO);
- CASERET(DL_NOTESTAUTO);
- CASERET(DL_XIDAUTO);
- CASERET(DL_TESTAUTO);
- CASERET(DL_PENDING);
-
- default:
- (void) sprintf(errnobuf, "unknown dlpi errno 0x%x", errno);
- return (errnobuf);
- }
-}
-
-char*
-dlpromisclevel(level)
-u_long level;
-{
- static char levelbuf[80];
-
- switch (level) {
- CASERET(DL_PROMISC_PHYS);
- CASERET(DL_PROMISC_SAP);
- CASERET(DL_PROMISC_MULTI);
- default:
- (void) sprintf(levelbuf, "unknown promisc level 0x%x", level);
- return (levelbuf);
- }
-}
-
-char*
-dlservicemode(servicemode)
-u_long servicemode;
-{
- static char servicemodebuf[80];
-
- switch (servicemode) {
- CASERET(DL_CODLS);
- CASERET(DL_CLDLS);
- CASERET(DL_CODLS|DL_CLDLS);
- default:
- (void) sprintf(servicemodebuf,
- "unknown provider service mode 0x%x", servicemode);
- return (servicemodebuf);
- }
-}
-
-char*
-dlstyle(style)
-long style;
-{
- static char stylebuf[80];
-
- switch (style) {
- CASERET(DL_STYLE1);
- CASERET(DL_STYLE2);
- default:
- (void) sprintf(stylebuf, "unknown provider style 0x%x", style);
- return (stylebuf);
- }
-}
-
-char*
-dlmactype(media)
-u_long media;
-{
- static char mediabuf[80];
-
- switch (media) {
- CASERET(DL_CSMACD);
- CASERET(DL_TPB);
- CASERET(DL_TPR);
- CASERET(DL_METRO);
- CASERET(DL_ETHER);
- CASERET(DL_HDLC);
- CASERET(DL_CHAR);
- CASERET(DL_CTCA);
- default:
- (void) sprintf(mediabuf, "unknown media type 0x%x", media);
- return (mediabuf);
- }
-}
-
-/*VARARGS1*/
-err(fmt, a1, a2, a3, a4)
-char *fmt;
-char *a1, *a2, *a3, *a4;
-{
- (void) fprintf(stderr, fmt, a1, a2, a3, a4);
- (void) fprintf(stderr, "\n");
- (void) exit(1);
-}
-
-syserr(s)
-char *s;
-{
- (void) perror(s);
- exit(1);
-}
-
-strioctl(fd, cmd, timout, len, dp)
-int fd;
-int cmd;
-int timout;
-int len;
-char *dp;
-{
- struct strioctl sioc;
- int rc;
-
- sioc.ic_cmd = cmd;
- sioc.ic_timout = timout;
- sioc.ic_len = len;
- sioc.ic_dp = dp;
- rc = ioctl(fd, I_STR, &sioc);
-
- if (rc < 0)
- return (rc);
- else
- return (sioc.ic_len);
-}
OpenPOWER on IntegriCloud