freebsd-skq/sys/netatm/spans/spans_print.c
Archie Cobbs 2127f26023 Examine all occurrences of sprintf(), strcat(), and str[n]cpy()
for possible buffer overflow problems. Replaced most sprintf()'s
with snprintf(); for others cases, added terminating NUL bytes where
appropriate, replaced constants like "16" with sizeof(), etc.

These changes include several bug fixes, but most changes are for
maintainability's sake. Any instance where it wasn't "immediately
obvious" that a buffer overflow could not occur was made safer.

Reviewed by:	Bruce Evans <bde@zeta.org.au>
Reviewed by:	Matthew Dillon <dillon@apollo.backplane.com>
Reviewed by:	Mike Spengler <mks@networkcs.com>
1998-12-04 22:54:57 +00:00

1085 lines
29 KiB
C

/*
*
* ===================================
* HARP | Host ATM Research Platform
* ===================================
*
*
* This Host ATM Research Platform ("HARP") file (the "Software") is
* made available by Network Computing Services, Inc. ("NetworkCS")
* "AS IS". NetworkCS does not provide maintenance, improvements or
* support of any kind.
*
* NETWORKCS MAKES NO WARRANTIES OR REPRESENTATIONS, EXPRESS OR IMPLIED,
* INCLUDING, BUT NOT LIMITED TO, IMPLIED WARRANTIES OF MERCHANTABILITY
* AND FITNESS FOR A PARTICULAR PURPOSE, AS TO ANY ELEMENT OF THE
* SOFTWARE OR ANY SUPPORT PROVIDED IN CONNECTION WITH THIS SOFTWARE.
* In no event shall NetworkCS be responsible for any damages, including
* but not limited to consequential damages, arising from or relating to
* any use of the Software or related support.
*
* Copyright 1994-1998 Network Computing Services, Inc.
*
* Copies of this Software may be made, however, the above copyright
* notice must be reproduced on all copies.
*
* @(#) $Id: spans_print.c,v 1.3 1998/10/31 20:06:56 phk Exp $
*
*/
/*
* SPANS Signalling Manager
* ---------------------------
*
* SPANS Print Routines.
*
*/
#include <netatm/kern_include.h>
#include "spans_xdr.h"
#include <netatm/spans/spans_var.h>
#ifndef lint
__RCSID("@(#) $Id: spans_print.c,v 1.3 1998/10/31 20:06:56 phk Exp $");
#endif
/*
* If LONGPRINT is defined, every field of the SPANS message will be
* printed. If not, a shorter summary (useful for debugging without
* swamping the console) is printed.
*/
/* #define LONGPRINT */
/*
* Local functions
*/
static void spans_msgtype_str __P((spans_msgtype *, char *, int));
static void spans_print_msgbody __P((spans_msgbody *));
static void spans_result_str __P((spans_result *, char *, int));
#ifdef LONGPRINT
static void inc_indent __P((void));
static void dec_indent __P((void));
static void spans_aal_str __P((spans_aal *, char *, int));
static void spans_query_type_str __P((spans_query_type *, char *, int));
static void spans_state_str __P((spans_query_type *, char *, int));
static void spans_print_version __P((spans_version *));
static void spans_print_vpvc __P((spans_vpvc *));
static void spans_print_vpvc_pref __P((spans_vpvc_pref *));
static void spans_print_addr __P((spans_addr *));
static void spans_print_sap __P((spans_sap *));
static void spans_print_atm_conn __P((spans_atm_conn *));
static void spans_print_resrc __P((spans_resrc *));
static void spans_print_aal __P((spans_aal *));
static void spans_print_result __P((spans_result *));
static void spans_print_msgtype __P((spans_msgtype *));
static void spans_print_parm_stat_req __P((spans_parm_stat_req *));
static void spans_print_parm_stat_ind __P((spans_parm_stat_ind *));
static void spans_print_parm_stat_rsp __P((spans_parm_stat_rsp *));
static void spans_print_parm_open_req __P((spans_parm_open_req *));
static void spans_print_parm_open_ind __P((spans_parm_open_ind *));
static void spans_print_parm_open_rsp __P((spans_parm_open_rsp *));
static void spans_print_parm_open_cnf __P((spans_parm_open_cnf *));
static void spans_print_parm_close_req __P((spans_parm_close_req *));
static void spans_print_parm_close_ind __P((spans_parm_close_ind *));
static void spans_print_parm_close_rsp __P((spans_parm_close_rsp *));
static void spans_print_parm_close_cnf __P((spans_parm_close_cnf *));
static void spans_print_parm_rclose_req __P((spans_parm_rclose_req *));
static void spans_print_parm_rclose_ind __P((spans_parm_rclose_ind *));
static void spans_print_parm_rclose_rsp __P((spans_parm_rclose_rsp *));
static void spans_print_parm_rclose_cnf __P((spans_parm_rclose_cnf *));
static void spans_print_parm_multi_req __P((spans_parm_multi_req *));
static void spans_print_parm_multi_ind __P((spans_parm_multi_ind *));
static void spans_print_parm_multi_rsp __P((spans_parm_multi_rsp *));
static void spans_print_parm_multi_cnf __P((spans_parm_multi_cnf *));
static void spans_print_parm_add_req __P((spans_parm_add_req *));
static void spans_print_parm_add_ind __P((spans_parm_add_ind *));
static void spans_print_parm_add_rsp __P((spans_parm_add_rsp *));
static void spans_print_parm_add_cnf __P((spans_parm_add_cnf *));
static void spans_print_parm_join_req __P((spans_parm_join_req *));
static void spans_print_parm_join_cnf __P((spans_parm_join_cnf *));
static void spans_print_parm_leave_req __P((spans_parm_leave_req *));
static void spans_print_parm_leave_cnf __P((spans_parm_leave_cnf *));
static void spans_print_parm_vcir_ind __P((spans_parm_vcir_ind *));
static void spans_print_parm_query_req __P((spans_parm_query_req *));
static void spans_print_parm_query_rsp __P((spans_parm_query_rsp *));
/*
* Local variables
*/
#define MAX_INDENT 10
#define INIT_INDENT &indent_str[MAX_INDENT]
static char *spans_indent;
static char indent_str[11] = " ";
static void
inc_indent()
{
if (spans_indent != &indent_str[0]) {
spans_indent--;
}
}
static void
dec_indent()
{
if (spans_indent != INIT_INDENT) {
spans_indent++;
}
}
static void
spans_aal_str(objp, dest, len)
spans_aal *objp;
char *dest;
int len;
{
static char *aal_names[] = {
"SPANS_AAL0",
"SPANS_AAL1",
"SPANS_AAL2",
"SPANS_AAL3",
"SPANS_AAL4",
"SPANS_AAL5"
};
if (*objp < SPANS_AAL0 || *objp > SPANS_AAL5) {
snprintf(dest, len, "Invalid (%d)", (int)*objp);
} else {
snprintf(dest, len, "%s (%d)", aal_names[(int)*objp],
(int)*objp);
}
}
#endif
static void
spans_result_str(objp, dest, len)
spans_result *objp;
char *dest;
int len;
{
static char *result_names[] = {
"SPANS_OK",
"SPANS_FAIL",
"SPANS_NOVPVC",
"SPANS_NORSC",
"SPANS_BADDEST"
};
if (*objp < SPANS_OK || *objp > SPANS_BADDEST) {
snprintf(dest, len, "Invalid (%d)", (int)*objp);
} else {
snprintf(dest, len, "%s (%d)",
result_names[(int)*objp], (int)*objp);
}
}
static void
spans_msgtype_str(objp, dest, len)
spans_msgtype *objp;
char *dest;
int len;
{
int i;
static struct {
spans_msgtype type;
char *name;
} msgtype_names[] = {
{ SPANS_STAT_REQ, "SPANS_STAT_REQ" },
{ SPANS_STAT_IND, "SPANS_STAT_IND" },
{ SPANS_STAT_RSP, "SPANS_STAT_RSP" },
{ SPANS_OPEN_REQ, "SPANS_OPEN_REQ" },
{ SPANS_OPEN_IND, "SPANS_OPEN_IND" },
{ SPANS_OPEN_RSP, "SPANS_OPEN_RSP" },
{ SPANS_OPEN_CNF, "SPANS_OPEN_CNF" },
{ SPANS_CLOSE_REQ, "SPANS_CLOSE_REQ" },
{ SPANS_CLOSE_IND, "SPANS_CLOSE_IND" },
{ SPANS_CLOSE_RSP, "SPANS_CLOSE_RSP" },
{ SPANS_CLOSE_CNF, "SPANS_CLOSE_CNF" },
{ SPANS_RCLOSE_REQ, "SPANS_RCLOSE_REQ" },
{ SPANS_RCLOSE_IND, "SPANS_RCLOSE_IND" },
{ SPANS_RCLOSE_RSP, "SPANS_RCLOSE_RSP" },
{ SPANS_RCLOSE_CNF, "SPANS_RCLOSE_CNF" },
{ SPANS_MULTI_REQ, "SPANS_MULTI_REQ" },
{ SPANS_MULTI_IND, "SPANS_MULTI_IND" },
{ SPANS_MULTI_RSP, "SPANS_MULTI_RSP" },
{ SPANS_MULTI_CNF, "SPANS_MULTI_CNF" },
{ SPANS_ADD_REQ, "SPANS_ADD_REQ" },
{ SPANS_ADD_IND, "SPANS_ADD_IND" },
{ SPANS_ADD_RSP, "SPANS_ADD_RSP" },
{ SPANS_ADD_CNF, "SPANS_ADD_CNF" },
{ SPANS_JOIN_REQ, "SPANS_JOIN_REQ" },
{ SPANS_JOIN_CNF, "SPANS_JOIN_CNF" },
{ SPANS_LEAVE_REQ, "SPANS_LEAVE_REQ" },
{ SPANS_LEAVE_CNF, "SPANS_LEAVE_CNF" },
{ SPANS_VCIR_IND, "SPANS_VCIR_IND" },
{ SPANS_QUERY_REQ, "SPANS_QUERY_REQ" },
{ SPANS_QUERY_RSP, "SPANS_QUERY_RSP" },
{ 0, (char *) 0 }
};
/*
* Search the name table for the specified type
*/
for (i=0; msgtype_names[i].name; i++) {
if (*objp == msgtype_names[i].type) {
snprintf(dest, len, "%s (%d)",
msgtype_names[i].name,
(int)*objp);
return;
}
}
/*
* Type was not found--return an error indicator
*/
snprintf(dest, len, "Invalid (%d)", (int)*objp);
}
#ifdef LONGPRINT
static void
spans_query_type_str(objp, dest, len)
spans_query_type *objp;
char *dest;
int len;
{
static char *query_names[] = {
"SPANS_QUERY_NORMAL",
"SPANS_QUERY_DEBUG",
"SPANS_QUERY_END_TO_END"
};
if (*objp < SPANS_QUERY_NORMAL ||
*objp > SPANS_QUERY_END_TO_END) {
snprintf(dest, len, "Invalid (%d)", (int)*objp);
} else {
snprintf(dest, len, "%s (%d)", query_names[(int)*objp],
(int)*objp);
}
}
static void
spans_state_str(objp, dest, len)
spans_query_type *objp;
char *dest;
int len;
{
static char *state_names[] = {
"SPANS_CONN_OPEN",
"SPANS_CONN_OPEN_PEND",
"SPANS_CONN_CLOSE_PEND",
"SPANS_CONN_CLOSED"
};
if (*objp < SPANS_CONN_OPEN || *objp > SPANS_CONN_CLOSED) {
snprintf(dest, len, "Invalid (%d)", (int)*objp);
} else {
snprintf(dest, len, "%s (%d)", state_names[(int)*objp],
(int)*objp);
}
}
static void
spans_print_version(objp)
spans_version *objp;
{
printf("%sspans_version 0x%x\n", spans_indent, *objp);
}
static void
spans_print_vpvc(objp)
spans_vpvc *objp;
{
printf("%sVP/VC %d/%d\n", spans_indent,
SPANS_EXTRACT_VPI(*objp),
SPANS_EXTRACT_VCI(*objp));
}
static void
spans_print_vpvc_pref(objp)
spans_vpvc_pref *objp;
{
printf("%sspans_vpvc_pref\n", spans_indent);
inc_indent();
printf("%s%s\n", spans_indent,
(objp->vpf_valid ? "Valid" : "Not valid"));
spans_print_vpvc(&objp->vpf_vpvc);
dec_indent();
}
static void
spans_print_addr(objp)
spans_addr *objp;
{
char addr_str[80];
strncpy(addr_str, spans_addr_print(objp), sizeof(addr_str));
printf("%sspans_addr %s\n", spans_indent, addr_str);
}
static void
spans_print_sap(objp)
spans_sap *objp;
{
printf("%sSAP %d\n", spans_indent, *objp);
}
static void
spans_print_atm_conn(objp)
spans_atm_conn *objp;
{
printf("%sspans_atm_conn\n", spans_indent);
inc_indent();
spans_print_addr(&objp->con_dst);
spans_print_addr(&objp->con_src);
spans_print_sap(&objp->con_dsap);
spans_print_sap(&objp->con_ssap);
dec_indent();
}
static void
spans_print_resrc(objp)
spans_resrc *objp;
{
printf("%sspans_resrc\n", spans_indent);
inc_indent();
printf("%srsc_peak %d\n", spans_indent, objp->rsc_peak);
printf("%srsc_mean %d\n", spans_indent, objp->rsc_mean);
printf("%srsc_burst %d\n", spans_indent, objp->rsc_burst);
dec_indent();
}
static void
spans_print_aal(objp)
spans_aal *objp;
{
char aal_str[80];
spans_aal_str(objp, aal_str, sizeof(aal_str));
printf("%sspans_aal %s\n", spans_indent, aal_str);
}
static void
spans_print_result(objp)
spans_result *objp;
{
char result_str[80];
spans_result_str(objp, result_str, sizeof(result_str));
printf("%sspans_result %s\n", spans_indent, result_str);
}
static void
spans_print_msgtype(objp)
spans_msgtype *objp;
{
char msgtype_str[80];
spans_msgtype_str(objp, msgtype_str, sizeof(msgtype_str));
printf("%sspans_msgtype %s\n", spans_indent, msgtype_str);
}
static void
spans_print_parm_stat_req(objp)
spans_parm_stat_req *objp;
{
printf("%sspans_parm_stat_req\n", spans_indent);
inc_indent();
printf("%sstreq_es_epoch %d\n", spans_indent,
objp->streq_es_epoch);
dec_indent();
}
static void
spans_print_parm_stat_ind(objp)
spans_parm_stat_ind *objp;
{
printf("%sspans_parm_stat_ind\n", spans_indent);
inc_indent();
printf("%sstind_sw_epoch %d\n", spans_indent,
objp->stind_sw_epoch);
spans_print_addr(&objp->stind_es_addr);
spans_print_addr(&objp->stind_sw_addr);
dec_indent();
}
static void
spans_print_parm_stat_rsp(objp)
spans_parm_stat_rsp *objp;
{
printf("%sspans_parm_stat_rsp\n", spans_indent);
inc_indent();
printf("%sstrsp_es_epoch %d\n", spans_indent,
objp->strsp_es_epoch);
spans_print_addr(&objp->strsp_es_addr);
dec_indent();
}
static void
spans_print_parm_open_req(objp)
spans_parm_open_req *objp;
{
printf("%sspans_parm_open_req\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->opreq_conn);
spans_print_aal(&objp->opreq_aal);
spans_print_resrc(&objp->opreq_desrsrc);
spans_print_resrc(&objp->opreq_minrsrc);
spans_print_vpvc_pref(&objp->opreq_vpvc);
dec_indent();
}
static void
spans_print_parm_open_ind(objp)
spans_parm_open_ind *objp;
{
printf("%sspans_parm_open_ind\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->opind_conn);
spans_print_aal(&objp->opind_aal);
spans_print_resrc(&objp->opind_desrsrc);
spans_print_resrc(&objp->opind_minrsrc);
spans_print_vpvc_pref(&objp->opind_vpvc);
dec_indent();
}
static void
spans_print_parm_open_rsp(objp)
spans_parm_open_rsp *objp;
{
printf("%sspans_parm_open_rsp\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->oprsp_conn);
spans_print_result(&objp->oprsp_result);
spans_print_resrc(&objp->oprsp_rsrc);
spans_print_vpvc(&objp->oprsp_vpvc);
dec_indent();
}
static void
spans_print_parm_open_cnf(objp)
spans_parm_open_cnf *objp;
{
printf("%sspans_parm_open_cnf\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->opcnf_conn);
spans_print_result(&objp->opcnf_result);
spans_print_resrc(&objp->opcnf_rsrc);
spans_print_vpvc(&objp->opcnf_vpvc);
dec_indent();
}
static void
spans_print_parm_close_req(objp)
spans_parm_close_req *objp;
{
printf("%sspans_parm_close_req\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->clreq_conn);
dec_indent();
}
static void
spans_print_parm_close_ind(objp)
spans_parm_close_ind *objp;
{
printf("%sspans_parm_close_ind\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->clind_conn);
dec_indent();
}
static void
spans_print_parm_close_rsp(objp)
spans_parm_close_rsp *objp;
{
printf("%sspans_parm_close_rsp\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->clrsp_conn);
spans_print_result(&objp->clrsp_result);
dec_indent();
}
static void
spans_print_parm_close_cnf(objp)
spans_parm_close_cnf *objp;
{
printf("%sspans_parm_close_cnf\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->clcnf_conn);
spans_print_result(&objp->clcnf_result);
dec_indent();
}
static void
spans_print_parm_rclose_req(objp)
spans_parm_rclose_req *objp;
{
printf("%sspans_parm_rclose_req\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->rcreq_conn);
dec_indent();
}
static void
spans_print_parm_rclose_ind(objp)
spans_parm_rclose_ind *objp;
{
printf("%sspans_parm_rclose_ind\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->rcind_conn);
dec_indent();
}
static void
spans_print_parm_rclose_rsp(objp)
spans_parm_rclose_rsp *objp;
{
printf("%sspans_parm_rclose_rsp\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->rcrsp_conn);
spans_print_result(&objp->rcrsp_result);
dec_indent();
}
static void
spans_print_parm_rclose_cnf(objp)
spans_parm_rclose_cnf *objp;
{
printf("%sspans_parm_rclose_cnf\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->rccnf_conn);
spans_print_result(&objp->rccnf_result);
dec_indent();
}
static void
spans_print_parm_multi_req(objp)
spans_parm_multi_req *objp;
{
printf("%sspans_parm_multi_req\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->mureq_conn);
spans_print_aal(&objp->mureq_aal);
spans_print_resrc(&objp->mureq_desrsrc);
spans_print_resrc(&objp->mureq_minrsrc);
spans_print_vpvc(&objp->mureq_vpvc);
dec_indent();
}
static void
spans_print_parm_multi_ind(objp)
spans_parm_multi_ind *objp;
{
printf("%sspans_parm_multi_ind\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->muind_conn);
spans_print_aal(&objp->muind_aal);
spans_print_resrc(&objp->muind_desrsrc);
spans_print_resrc(&objp->muind_minrsrc);
spans_print_vpvc(&objp->muind_vpvc);
dec_indent();
}
static void
spans_print_parm_multi_rsp(objp)
spans_parm_multi_rsp *objp;
{
printf("%sspans_parm_multi_rsp\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->mursp_conn);
spans_print_result(&objp->mursp_result);
spans_print_resrc(&objp->mursp_rsrc);
spans_print_vpvc(&objp->mursp_vpvc);
dec_indent();
}
static void
spans_print_parm_multi_cnf(objp)
spans_parm_multi_cnf *objp;
{
printf("%sspans_parm_multi_cnf\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->mucnf_conn);
spans_print_result(&objp->mucnf_result);
spans_print_resrc(&objp->mucnf_rsrc);
spans_print_vpvc(&objp->mucnf_vpvc);
dec_indent();
}
static void
spans_print_parm_add_req(objp)
spans_parm_add_req *objp;
{
printf("%sspans_parm_add_req\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->adreq_desconn);
spans_print_atm_conn(&objp->adreq_xstconn);
dec_indent();
}
static void
spans_print_parm_add_ind(objp)
spans_parm_add_ind *objp;
{
printf("%sspans_parm_add_ind\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->adind_desconn);
spans_print_atm_conn(&objp->adind_xstconn);
dec_indent();
}
static void
spans_print_parm_add_rsp(objp)
spans_parm_add_rsp *objp;
{
printf("%sspans_parm_add_rsp\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->adrsp_conn);
spans_print_result(&objp->adrsp_result);
spans_print_resrc(&objp->adrsp_rsrc);
dec_indent();
}
static void
spans_print_parm_add_cnf(objp)
spans_parm_add_cnf *objp;
{
printf("%sspans_parm_add_cnf\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->adcnf_conn);
spans_print_result(&objp->adcnf_result);
spans_print_resrc(&objp->adcnf_rsrc);
dec_indent();
}
static void
spans_print_parm_join_req(objp)
spans_parm_join_req *objp;
{
printf("%sspans_parm_join_req\n", spans_indent);
inc_indent();
spans_print_addr(&objp->jnreq_addr);
dec_indent();
}
static void
spans_print_parm_join_cnf(objp)
spans_parm_join_cnf *objp;
{
printf("%sspans_print_parm_join_cnf\n", spans_indent);
inc_indent();
spans_print_addr(&objp->jncnf_addr);
spans_print_result(&objp->jncnf_result);
dec_indent();
}
static void
spans_print_parm_leave_req(objp)
spans_parm_leave_req *objp;
{
printf("%sspans_print_parm_leave_req\n", spans_indent);
inc_indent();
spans_print_addr(&objp->lvreq_addr);
dec_indent();
}
static void
spans_print_parm_leave_cnf(objp)
spans_parm_leave_cnf *objp;
{
printf("%sspans_parm_leave_cnf\n", spans_indent);
inc_indent();
spans_print_addr(&objp->lvcnf_addr);
spans_print_result(&objp->lvcnf_result);
dec_indent();
}
static void
spans_print_parm_vcir_ind(objp)
spans_parm_vcir_ind *objp;
{
printf("%sspans_parm_vcir_ind\n", spans_indent);
inc_indent();
printf("%svrind_min %d\n", spans_indent, objp->vrind_min);
printf("%svrind_max %d\n", spans_indent, objp->vrind_max);
dec_indent();
}
static void
spans_print_parm_query_req(objp)
spans_parm_query_req *objp;
{
char query_type_str[80];
printf("%sspans_parm_query_req\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->qyreq_conn);
spans_query_type_str(&objp->qyreq_type,
query_type_str, sizeof(query_type_str));
printf("%sqyreq_type %s\n", spans_indent, query_type_str);
dec_indent();
}
static void
spans_print_parm_query_rsp(objp)
spans_parm_query_rsp *objp;
{
char query_type_str[80], state_type_str[80];
printf("%sspans_parm_query_rsp\n", spans_indent);
inc_indent();
spans_print_atm_conn(&objp->qyrsp_conn);
spans_query_type_str(&objp->qyrsp_type,
query_type_str, sizeof(query_type_str));
printf("%sqyrsp_type %s\n", spans_indent, query_type_str);
spans_state_str(&objp->qyrsp_state,
state_type_str, sizeof(state_type_str));
printf("%sqyrsp_state %s\n", spans_indent, state_type_str);
printf("%sqyrsp_data 0x%x\n", spans_indent,
objp->qyrsp_data);
dec_indent();
}
static void
spans_print_msgbody(objp)
spans_msgbody *objp;
{
printf("%sspans_msgbody\n", spans_indent);
inc_indent();
spans_print_msgtype(&objp->mb_type);
switch (objp->mb_type) {
case SPANS_STAT_REQ:
spans_print_parm_stat_req(&objp->spans_msgbody_u.mb_stat_req);
break;
case SPANS_STAT_IND:
spans_print_parm_stat_ind(&objp->spans_msgbody_u.mb_stat_ind);
break;
case SPANS_STAT_RSP:
spans_print_parm_stat_rsp(&objp->spans_msgbody_u.mb_stat_rsp);
break;
case SPANS_OPEN_REQ:
spans_print_parm_open_req(&objp->spans_msgbody_u.mb_open_req);
break;
case SPANS_OPEN_IND:
spans_print_parm_open_ind(&objp->spans_msgbody_u.mb_open_ind);
break;
case SPANS_OPEN_RSP:
spans_print_parm_open_rsp(&objp->spans_msgbody_u.mb_open_rsp);
break;
case SPANS_OPEN_CNF:
spans_print_parm_open_cnf(&objp->spans_msgbody_u.mb_open_cnf);
break;
case SPANS_CLOSE_REQ:
spans_print_parm_close_req(&objp->spans_msgbody_u.mb_close_req);
break;
case SPANS_CLOSE_IND:
spans_print_parm_close_ind(&objp->spans_msgbody_u.mb_close_ind);
break;
case SPANS_CLOSE_RSP:
spans_print_parm_close_rsp(&objp->spans_msgbody_u.mb_close_rsp);
break;
case SPANS_CLOSE_CNF:
spans_print_parm_close_cnf(&objp->spans_msgbody_u.mb_close_cnf);
break;
case SPANS_RCLOSE_REQ:
spans_print_parm_rclose_req(&objp->spans_msgbody_u.mb_rclose_req);
break;
case SPANS_RCLOSE_IND:
spans_print_parm_rclose_ind(&objp->spans_msgbody_u.mb_rclose_ind);
break;
case SPANS_RCLOSE_RSP:
spans_print_parm_rclose_rsp(&objp->spans_msgbody_u.mb_rclose_rsp);
break;
case SPANS_RCLOSE_CNF:
spans_print_parm_rclose_cnf(&objp->spans_msgbody_u.mb_rclose_cnf);
break;
case SPANS_MULTI_REQ:
spans_print_parm_multi_req(&objp->spans_msgbody_u.mb_multi_req);
break;
case SPANS_MULTI_IND:
spans_print_parm_multi_ind(&objp->spans_msgbody_u.mb_multi_ind);
break;
case SPANS_MULTI_RSP:
spans_print_parm_multi_rsp(&objp->spans_msgbody_u.mb_multi_rsp);
break;
case SPANS_MULTI_CNF:
spans_print_parm_multi_cnf(&objp->spans_msgbody_u.mb_multi_cnf);
break;
case SPANS_ADD_REQ:
spans_print_parm_add_req(&objp->spans_msgbody_u.mb_add_req);
break;
case SPANS_ADD_IND:
spans_print_parm_add_ind(&objp->spans_msgbody_u.mb_add_ind);
break;
case SPANS_ADD_RSP:
spans_print_parm_add_rsp(&objp->spans_msgbody_u.mb_add_rsp);
break;
case SPANS_ADD_CNF:
spans_print_parm_add_cnf(&objp->spans_msgbody_u.mb_add_cnf);
break;
case SPANS_JOIN_REQ:
spans_print_parm_join_req(&objp->spans_msgbody_u.mb_join_req);
break;
case SPANS_JOIN_CNF:
spans_print_parm_join_cnf(&objp->spans_msgbody_u.mb_join_cnf);
break;
case SPANS_LEAVE_REQ:
spans_print_parm_leave_req(&objp->spans_msgbody_u.mb_leave_req);
break;
case SPANS_LEAVE_CNF:
spans_print_parm_leave_cnf(&objp->spans_msgbody_u.mb_leave_cnf);
break;
case SPANS_VCIR_IND:
spans_print_parm_vcir_ind(&objp->spans_msgbody_u.mb_vcir_ind);
break;
case SPANS_QUERY_REQ:
spans_print_parm_query_req(&objp->spans_msgbody_u.mb_query_req);
break;
case SPANS_QUERY_RSP:
spans_print_parm_query_rsp(&objp->spans_msgbody_u.mb_query_rsp);
break;
}
dec_indent();
}
void
spans_print_msg(objp)
spans_msg *objp;
{
spans_indent = INIT_INDENT;
printf("%sspans_msg\n", spans_indent);
inc_indent();
spans_print_version(&objp->sm_vers);
spans_print_msgbody(&objp->sm_body);
dec_indent();
}
#else /* ifdef LONGPRINT */
static void
spans_print_msgbody(objp)
spans_msgbody *objp;
{
char daddr[80], msgtype_str[80], result_str[80], saddr[80];
spans_parm_stat_req *streq_p;
spans_parm_stat_ind *stind_p;
spans_parm_stat_rsp *strsp_p;
spans_parm_open_req *opreq_p;
spans_parm_open_ind *opind_p;
spans_parm_open_rsp *oprsp_p;
spans_parm_open_cnf *opcnf_p;
spans_parm_close_req *clreq_p;
spans_parm_close_ind *clind_p;
spans_parm_close_rsp *clrsp_p;
spans_parm_close_cnf *clcnf_p;
spans_parm_rclose_req *rcreq_p;
spans_parm_rclose_ind *rcind_p;
spans_parm_rclose_rsp *rcrsp_p;
spans_parm_rclose_cnf *rccnf_p;
spans_msgtype_str(&objp->mb_type, msgtype_str, sizeof(msgtype_str));
printf("%s: ", msgtype_str);
switch (objp->mb_type) {
case SPANS_STAT_REQ:
streq_p = &objp->spans_msgbody_u.mb_stat_req;
printf("es_epoch=0x%lx", streq_p->streq_es_epoch);
break;
case SPANS_STAT_IND:
stind_p = &objp->spans_msgbody_u.mb_stat_ind;
strncpy(daddr, spans_addr_print(&stind_p->stind_es_addr),
sizeof(daddr));
strncpy(saddr, spans_addr_print(&stind_p->stind_sw_addr),
sizeof(saddr));
printf("sw_epoch=0x%lx, es_addr=%s, sw_addr=0x%s",
stind_p->stind_sw_epoch,
daddr, saddr);
break;
case SPANS_STAT_RSP:
strsp_p = &objp->spans_msgbody_u.mb_stat_rsp;
strncpy(daddr, spans_addr_print(&strsp_p->strsp_es_addr),
sizeof(daddr));
printf("es_epoch=0x%lx, es_addr=%s",
strsp_p->strsp_es_epoch, daddr);
break;
case SPANS_OPEN_REQ:
opreq_p = &objp->spans_msgbody_u.mb_open_req;
strncpy(daddr, spans_addr_print(&opreq_p->opreq_conn.con_dst),
sizeof(daddr));
strncpy(saddr, spans_addr_print(&opreq_p->opreq_conn.con_src),
sizeof(saddr));
printf("daddr=%s, saddr=%s, dsap=%d, ssap=%d, aal=%d",
daddr, saddr,
opreq_p->opreq_conn.con_dsap,
opreq_p->opreq_conn.con_ssap,
opreq_p->opreq_aal);
if (opreq_p->opreq_vpvc.vpf_valid)
printf(", vp.vc=%d.%d",
SPANS_EXTRACT_VPI(opreq_p->opreq_vpvc.vpf_vpvc),
SPANS_EXTRACT_VCI(opreq_p->opreq_vpvc.vpf_vpvc));
break;
case SPANS_OPEN_IND:
opind_p = &objp->spans_msgbody_u.mb_open_ind;
strncpy(daddr, spans_addr_print(&opind_p->opind_conn.con_dst),
sizeof(daddr));
strncpy(saddr, spans_addr_print(&opind_p->opind_conn.con_src),
sizeof(saddr));
printf("daddr=%s, saddr=%s, dsap=%d, ssap=%d, aal=%d",
daddr, saddr,
opind_p->opind_conn.con_dsap,
opind_p->opind_conn.con_ssap,
opind_p->opind_aal);
if (opind_p->opind_vpvc.vpf_valid)
printf(", vp.vc=%d.%d",
SPANS_EXTRACT_VPI(opind_p->opind_vpvc.vpf_vpvc),
SPANS_EXTRACT_VCI(opind_p->opind_vpvc.vpf_vpvc));
break;
case SPANS_OPEN_RSP:
oprsp_p = &objp->spans_msgbody_u.mb_open_rsp;
strncpy(daddr, spans_addr_print(&oprsp_p->oprsp_conn.con_dst),
sizeof(daddr));
strncpy(saddr, spans_addr_print(&oprsp_p->oprsp_conn.con_src),
sizeof(saddr));
spans_result_str(&oprsp_p->oprsp_result, result_str,
sizeof(result_str));
printf("result=%s, daddr=%s, saddr=%s, dsap=%d, ssap=%d, vp.vc=%d.%d",
result_str, daddr, saddr,
oprsp_p->oprsp_conn.con_dsap,
oprsp_p->oprsp_conn.con_ssap,
SPANS_EXTRACT_VPI(oprsp_p->oprsp_vpvc),
SPANS_EXTRACT_VCI(oprsp_p->oprsp_vpvc));
break;
case SPANS_OPEN_CNF:
opcnf_p = &objp->spans_msgbody_u.mb_open_cnf;
strncpy(daddr, spans_addr_print(&opcnf_p->opcnf_conn.con_dst),
sizeof(daddr));
strncpy(saddr, spans_addr_print(&opcnf_p->opcnf_conn.con_src),
sizeof(saddr));
spans_result_str(&opcnf_p->opcnf_result, result_str,
sizeof(result_str));
printf("result=%s, daddr=%s, saddr=%s, dsap=%d, ssap=%d, vp.vc=%d.%d",
result_str, daddr, saddr,
opcnf_p->opcnf_conn.con_dsap,
opcnf_p->opcnf_conn.con_ssap,
SPANS_EXTRACT_VPI(opcnf_p->opcnf_vpvc),
SPANS_EXTRACT_VCI(opcnf_p->opcnf_vpvc));
break;
case SPANS_CLOSE_REQ:
clreq_p = &objp->spans_msgbody_u.mb_close_req;
strncpy(daddr, spans_addr_print(&clreq_p->clreq_conn.con_dst),
sizeof(daddr));
strncpy(saddr, spans_addr_print(&clreq_p->clreq_conn.con_src),
sizeof(saddr));
printf("daddr=%s, saddr=%s, dsap=%d, ssap=%d",
daddr, saddr,
clreq_p->clreq_conn.con_dsap,
clreq_p->clreq_conn.con_ssap);
break;
case SPANS_CLOSE_IND:
clind_p = &objp->spans_msgbody_u.mb_close_ind;
strncpy(daddr, spans_addr_print(&clind_p->clind_conn.con_dst),
sizeof(daddr));
strncpy(saddr, spans_addr_print(&clind_p->clind_conn.con_src),
sizeof(saddr));
printf("daddr=%s, saddr=%s, dsap=%d, ssap=%d",
daddr, saddr,
clind_p->clind_conn.con_dsap,
clind_p->clind_conn.con_ssap);
break;
case SPANS_CLOSE_RSP:
clrsp_p = &objp->spans_msgbody_u.mb_close_rsp;
strncpy(daddr, spans_addr_print(&clrsp_p->clrsp_conn.con_dst),
sizeof(daddr));
strncpy(saddr, spans_addr_print(&clrsp_p->clrsp_conn.con_src),
sizeof(saddr));
spans_result_str(&clrsp_p->clrsp_result, result_str,
sizeof(result_str));
printf("result=%s, daddr=%s, saddr=%s, dsap=%d, ssap=%d",
result_str, daddr, saddr,
clrsp_p->clrsp_conn.con_dsap,
clrsp_p->clrsp_conn.con_ssap);
break;
case SPANS_CLOSE_CNF:
clcnf_p = &objp->spans_msgbody_u.mb_close_cnf;
strncpy(daddr, spans_addr_print(&clcnf_p->clcnf_conn.con_dst),
sizeof(daddr));
strncpy(saddr, spans_addr_print(&clcnf_p->clcnf_conn.con_src),
sizeof(saddr));
spans_result_str(&clcnf_p->clcnf_result, result_str,
sizeof(result_str));
printf("result=%s, daddr=%s, saddr=%s, dsap=%d, ssap=%d",
result_str, daddr, saddr,
clcnf_p->clcnf_conn.con_dsap,
clcnf_p->clcnf_conn.con_ssap);
break;
case SPANS_RCLOSE_REQ:
rcreq_p = &objp->spans_msgbody_u.mb_rclose_req;
strncpy(daddr, spans_addr_print(&rcreq_p->rcreq_conn.con_dst),
sizeof(daddr));
strncpy(saddr, spans_addr_print(&rcreq_p->rcreq_conn.con_src),
sizeof(saddr));
printf("daddr=%s, saddr=%s, dsap=%d, ssap=%d",
daddr, saddr,
rcreq_p->rcreq_conn.con_dsap,
rcreq_p->rcreq_conn.con_ssap);
break;
case SPANS_RCLOSE_IND:
rcind_p = &objp->spans_msgbody_u.mb_rclose_ind;
strncpy(daddr, spans_addr_print(&rcind_p->rcind_conn.con_dst),
sizeof(daddr));
strncpy(saddr, spans_addr_print(&rcind_p->rcind_conn.con_src),
sizeof(saddr));
printf("daddr=%s, saddr=%s, dsap=%d, ssap=%d",
daddr, saddr,
rcind_p->rcind_conn.con_dsap,
rcind_p->rcind_conn.con_ssap);
break;
case SPANS_RCLOSE_RSP:
rcrsp_p = &objp->spans_msgbody_u.mb_rclose_rsp;
strncpy(daddr, spans_addr_print(&rcrsp_p->rcrsp_conn.con_dst),
sizeof(daddr));
strncpy(saddr, spans_addr_print(&rcrsp_p->rcrsp_conn.con_src),
sizeof(saddr));
spans_result_str(&rcrsp_p->rcrsp_result, result_str,
sizeof(result_str));
printf("result=%s, daddr=%s, saddr=%s, dsap=%d, ssap=%d",
result_str, daddr, saddr,
rcrsp_p->rcrsp_conn.con_dsap,
rcrsp_p->rcrsp_conn.con_ssap);
break;
case SPANS_RCLOSE_CNF:
rccnf_p = &objp->spans_msgbody_u.mb_rclose_cnf;
strncpy(daddr, spans_addr_print(&rccnf_p->rccnf_conn.con_dst),
sizeof(daddr));
strncpy(saddr, spans_addr_print(&rccnf_p->rccnf_conn.con_src),
sizeof(saddr));
spans_result_str(&rccnf_p->rccnf_result, result_str,
sizeof(result_str));
printf("result=%s, daddr=%s, saddr=%s, dsap=%d, ssap=%d",
result_str, daddr, saddr,
rccnf_p->rccnf_conn.con_dsap,
rccnf_p->rccnf_conn.con_ssap);
break;
}
printf("\n");
}
void
spans_print_msg(objp)
spans_msg *objp;
{
#ifdef LONGPRINT
spans_indent = INIT_INDENT;
#endif
spans_print_msgbody(&objp->sm_body);
}
#endif /* ifdef LONGPRINT */