5493f188c7
parentheses in return statements. Cosmetic: don't open-code TAILQ_FOREACH(). Cosmetic: change types of variables to avoid oodles of casts: in in6_src.c, avoid casts by changing several route_in6 pointers to struct route pointers. Remove unnecessary casts to caddr_t elsewhere. Pave the way for eliminating address family-specific route caches: soon, struct route will not embed a sockaddr, but it will hold a reference to an external sockaddr, instead. We will set the destination sockaddr using rtcache_setdst(). (I created a stub for it, but it isn't used anywhere, yet.) rtcache_free() will free the sockaddr. I have extracted from rtcache_free() a helper subroutine, rtcache_clear(). rtcache_clear() will "forget" a cached route, but it will not forget the destination by releasing the sockaddr. I use rtcache_clear() instead of rtcache_free() in rtcache_update(), because rtcache_update() is not supposed to forget the destination. Constify: 1 Introduce const accessor for route->ro_dst, rtcache_getdst(). 2 Constify the 'dst' argument to ifnet->if_output(). This led me to constify a lot of code called by output routines. 3 Constify the sockaddr argument to protosw->pr_ctlinput. This led me to constify a lot of code called by ctlinput routines. 4 Introduce const macros for converting from a generic sockaddr to family-specific sockaddrs, e.g., sockaddr_in: satocsin6, satocsin, et cetera.
268 lines
7.4 KiB
C
268 lines
7.4 KiB
C
/* $NetBSD: clnp_debug.c,v 1.18 2007/02/17 22:34:16 dyoung Exp $ */
|
|
|
|
/*-
|
|
* Copyright (c) 1991, 1993
|
|
* The Regents of the University of California. All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
* documentation and/or other materials provided with the distribution.
|
|
* 3. Neither the name of the University nor the names of its contributors
|
|
* may be used to endorse or promote products derived from this software
|
|
* without specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
* SUCH DAMAGE.
|
|
*
|
|
* @(#)clnp_debug.c 8.1 (Berkeley) 6/10/93
|
|
*/
|
|
|
|
/***********************************************************
|
|
Copyright IBM Corporation 1987
|
|
|
|
All Rights Reserved
|
|
|
|
Permission to use, copy, modify, and distribute this software and its
|
|
documentation for any purpose and without fee is hereby granted,
|
|
provided that the above copyright notice appear in all copies and that
|
|
both that copyright notice and this permission notice appear in
|
|
supporting documentation, and that the name of IBM not be
|
|
used in advertising or publicity pertaining to distribution of the
|
|
software without specific, written prior permission.
|
|
|
|
IBM DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING
|
|
ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL
|
|
IBM BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR
|
|
ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
|
|
WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
|
|
ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
|
|
SOFTWARE.
|
|
|
|
******************************************************************/
|
|
|
|
/*
|
|
* ARGO Project, Computer Sciences Dept., University of Wisconsin - Madison
|
|
*/
|
|
|
|
#include <sys/cdefs.h>
|
|
__KERNEL_RCSID(0, "$NetBSD: clnp_debug.c,v 1.18 2007/02/17 22:34:16 dyoung Exp $");
|
|
|
|
#include <sys/param.h>
|
|
#include <sys/mbuf.h>
|
|
#include <sys/domain.h>
|
|
#include <sys/protosw.h>
|
|
#include <sys/socket.h>
|
|
#include <sys/socketvar.h>
|
|
#include <sys/errno.h>
|
|
#include <sys/systm.h>
|
|
|
|
#include <net/if.h>
|
|
#include <net/route.h>
|
|
|
|
#include <netiso/iso.h>
|
|
#include <netiso/clnp.h>
|
|
#include <netiso/clnp_stat.h>
|
|
#include <netiso/argo_debug.h>
|
|
|
|
#ifdef ARGO_DEBUG
|
|
|
|
#ifdef TESTDEBUG
|
|
#ifdef notdef
|
|
struct addr_37 u_37 = {
|
|
{0x00, 0x02, 0x00, 0x10, 0x20, 0x30, 0x35},
|
|
{0x01, 0x02, 0x03, 0x04, 0x50, 0x60, 0x70, 0x80, 0x90}
|
|
};
|
|
struct addr_osinet u_osinet = {
|
|
{0x00, 0x04},
|
|
{0x00, 0x02, 0x00, 0x01, 0x23, 0x42, 0x78, 0x20, 0x01, 0x05, 0x00}
|
|
};
|
|
#endif /* notdef */
|
|
struct addr_rfc986 u_rfc986 = {
|
|
{0x00, 0x06},
|
|
{0x01, 0xc0, 0x0c, 0x0c, 0xab, 0x11}
|
|
};
|
|
struct addr_rfc986 u_bad = {
|
|
{0x00, 0x01},
|
|
{0x01, 0xc0, 0x0c, 0x0c, 0xab, 0x11}
|
|
};
|
|
int main (void);
|
|
|
|
#include <stdio.h>
|
|
int
|
|
main()
|
|
{
|
|
struct iso_addr a;
|
|
|
|
a.isoa_afi = AFI_37;
|
|
a.isoa_u.addr_37 = u_37;
|
|
a.isoa_len = 17;
|
|
printf("type 37: %s\n", clnp_iso_addrp(&a));
|
|
|
|
a.isoa_afi = AFI_OSINET;
|
|
a.isoa_u.addr_osinet = u_osinet;
|
|
a.isoa_len = 14;
|
|
printf("type osinet: %s\n", clnp_iso_addrp(&a));
|
|
|
|
a.isoa_afi = AFI_RFC986;
|
|
a.isoa_u.addr_rfc986 = u_rfc986;
|
|
a.isoa_len = 9;
|
|
printf("type rfc986: %s\n", clnp_iso_addrp(&a));
|
|
|
|
a.isoa_afi = 12;
|
|
a.isoa_u.addr_rfc986 = u_rfc986;
|
|
a.isoa_len = 9;
|
|
printf("type bad afi: %s\n", clnp_iso_addrp(&a));
|
|
|
|
a.isoa_afi = AFI_RFC986;
|
|
a.isoa_u.addr_rfc986 = u_bad;
|
|
a.isoa_len = 9;
|
|
printf("type bad idi: %s\n", clnp_iso_addrp(&a));
|
|
return 0;
|
|
}
|
|
#endif /* TESTDEBUG */
|
|
|
|
unsigned int clnp_debug;
|
|
|
|
char *clnp_hexp (const char *, int, char *);
|
|
char *clnp_iso_addrp(const struct iso_addr *);
|
|
char *clnp_saddr_isop(const struct sockaddr_iso *);
|
|
|
|
/*
|
|
* Print buffer in hex, return addr of where we left off.
|
|
* Do not null terminate.
|
|
*/
|
|
char *
|
|
clnp_hexp(const char *src, int len, char *where)
|
|
{
|
|
int i;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
int j = ((const u_char *) src)[i];
|
|
*where++ = hexdigits[j >> 4];
|
|
*where++ = hexdigits[j & 0x0f];
|
|
}
|
|
return where;
|
|
}
|
|
|
|
/*
|
|
* Return a ptr to a human readable form of an iso addr
|
|
*/
|
|
static char iso_addr_b[50];
|
|
#define DELIM '.';
|
|
|
|
char *
|
|
clnp_iso_addrp(const struct iso_addr *isoa)
|
|
{
|
|
char *cp;
|
|
#ifdef notdef
|
|
u_short idi;
|
|
#endif
|
|
|
|
/* print length */
|
|
snprintf(iso_addr_b, sizeof(iso_addr_b), "[%d] ", isoa->isoa_len);
|
|
|
|
/* set cp to end of what we have */
|
|
cp = iso_addr_b;
|
|
while (*cp)
|
|
cp++;
|
|
|
|
/* print afi */
|
|
cp = clnp_hexp(isoa->isoa_genaddr, (int) isoa->isoa_len, cp);
|
|
#ifdef notdef
|
|
*cp++ = DELIM;
|
|
|
|
/* print type specific part */
|
|
switch (isoa->isoa_afi) {
|
|
case AFI_37:
|
|
cp = clnp_hexp(isoa->t37_idi, ADDR37_IDI_LEN, cp);
|
|
*cp++ = DELIM;
|
|
cp = clnp_hexp(isoa->t37_dsp, ADDR37_DSP_LEN, cp);
|
|
break;
|
|
|
|
/* case AFI_OSINET: */
|
|
case AFI_RFC986:
|
|
|
|
/* osinet and rfc986 have idi in the same place */
|
|
/* print idi */
|
|
cp = clnp_hexp(isoa->rfc986_idi,
|
|
ADDROSINET_IDI_LEN, cp);
|
|
*cp++ = DELIM;
|
|
CTOH(isoa->rfc986_idi[0], isoa->rfc986_idi[1], idi);
|
|
|
|
if (idi == IDI_OSINET) {
|
|
struct ovl_osinet *oosi = (struct ovl_osinet *) isoa;
|
|
cp = clnp_hexp(oosi->oosi_orgid,
|
|
OVLOSINET_ORGID_LEN, cp);
|
|
*cp++ = DELIM;
|
|
cp = clnp_hexp(oosi->oosi_snetid,
|
|
OVLOSINET_SNETID_LEN, cp);
|
|
*cp++ = DELIM;
|
|
cp = clnp_hexp(oosi->oosi_snpa, OVLOSINET_SNPA_LEN, cp);
|
|
*cp++ = DELIM;
|
|
cp = clnp_hexp(oosi->oosi_nsap, OVLOSINET_NSAP_LEN, cp);
|
|
} else if (idi == IDI_RFC986) {
|
|
struct ovl_rfc986 *o986 = (struct ovl_rfc986 *) isoa;
|
|
cp = clnp_hexp(&o986->o986_vers, 1, cp);
|
|
*cp++ = DELIM;
|
|
#ifdef __vax__
|
|
sprintf(cp, "%d.%d.%d.%d.%d",
|
|
o986->o986_inetaddr[0] & 0xff,
|
|
o986->o986_inetaddr[1] & 0xff,
|
|
o986->o986_inetaddr[2] & 0xff,
|
|
o986->o986_inetaddr[3] & 0xff,
|
|
o986->o986_upid & 0xff);
|
|
return (iso_addr_b);
|
|
#else
|
|
cp = clnp_hexp(&o986->o986_inetaddr[0], 1, cp);
|
|
*cp++ = DELIM;
|
|
cp = clnp_hexp(&o986->o986_inetaddr[1], 1, cp);
|
|
*cp++ = DELIM;
|
|
cp = clnp_hexp(&o986->o986_inetaddr[2], 1, cp);
|
|
*cp++ = DELIM;
|
|
cp = clnp_hexp(&o986->o986_inetaddr[3], 1, cp);
|
|
*cp++ = DELIM;
|
|
cp = clnp_hexp(&o986->o986_upid, 1, cp);
|
|
#endif /* vax */
|
|
}
|
|
break;
|
|
|
|
default:
|
|
*cp++ = '?';
|
|
break;
|
|
}
|
|
#endif /* notdef */
|
|
*cp = (char) 0;
|
|
|
|
return (iso_addr_b);
|
|
}
|
|
|
|
char *
|
|
clnp_saddr_isop(const struct sockaddr_iso *s)
|
|
{
|
|
char *cp = clnp_iso_addrp(&s->siso_addr);
|
|
|
|
while (*cp)
|
|
cp++;
|
|
*cp++ = '(';
|
|
cp = clnp_hexp(TSEL(s), (int) s->siso_tlen, cp);
|
|
*cp++ = ')';
|
|
*cp++ = 0;
|
|
return (iso_addr_b);
|
|
}
|
|
|
|
#endif /* ARGO_DEBUG */
|