⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ldlconfig.c

📁 7号信令功能代码,为开源代码
💻 C
📖 第 1 页 / 共 2 页
字号:
/***************************************************************************** @(#) ldlconfig.c,v LiS-2_16_18-8(1.1.1.1.8.1) 2004/01/12 23:33:15 ----------------------------------------------------------------------------- Copyright (c) 2003-2004  OpenSS7 Corporation <http://www.openss7.com> All Rights Reserved. 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 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ----------------------------------------------------------------------------- U.S. GOVERNMENT RESTRICTED RIGHTS.  If you are licensing this Software on behalf of the U.S. Government ("Government"), the following provisions apply to you.  If the Software is supplied by the Department of Defense ("DoD"), it is classified as "Commercial Computer Software" under paragraph 252.227-7014 of the DoD Supplement to the Federal Acquisition Regulations ("DFARS") (or any successor regulations) and the Government is acquiring only the license rights granted herein (the license rights customarily provided to non-Government users).  If the Software is supplied to any unit or agency of the Government other than DoD, it is classified as "Restricted Computer Software" and the Government's rights in the Software are defined in paragraph 52.227-19 of the Federal Acquisition Regulations ("FAR") (or any success regulations) or, in the cases of NASA, in paragraph 18.52.227-86 of the NASA Supplement to the FAR (or any successor regulations). ----------------------------------------------------------------------------- Commercial licensing and support of this software is available from OpenSS7 Corporation at a fee.  See http://www.openss7.com/ ----------------------------------------------------------------------------- Last Modified 2004/01/12 23:33:15 by brian ----------------------------------------------------------------------------- ldlconfig.c,v Revision 1.1.1.1.8.1  2004/01/12 23:33:15  brian - Updated LiS-2.16.18 gcom release to autoconf. Revision 1.1.1.1.4.2  2003/12/15 23:35:06  brian - Tried to reduce number of patch lines. Revision 1.1.1.1.4.1  2003/12/10 11:09:29  brian Start of autoconf changes. *****************************************************************************/#ident "@(#) ldlconfig.c,v LiS-2_16_18-8(1.1.1.1.8.1) 2004/01/12 23:33:15"static char const ident[] =    "ldlconfig.c,v LiS-2_16_18-8(1.1.1.1.8.1) 2004/01/12 23:33:15";/* *  ldlconfig: A configuration helper for ldl clients * *  Copyright (C) 1998 Ole Husgaard (sparre@login.dknet.dk) *  Copyright (C) 1999 David Grothe (dave@gcom.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 of the License, or *  (at your option) any later version. * *  This program is distributed in the hope that it will be useful, *  but WITHOUT ANY WARRANTY; without even the implied warranty of *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the *  GNU General Public License for more details. * *  You should have received a copy of the GNU General Public License *  along with this program; if not, write to the Free Software *  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. * */#ident "@(#) LiS ldlconfig.c 1.4 12/11/00"#include <stdio.h>#include <fcntl.h>#include <assert.h>#include <string.h>#include <ctype.h>#include <stdlib.h>#ifdef _GNU_SOURCE#include <getopt.h>#endif				/* _GNU_SOURCE */#include <sys/ioctl.h>#include <sys/dlpi.h>#include <sys/stropts.h>#include <sys/ldl.h>int             output = 1;#define MAX_DL_ADDR_LEN 128#define MAX_DL_SAP_LEN 64typedef unsigned char u8;typedef unsigned short u16;typedef unsigned int u32;unsigned char   my_addr[MAX_DL_ADDR_LEN];unsigned char   my_brd_addr[MAX_DL_ADDR_LEN];unsigned char   my_dlsap[MAX_DL_ADDR_LEN + MAX_DL_SAP_LEN];unsigned char   my_sap[MAX_DL_SAP_LEN];int             addr_len;	/* Data Link address length */int             sap_len;	/* Data Link SAP length */int             sap_first;	/* Flag: SAP first in DLSAP */int             hw_type;	/* ARP hardware type */int             filed = -1;char           *if_name = "eth0";unsigned long   bind_sap = 0xAA;int             bind_specified;unsigned long   flag_opts[32];int             nxt_flag_opt;unsigned long   promisc_opts[32];int             nxt_promisc_opt;unsigned long   framing = 0;int             print_info = 0;char           *hex(unsigned char c){    static char     s[3];    static char     h[16] = "0123456789abcdef";    s[0] = h[c >> 4];    s[1] = h[c & 15];    s[2] = '\0';    return s;}void dumpbuf(struct strbuf buf){    int             i,                    j;    int             lines = (buf.len == 0) ? 0 : ((buf.len - 1) >> 4) + 1;    char            s1[128],                    s2[128];    printf("  Len = %d  MaxLen = %d\n", buf.len, buf.maxlen);    for (i = 0; i < lines; ++i)    {	strcpy(s1, "  ");	strcpy(s2, "  ");	for (j = 0; j < 16; ++j)	{	    if (16 * i + j < buf.len)	    {		unsigned char   c = buf.buf[16 * i + j];		strcat(s1, hex(c));		strcat(s1, " ");		if (isprint(c))		{		    char            s3[2];		    s3[0] = c;		    s3[1] = '\0';		    strcat(s2, s3);		}		else		    strcat(s2, ".");	    }	    else	    {		strcat(s1, "   ");		strcat(s2, " ");	    }	    if (j == 7)	    {		strcat(s1, " ");		strcat(s2, " ");	    }	}	printf("  %s  %s\n", s1, s2);    }}void dumphex(unsigned char *data, int len){    while (len--)    {	printf("%s%s", hex(*data), (len) ? ":" : "");	++data;    }}void dumpbytes(char *prompt, unsigned char *data, int len){    printf("%s: ", prompt);    dumphex(data, len);    printf("\n");}void dumpaddr(char *prompt, unsigned char *addr, int addrlen){    printf("%s: ", prompt);    if (addrlen)    {	printf("%02x", (int) *addr++);	--addrlen;    }    else    {	printf("(none)\n");	return;    }    while (addrlen--)	printf(":%02x", (int) *addr++);    printf("\n");}void dump8022(char *prompt, unsigned char *buf, int length){    int             i;    int             ff_cnt = 0;    for (i = 0; i < 6; i++)    {	if (buf[i] == 0xff)	    ff_cnt++;    }    printf("%s: ", prompt);    printf("daddr=");    dumphex(buf, 6);    printf(" saddr=");    dumphex(buf + 6, 6);    printf("\n    length=");    dumphex(buf + 12, 2);    printf(" dsap=%02x ssap=%02x ctl=%02x\n", buf[14], buf[15], buf[16]);    if (length >= 17 && ff_cnt != 6)    {	dumpbytes("    data", buf + 17, length - 17);    }}#ifdef TRvoid dumptr(char *prompt, unsigned char *buf, int length){				/* dump token ring header/buffer */    tr_hdr_t       *hdrp;    rcf_t          *rcfp;    tr_llc_frm_hdr_t *llcp;    int             rtelgth = 0;    int             hdrsize;    hdrp = (tr_hdr_t *) buf;    rcfp = (rcf_t *) (hdrp + 1);    printf("%s: ", prompt);    printf("acf=%02x fcf=%02x ", hdrp->acf, hdrp->fcf);    printf("daddr=");    dumphex(hdrp->dst_addr, sizeof(hdrp->dst_addr));    printf(" saddr=");    dumphex(hdrp->src_addr, sizeof(hdrp->src_addr));    if (hdrp->src_addr[0] & SADDR_0_RTE_PRES)    {	rtelgth = rcfp->bl & RCF_0_LLLLL;	printf(" bl=%02x df=%02x", rcfp->bl, rcfp->df);	llcp = (tr_llc_frm_hdr_t *) (buf + sizeof(*hdrp) + rtelgth);    }    else	llcp = (tr_llc_frm_hdr_t *) (buf + sizeof(*hdrp));    printf(" dsap=%02x ssap=%02x ctl=%02x\n", llcp->llc_dsap, llcp->llc_ssap,	   llcp->llc_ctl);    hdrsize = sizeof(*hdrp) + sizeof(*llcp) + rtelgth;    if (length >= hdrsize)    {	dumpbytes("    data", buf + hdrsize, length - hdrsize);    }}#endifunsigned long do_findppa(int fd, char *interface){    union {	char            interface[256];	unsigned long   ppa;    } data;    struct strioctl strioctl;    strioctl.ic_cmd = LDL_FINDPPA;    strioctl.ic_timout = 3;    strioctl.ic_len = sizeof(data);    strioctl.ic_dp = (char *) &data;    strcpy(data.interface, interface);    if (ioctl(fd, I_STR, &strioctl) < 0)    {	perror("do_findppa: ioctl()");	return (unsigned long) -1;    }    return data.ppa;}int do_set_flags(int fd, int flags){    struct ldl_flags_ioctl ioc;    struct strioctl strioctl;    ioc.flags = flags;    ioc.mask = 0xff;    strioctl.ic_cmd = LDL_SETFLAGS;    strioctl.ic_timout = 3;    strioctl.ic_len = sizeof(ioc);    strioctl.ic_dp = (char *) &ioc;    if (ioctl(fd, I_STR, &strioctl) < 0)    {	perror("do_set_flags: ioctl()");	return -1;    }    return 0;}int do_info(int fd){    dl_info_req_t   request;    struct {	dl_info_ack_t   ack;	unsigned char   extra[1024];    } reply;    int             flags;    struct strbuf   ctlbuf;    dl_error_ack_t *err_ack;    if (output > 2)	printf("do_info: Sending DL_INFO_REQ\n");    request.dl_primitive = DL_INFO_REQ;    ctlbuf.maxlen = ctlbuf.len = sizeof(request);    ctlbuf.buf = (char *) &request;    if (putmsg(fd, &ctlbuf, NULL, 0) < 0)    {	perror("do_info: putmsg()");	return -1;    }    ctlbuf.maxlen = sizeof(reply);    ctlbuf.len = 0;    ctlbuf.buf = (char *) &reply;    flags = RS_HIPRI;    flags = 0;    if (getmsg(fd, &ctlbuf, NULL, &flags) < 0)    {	perror("do_info: getmsg()");	return -1;    }    if (output > 2)    {	printf("do_info: Buffer dump:\n");	dumpbuf(ctlbuf);    }    if (ctlbuf.len < sizeof(dl_ulong))    {	fprintf(stderr, "do_info: Bad reply length %d\n", ctlbuf.len);	return -1;    }    switch (reply.ack.dl_primitive)    {	case DL_ERROR_ACK:	    printf("do_info: Got DL_ERROR_ACK\n");	    if (ctlbuf.len < sizeof(dl_error_ack_t))	    {		fprintf(stderr, "do_info: Bad DL_ERROR_ACK length %d\n",			ctlbuf.len);		return -1;	    }	    err_ack = (dl_error_ack_t *) & reply;	    printf("do_info: error ack:\n");	    printf("\tprimitive=%lu, errno=%lu, unix_errno=%lu\n",		   err_ack->dl_error_primitive, err_ack->dl_errno,		   err_ack->dl_unix_errno);	    return -1;	case DL_INFO_ACK:	    if (output > 2)		printf("do_info: Got DL_INFO_ACK\n");	    if (ctlbuf.len < sizeof(dl_info_ack_t))	    {		fprintf(stderr, "do_info: Bad DL_INFO_ACK length %d\n",			ctlbuf.len);		return -1;	    }	    if (output > 1)	    {		printf("do_info: info ack:\n");		printf("\tprimitive=%lu\n", reply.ack.dl_primitive);		printf("\tmin_sdu=%lu\n", reply.ack.dl_min_sdu);		printf("\tmax_sdu=%lu\n", reply.ack.dl_max_sdu);		printf("\taddr_length=%lu\n", reply.ack.dl_addr_length);		printf("\tmac_type=%lu\n", reply.ack.dl_mac_type);		printf("\treserved=%lu\n", reply.ack.dl_reserved);		printf("\tcurrent_state=%lu\n", reply.ack.dl_current_state);		printf("\tsap_length=%ld\n", reply.ack.dl_sap_length);		printf("\tservice_mode=%lu\n", reply.ack.dl_service_mode);		printf("\tqos_length=%lu\n", reply.ack.dl_qos_length);		printf("\tqos_offset=%lu\n", reply.ack.dl_qos_offset);		printf("\tqos_range_length=%lu\n",		       reply.ack.dl_qos_range_length);		printf("\tqos_range_offset=%lu\n",		       reply.ack.dl_qos_range_offset);		printf("\tprovider_style=%ld\n", reply.ack.dl_provider_style);		printf("\taddr_offset=%lu\n", reply.ack.dl_addr_offset);		printf("\tversion=%lu\n", reply.ack.dl_version);		printf("\tbrdcst_addr_length=%lu\n",		       reply.ack.dl_brdcst_addr_length);		printf("\tbrdcst_addr_offset=%lu\n",		       reply.ack.dl_brdcst_addr_offset);		printf("\tgrowth=%lu\n", reply.ack.dl_growth);		if (reply.ack.dl_addr_length && reply.ack.dl_addr_offset &&		    reply.ack.dl_addr_offset + reply.ack.dl_addr_length <=		    ctlbuf.len)		    dumpaddr("\tAddress", &ctlbuf.buf[reply.ack.dl_addr_offset],			     reply.ack.dl_addr_length);		if (reply.ack.dl_brdcst_addr_length		    && reply.ack.dl_brdcst_addr_offset		    && reply.ack.dl_brdcst_addr_offset +		    reply.ack.dl_brdcst_addr_length <= ctlbuf.len)		    dumpaddr("\tBroadcast address",			     &ctlbuf.buf[reply.ack.dl_brdcst_addr_offset],			     reply.ack.dl_brdcst_addr_length);		if (reply.ack.dl_qos_length >= sizeof(unsigned long)		    && reply.ack.dl_qos_offset)		{		    dl_qos_cl_sel1_t *sel =			(dl_qos_cl_sel1_t *) ((char *) &reply.ack +					      reply.ack.dl_qos_offset);		    printf("\tQOS selection:\n");		    if (sel->dl_qos_type != DL_QOS_CL_SEL1)			printf("\t\tUnknown type %lu, expected %lu\n",			       sel->dl_qos_type, (dl_ulong) DL_QOS_CL_SEL1);		    else		    {			printf("\t\ttrans_delay=%ld\n", sel->dl_trans_delay);			printf("\t\tpriority=%ld\n", sel->dl_priority);			printf("\t\tprotection=%ld\n", sel->dl_protection);			printf("\t\tresidual_error=%ld\n",			       sel->dl_residual_error);		    }		}		if (reply.ack.dl_qos_range_length >= sizeof(unsigned long) &&		    reply.ack.dl_qos_range_offset)		{		    dl_qos_cl_range1_t *range =			(dl_qos_cl_range1_t *) ((char *) &reply.ack +						reply.ack.dl_qos_range_offset);		    printf("\tQOS range:\n");		    if (range->dl_qos_type != DL_QOS_CL_RANGE1)			printf("\t\tUnknown type %lu, expected %lu\n",			       range->dl_qos_type, (dl_ulong) DL_QOS_CL_RANGE1);		    else		    {			printf("\t\ttrans_delay(target, accept)=(%ld, %ld)\n",			       range->dl_trans_delay.dl_target_value,			       range->dl_trans_delay.dl_accept_value);			printf("\t\tpriority(min, max)=(%ld, %ld)\n",			       range->dl_priority.dl_min,			       range->dl_priority.dl_max);			printf("\t\tprotection(min, max)=(%ld, %ld)\n",			       range->dl_protection.dl_min,			       range->dl_protection.dl_max);			printf("\t\tresidual_error=%ld\n",			       range->dl_residual_error);		    }		}	    }	    if (reply.ack.dl_sap_length < 0)	    {		sap_len = -reply.ack.dl_sap_length;		sap_first = 0;	    }	    else	    {		sap_len = reply.ack.dl_sap_length;		sap_first = 1;	    }	    addr_len = reply.ack.dl_addr_length - sap_len;	    if (reply.ack.dl_addr_length != 0 && reply.ack.dl_addr_offset != 0)	    {		memcpy(my_dlsap, &ctlbuf.buf[reply.ack.dl_addr_offset],		       addr_len + sap_len);		if (sap_first)		{		    memcpy(my_sap, &ctlbuf.buf[reply.ack.dl_addr_offset],			   sap_len);		    memcpy(my_addr,			   &ctlbuf.buf[reply.ack.dl_addr_offset + sap_len],			   addr_len);		}		else		{		    memcpy(my_addr, &ctlbuf.buf[reply.ack.dl_addr_offset],			   addr_len);		    memcpy(my_sap,			   &ctlbuf.buf[reply.ack.dl_addr_offset + addr_len],			   sap_len);		}	    }	    if (reply.ack.dl_brdcst_addr_length != 0		&& reply.ack.dl_brdcst_addr_offset != 0)	    {		assert(reply.ack.dl_addr_length == 0		       || reply.ack.dl_brdcst_addr_length == addr_len);		memcpy(my_brd_addr,		       &ctlbuf.buf[reply.ack.dl_brdcst_addr_offset],		       reply.ack.dl_brdcst_addr_length);	    }	    break;	default:	    fprintf(stderr, "do_info: Unknown reply primitive=%lu\n",		    reply.ack.dl_primitive);	    return -1;    }    return 0;}int do_attach(int fd, dl_ulong ppa){    dl_attach_req_t request;    struct {	dl_ok_ack_t     ack;	unsigned char   extra[1024];    } reply;    int             flags;    struct strbuf   ctlbuf;    dl_error_ack_t *err_ack;    if (output > 2)

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -