f-stack/freebsd/contrib/ngatm/netnatm/msg/unistruct.h

1372 lines
36 KiB
C

/*
* Copyright (c) 1996-2003
* Fraunhofer Institute for Open Communication Systems (FhG Fokus).
* All rights reserved.
*
* Author: Hartmut Brandt <harti@freebsd.org>
*
* 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.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR 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 AUTHOR 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.
*
* $Begemot: libunimsg/netnatm/msg/unistruct.h,v 1.7 2004/07/16 18:42:22 brandt Exp $
*
* This file defines all structures that are used by
* API users.
*/
#ifndef _NETNATM_MSG_UNISTRUCT_H_
#define _NETNATM_MSG_UNISTRUCT_H_
#include <netnatm/msg/uni_config.h>
/*
* define IE and MSG header
*/
#include <netnatm/msg/uni_hdr.h>
/*
* define all IE's
*/
/*************************************************************************
*
* Free FORM IE
*/
struct uni_ie_unrec {
struct uni_iehdr h;
uint8_t id; /* ID of this IE */
u_int len; /* data length */
u_char data[128]; /* arbitrary maximum length */
};
/*************************************************************************
*
* ATM adaptation layer parameters information element
*/
enum {
UNI_AAL_SUB_ID = 0x85,
UNI_AAL_CBR_ID = 0x86,
UNI_AAL_MULT_ID = 0x87,
UNI_AAL_SCREC_ID = 0x88,
UNI_AAL_ECM_ID = 0x89,
UNI_AAL_BSIZE_ID = 0x8a,
UNI_AAL_PART_ID = 0x8b,
UNI_AAL_FWDCPCS_ID = 0x8c,
UNI_AAL_BWDCPCS_ID = 0x81,
UNI_AAL_MID_ID = 0x82,
UNI_AAL_SSCS_ID = 0x84,
};
enum uni_aal {
UNI_AAL_0 = 0x00, /* voice */
UNI_AAL_1 = 0x01,
UNI_AAL_2 = 0x02,
UNI_AAL_4 = 0x03, /* same as AAL 3 */
UNI_AAL_5 = 0x05,
UNI_AAL_USER = 0x10,
};
enum uni_aal1_subtype {
UNI_AAL1_SUB_NULL = 0x00,
UNI_AAL1_SUB_VOICE = 0x01,
UNI_AAL1_SUB_CIRCUIT = 0x02,
UNI_AAL1_SUB_HQAUDIO = 0x04,
UNI_AAL1_SUB_VIDEO = 0x05,
};
enum uni_aal1_cbr {
UNI_AAL1_CBR_64 = 0x01,
UNI_AAL1_CBR_1544 = 0x04,
UNI_AAL1_CBR_6312 = 0x05,
UNI_AAL1_CBR_32064 = 0x06,
UNI_AAL1_CBR_44736 = 0x07,
UNI_AAL1_CBR_97728 = 0x08,
UNI_AAL1_CBR_2048 = 0x10,
UNI_AAL1_CBR_8448 = 0x11,
UNI_AAL1_CBR_34368 = 0x12,
UNI_AAL1_CBR_139264 = 0x13,
UNI_AAL1_CBR_N64 = 0x40,
UNI_AAL1_CBR_N8 = 0x41,
};
enum uni_aal1_screc {
UNI_AAL1_SCREC_NULL = 0x00, /* synchr. circuit transport */
UNI_AAL1_SCREC_SRTS = 0x01, /* synchr. residual timestamp */
UNI_AAL1_SCREC_ACLK = 0x02, /* adaptive clock */
};
enum uni_aal1_ecm {
UNI_AAL1_ECM_NULL = 0x00, /* no error correction */
UNI_AAL1_ECM_LOSS = 0x01, /* for loss sensitive signals */
UNI_AAL1_ECM_DELAY = 0x02, /* for delay sensitive signals */
};
enum uni_aal_sscs {
UNI_AAL_SSCS_NULL = 0x00, /* Null */
UNI_AAL_SSCS_SSCOPA = 0x01, /* assured SSCOP */
UNI_AAL_SSCS_SSCOPU = 0x02, /* unassured SSCOP */
UNI_AAL_SSCS_FRAME = 0x04, /* frame relay */
};
struct uni_ie_aal {
struct uni_iehdr h;
enum uni_aal type; /* aal type */
union {
#define UNI_AAL1_MULT_P 0x01
#define UNI_AAL1_SCREC_P 0x02
#define UNI_AAL1_ECM_P 0x04
#define UNI_AAL1_BSIZE_P 0x08
#define UNI_AAL1_PART_P 0x10
struct {
enum uni_aal1_subtype subtype; /* AAL1 subtype */
enum uni_aal1_cbr cbr_rate; /* AAL1 CBR rate */
u_int mult; /* AAL1 CBR mutliplier */
enum uni_aal1_screc screc; /* AAL1 source clock recovery */
enum uni_aal1_ecm ecm; /* AAL1 error correction */
u_int bsize; /* AAL1 SDT blocksize */
u_int part; /* AAL1 partial cell fill */
} aal1;
#define UNI_AAL4_CPCS_P 0x01
#define UNI_AAL4_MID_P 0x02
#define UNI_AAL4_SSCS_P 0x04
struct {
u_int fwd_cpcs; /* max fwd cpcs blocksize */
u_int bwd_cpcs; /* max bkw cpcs blocksize */
u_int mid_low; /* MID low range */
u_int mid_high; /* MID high range */
enum uni_aal_sscs sscs; /* sscs type */
} aal4;
#define UNI_AAL5_CPCS_P 0x01
#define UNI_AAL5_SSCS_P 0x02
struct {
u_int fwd_cpcs; /* max fwd cpcs blocksize */
u_int bwd_cpcs; /* max bkw cpcs blocksize */
enum uni_aal_sscs sscs; /* sscs type */
} aal5;
struct {
u_int len; /* number of bytes */
u_char user[4]; /* user data */
} aalu;
} u;
};
/*************************************************************************
*
* Called party number information element
* Called party subaddress information element
* Calling party number information element
* Calling party subaddress information element
* Q.2951/UNI4.0 Connected number information element
* Q.2951/UNI4.0 Connected subaddress information element
*/
enum uni_addr_type {
UNI_ADDR_UNKNOWN = 0x0,
UNI_ADDR_INTERNATIONAL = 0x1,
UNI_ADDR_NATIONAL = 0x2, /* not sup */
UNI_ADDR_NETWORK = 0x3, /* not sup */
UNI_ADDR_SUBSCR = 0x4, /* not sup */
UNI_ADDR_ABBR = 0x6, /* not sup */
};
enum uni_addr_plan {
/* UNI_ADDR_UNKNOWN = 0x0, */ /* not sup */
UNI_ADDR_E164 = 0x1,
UNI_ADDR_ATME = 0x2,
UNI_ADDR_DATA = 0x3, /* not sup */
UNI_ADDR_PRIVATE = 0x9, /* not sup */
};
enum uni_subaddr_type {
UNI_SUBADDR_NSAP = 0x0,
UNI_SUBADDR_ATME = 0x1,
UNI_SUBADDR_USER = 0x2, /* not sup */
};
enum uni_addr_pres {
UNI_ADDR_PRES = 0x0,
UNI_ADDR_RESTRICT = 0x1,
UNI_ADDR_NONUMBER = 0x2,
};
enum uni_addr_screen {
UNI_ADDR_SCREEN_NOT = 0x0,
UNI_ADDR_SCREEN_PASSED = 0x1,
UNI_ADDR_SCREEN_FAILED = 0x2,
UNI_ADDR_SCREEN_NET = 0x3,
};
/* don't use bitfields to get a defined structure layout */
struct uni_addr {
uint8_t type;
uint8_t plan;
uint8_t len;
u_char addr[UNI_ADDR_MAXLEN];
};
struct uni_subaddr {
enum uni_subaddr_type type;
u_int len;
u_char addr[UNI_SUBADDR_MAXLEN];
};
struct uni_ie_called {
struct uni_iehdr h;
struct uni_addr addr;
};
struct uni_ie_calledsub {
struct uni_iehdr h;
struct uni_subaddr addr;
};
struct uni_ie_calling {
struct uni_iehdr h;
#define UNI_CALLING_SCREEN_P 0x0001
struct uni_addr addr;
enum uni_addr_pres pres;
enum uni_addr_screen screen;
};
struct uni_ie_callingsub {
struct uni_iehdr h;
struct uni_subaddr addr;
};
struct uni_ie_conned {
struct uni_iehdr h;
#define UNI_CONNED_SCREEN_P 0x0001
struct uni_addr addr;
enum uni_addr_pres pres;
enum uni_addr_screen screen;
};
struct uni_ie_connedsub {
struct uni_iehdr h;
struct uni_subaddr addr;
};
/*************************************************************************
*
* Broadband bearer capability descriptor
* On reception of an old bearer descriptor, it is automatically
* converted to a new, legal one.
*/
enum uni_bearer_class {
UNI_BEARER_A = 0x01,
UNI_BEARER_C = 0x03,
UNI_BEARER_X = 0x10,
UNI_BEARER_TVP = 0x30,
};
enum uni_bearer_atc {
UNI_BEARER_ATC_CBR = 0x05,
UNI_BEARER_ATC_CBR1 = 0x07,
UNI_BEARER_ATC_VBR = 0x09,
UNI_BEARER_ATC_VBR1 = 0x13,
UNI_BEARER_ATC_NVBR = 0x0a,
UNI_BEARER_ATC_NVBR1 = 0x0b,
UNI_BEARER_ATC_ABR = 0x0c,
UNI_BEARER_ATCX_0 = 0x00,
UNI_BEARER_ATCX_1 = 0x01,
UNI_BEARER_ATCX_2 = 0x02,
UNI_BEARER_ATCX_4 = 0x04,
UNI_BEARER_ATCX_6 = 0x06,
UNI_BEARER_ATCX_8 = 0x08,
};
enum uni_bearer_clip {
UNI_BEARER_NOCLIP = 0x0,
UNI_BEARER_CLIP = 0x1,
};
enum uni_bearer_cfg {
UNI_BEARER_P2P = 0x0,
UNI_BEARER_MP = 0x1,
};
struct uni_ie_bearer {
struct uni_iehdr h;
#define UNI_BEARER_ATC_P 0x02
enum uni_bearer_class bclass; /* bearer class */
enum uni_bearer_atc atc; /* ATM transfer capability */
enum uni_bearer_clip clip; /* suspectibility to clipping */
enum uni_bearer_cfg cfg; /* u-plane configuration */
};
/*************************************************************************
*
* Broadband higher layer information element
*/
enum uni_bhli {
UNI_BHLI_ISO = 0x00, /* IDO defined */
UNI_BHLI_USER = 0x01, /* user specific */
UNI_BHLI_VENDOR = 0x03, /* vendor specific */
};
struct uni_ie_bhli {
struct uni_iehdr h;
enum uni_bhli type;
u_char info[8];
u_int len;
};
/*************************************************************************
*
* Boradband lower layer information element
*/
enum {
UNI_BLLI_L1_ID = 0x1,
UNI_BLLI_L2_ID = 0x2,
UNI_BLLI_L3_ID = 0x3,
};
enum uni_blli_l2 {
UNI_BLLI_L2_BASIC = 0x01,
UNI_BLLI_L2_Q921 = 0x02,
UNI_BLLI_L2_X25LL = 0x06,
UNI_BLLI_L2_X25ML = 0x07,
UNI_BLLI_L2_LABP = 0x08,
UNI_BLLI_L2_HDLC_ARM = 0x09,
UNI_BLLI_L2_HDLC_NRM = 0x0a,
UNI_BLLI_L2_HDLC_ABM = 0x0b,
UNI_BLLI_L2_LAN = 0x0c,
UNI_BLLI_L2_X75 = 0x0d,
UNI_BLLI_L2_Q922 = 0x0e,
UNI_BLLI_L2_USER = 0x10,
UNI_BLLI_L2_ISO7776 = 0x11,
};
enum uni_blli_l2_mode {
UNI_BLLI_L2NORM = 0x1,
UNI_BLLI_L2EXT = 0x2,
};
enum uni_blli_l3 {
UNI_BLLI_L3_X25 = 0x06,
UNI_BLLI_L3_ISO8208 = 0x07,
UNI_BLLI_L3_X223 = 0x08,
UNI_BLLI_L3_CLMP = 0x09,
UNI_BLLI_L3_T70 = 0x0a,
UNI_BLLI_L3_TR9577 = 0x0b,
UNI_BLLI_L3_H310 = 0x0c,
UNI_BLLI_L3_H321 = 0x0d,
UNI_BLLI_L3_USER = 0x10,
};
enum uni_blli_l3_mode {
UNI_BLLI_L3NSEQ = 0x1, /* normal sequence numbering */
UNI_BLLI_L3ESEQ = 0x2, /* extended sequence numbering */
};
enum uni_blli_l3_psiz {
UNI_BLLI_L3_16 = 0x4, /* 16 byte packets */
UNI_BLLI_L3_32 = 0x5, /* 32 byte packets */
UNI_BLLI_L3_64 = 0x6, /* 64 byte packets */
UNI_BLLI_L3_128 = 0x7, /* 128 byte packets */
UNI_BLLI_L3_256 = 0x8, /* 256 byte packets */
UNI_BLLI_L3_512 = 0x9, /* 512 byte packets */
UNI_BLLI_L3_1024 = 0xa, /* 1024 byte packets */
UNI_BLLI_L3_2048 = 0xb, /* 2048 byte packets */
UNI_BLLI_L3_4096 = 0xc, /* 4096 byte packets */
};
enum uni_blli_l3_ttype {
UNI_BLLI_L3_TTYPE_RECV = 0x1, /* receive only */
UNI_BLLI_L3_TTYPE_SEND = 0x2, /* send only */
UNI_BLLI_L3_TTYPE_BOTH = 0x3, /* both */
};
enum uni_blli_l3_mux {
UNI_BLLI_L3_MUX_NOMUX = 0, /* no multiplexing */
UNI_BLLI_L3_MUX_TS = 1, /* transport stream */
UNI_BLLI_L3_MUX_TSFEC = 2, /* transport stream with FEC */
UNI_BLLI_L3_MUX_PS = 3, /* program stream */
UNI_BLLI_L3_MUX_PSFEC = 4, /* program stream with FEC */
UNI_BLLI_L3_MUX_H221 = 5, /* H.221 */
};
enum uni_blli_l3_tcap {
UNI_BLLI_L3_TCAP_NOIND = 0, /* no indication */
UNI_BLLI_L3_TCAP_AAL1 = 1, /* only AAL1 */
UNI_BLLI_L3_TCAP_AAL5 = 2, /* only AAL5 */
UNI_BLLI_L3_TCAP_AAL15 = 3, /* AAL1 and AAL5 */
};
/* Value for l3_ipi: */
enum {
UNI_BLLI_L3_SNAP = 0x80, /* IEEE 802.1 SNAP */
};
struct uni_ie_blli {
struct uni_iehdr h;
#define UNI_BLLI_L1_P 0x0001
#define UNI_BLLI_L2_P 0x0002
#define UNI_BLLI_L2_Q933_P 0x0004
#define UNI_BLLI_L2_WSIZ_P 0x0008
#define UNI_BLLI_L2_USER_P 0x0010
#define UNI_BLLI_L3_P 0x0020
#define UNI_BLLI_L3_MODE_P 0x0040
#define UNI_BLLI_L3_PSIZ_P 0x0080
#define UNI_BLLI_L3_WSIZ_P 0x0100
#define UNI_BLLI_L3_USER_P 0x0200
#define UNI_BLLI_L3_IPI_P 0x0400
#define UNI_BLLI_L3_SNAP_P 0x0800
#define UNI_BLLI_L3_TTYPE_P 0x1000
#define UNI_BLLI_L3_MUX_P 0x2000
u_int l1:5; /* layer 1 info */
enum uni_blli_l2 l2; /* layer 2 info */
u_int l2_q933:2; /* layer 2 Q.933 use */
enum uni_blli_l2_mode l2_mode; /* layer 2 HDLC mode */
u_char l2_user; /* layer 2 user info */
u_char l2_wsiz; /* layer 2 window size */
enum uni_blli_l3 l3; /* layer 3 info */
enum uni_blli_l3_mode l3_mode; /* layer 3 mode */
enum uni_blli_l3_psiz l3_psiz; /* layer 3 default packet size */
u_char l3_wsiz; /* layer 3 window size */
u_char l3_user; /* layer 3 user info */
u_char l3_ipi; /* IPI byte */
u_int oui; /* OUI bytes */
u_int pid; /* PID bytes */
enum uni_blli_l3_ttype l3_ttype; /* terminal bytes */
enum uni_blli_l3_tcap l3_tcap; /* terminal capability */
enum uni_blli_l3_mux l3_fmux; /* forward muxing */
enum uni_blli_l3_mux l3_bmux; /* forward muxing */
};
/*************************************************************************
*
* Transit network selection IE
*/
struct uni_ie_tns {
struct uni_iehdr h;
u_char net[UNI_TNS_MAXLEN];
u_int len;
};
/*************************************************************************
*
* Call state information element
*/
enum uni_callstate {
UNI_CALLSTATE_U0 = 0x00,
UNI_CALLSTATE_N0 = 0x00,
UNI_CALLSTATE_NN0 = 0x00,
UNI_CALLSTATE_U1 = 0x01,
UNI_CALLSTATE_N1 = 0x01,
UNI_CALLSTATE_NN1 = 0x01,
UNI_CALLSTATE_U3 = 0x03,
UNI_CALLSTATE_N3 = 0x03,
UNI_CALLSTATE_NN3 = 0x03,
UNI_CALLSTATE_U4 = 0x04,
UNI_CALLSTATE_N4 = 0x04,
UNI_CALLSTATE_NN4 = 0x04,
UNI_CALLSTATE_U6 = 0x06,
UNI_CALLSTATE_N6 = 0x06,
UNI_CALLSTATE_NN6 = 0x06,
UNI_CALLSTATE_U7 = 0x07,
UNI_CALLSTATE_N7 = 0x07,
UNI_CALLSTATE_NN7 = 0x07,
UNI_CALLSTATE_U8 = 0x08,
UNI_CALLSTATE_N8 = 0x08,
UNI_CALLSTATE_U9 = 0x09,
UNI_CALLSTATE_N9 = 0x09,
UNI_CALLSTATE_NN9 = 0x09,
UNI_CALLSTATE_U10 = 0x0a,
UNI_CALLSTATE_N10 = 0x0a,
UNI_CALLSTATE_NN10 = 0x0a,
UNI_CALLSTATE_U11 = 0x0b,
UNI_CALLSTATE_N11 = 0x0b,
UNI_CALLSTATE_NN11 = 0x0b,
UNI_CALLSTATE_U12 = 0x0c,
UNI_CALLSTATE_N12 = 0x0c,
UNI_CALLSTATE_NN12 = 0x0c,
UNI_CALLSTATE_REST0 = 0x00,
UNI_CALLSTATE_REST1 = 0x3d,
UNI_CALLSTATE_REST2 = 0x3e,
UNI_CALLSTATE_U13 = 0x0d,
UNI_CALLSTATE_N13 = 0x0d,
UNI_CALLSTATE_U14 = 0x0e,
UNI_CALLSTATE_N14 = 0x0e,
};
struct uni_ie_callstate {
struct uni_iehdr h;
enum uni_callstate state;
};
/*************************************************************************
*
* Cause information element
*/
enum uni_cause_loc {
UNI_CAUSE_LOC_USER = 0x0,
UNI_CAUSE_LOC_PRIVLOC = 0x1,
UNI_CAUSE_LOC_PUBLOC = 0x2,
UNI_CAUSE_LOC_TRANSIT = 0x3,
UNI_CAUSE_LOC_PUBREM = 0x4,
UNI_CAUSE_LOC_PRIVREM = 0x5,
UNI_CAUSE_LOC_INTERNAT = 0x6,
UNI_CAUSE_LOC_BEYOND = 0x7,
};
#define UNI_DECLARE_CAUSE_VALUES \
D(UNALL_NUM, 0x01 /* 1*/, COND, Q.850, "Unallocated (unassigned) number") \
D(NOROUTE_NET, 0x02 /* 2*/, TNS, Q.850, "No route to specified transit network") \
D(NOROUTE, 0x03 /* 3*/, COND, Q.850, "No route to destination") \
D(SPTONE, 0x04 /* 4*/, NONE, Q.850, "Send special information tone") \
D(BADTRUNK, 0x05 /* 5*/, NONE, Q.850, "Misdialled trunk prefix") \
D(BADCHAN, 0x06 /* 6*/, NONE, Q.850, "Channel unacceptable") \
D(CALLAWARDED, 0x07 /* 7*/, NONE, Q.850, "Call awarded and being delivered in an established channel") \
D(PREEMPT, 0x08 /* 8*/, NONE, Q.850, "Preemption") \
D(PREEMPT_RES, 0x09 /* 9*/, NONE, Q.850, "Preemption - circuit reserved for reuse") \
D(CLEARING, 0x10 /* 16*/, COND, Q.850, "Normal call clearing") \
D(BUSY, 0x11 /* 17*/, CCBS, Q.850, "User busy") \
D(NO_RESPONSE, 0x12 /* 18*/, NONE, Q.850, "No user responding") \
D(NO_RESP_ALERT,0x13 /* 19*/, NONE, Q.850, "No answer from user (user alerted)") \
D(ABSENT, 0x14 /* 20*/, NONE, Q.850, "Subscriber absent") \
D(REJECTED, 0x15 /* 21*/, REJ, Q.850, "Call rejected") \
D(NUMCHG, 0x16 /* 22*/, NUMBER, Q.850, "Number changed") \
D(REDIR, 0x17 /* 23*/, NONE, Q.850, "Redirection to new destination") \
N(CLIR_REJECTED,0x17 /* 23*/, NONE, UNI4.0, "User rejects call with calling line identification restriction (CLIR)") \
D(EXCHG_ERR, 0x19 /* 25*/, NONE, Q.850, "Exchange routing error") \
D(NOSEL_CLEAR, 0x1a /* 26*/, NONE, Q.850, "Non-selected user clearing") \
D(DST_OOO, 0x1b /* 27*/, NONE, Q.850, "Destination out of order") \
D(INV_ADDR, 0x1c /* 28*/, NONE, Q.850, "Invalid number format (address incomplete)") \
D(FAC_REJ, 0x1d /* 29*/, FAC, Q.850, "Facility rejected") \
D(STATUS, 0x1e /* 30*/, NONE, Q.850, "Response to STATUS ENQUIRY") \
D(UNSPEC, 0x1f /* 31*/, NONE, Q.850, "Normal, unspecified") \
D(TMY_PARTY, 0x20 /* 32*/, NONE, Q.2971, "Too many pending add party requests") \
D(NOCHAN, 0x22 /* 34*/, CCBS, Q.850, "No circuit/channel available") \
N(SOFT_NAVL, 0x22 /* 34*/, NONE, PNNI1.0,"Requested called party soft PVPC or PVCC not available")\
D(VPCI_NAVL, 0x23 /* 35*/, NONE, Q.2610, "Requested VPCI/VCI not available") \
D(VPCI_FAIL, 0x24 /* 36*/, NONE, Q.2610, "VPCI/VPI assignment failure") \
D(CRATE_NAVL, 0x25 /* 37*/, CRATE, Q.2610, "User cell rate not available") \
D(NET_OOO, 0x26 /* 38*/, NONE, Q.850, "Network out of order") \
D(FRAME_OOS, 0x27 /* 39*/, NONE, Q.850, "Permanent frame mode connection out of service") \
D(FRAME_OP, 0x28 /* 40*/, NONE, Q.850, "Permanent frame mode connection operational") \
D(TEMP, 0x29 /* 41*/, NONE, Q.850, "Temporary failure") \
D(CONG, 0x2a /* 42*/, NONE, Q.850, "Switching equipment congestion") \
D(ACC_DISC, 0x2b /* 43*/, IE, Q.850, "Access information discarded") \
D(REQNOCHAN, 0x2c /* 44*/, NONE, Q.850, "Requested circuit/channel not available") \
D(NOVPCI, 0x2d /* 45*/, NONE, Q.2610, "No VPCI/VCI available") \
D(PREC_BLOCK, 0x2e /* 46*/, NONE, Q.850, "Precedence call blocked") \
D(RESRC_NAVL, 0x2f /* 47*/, NONE, Q.850, "Resource unavailable, unspecified") \
D(QOS_NAVL, 0x31 /* 49*/, COND, Q.850, "Quality of service not available") \
D(FAC_NOTSUB, 0x32 /* 50*/, FAC, Q.850, "Requested facility not subscribed") \
D(OUT_CUG, 0x35 /* 53*/, NONE, Q.850, "Outgoing calls barred within CUG") \
N(PGL_CHG, 0x35 /* 53*/, NONE, PNNI1.0,"Call cleared due to change in PGL") \
D(IN_CUG, 0x37 /* 55*/, NONE, Q.850, "Incoming call barred within CUG") \
D(BEARER_NAUTH, 0x39 /* 57*/, ATTR, Q.850, "Bearer capability not authorized") \
D(BEARER_NAVL, 0x3a /* 58*/, ATTR, Q.850, "Bearer capability not presently available") \
D(INCONS, 0x3e /* 62*/, NONE, Q.850, "Inconsistency in designated outgoing access information and subscriber class") \
D(OPT_NAVL, 0x3f /* 63*/, NONE, Q.850, "Service or option not available, unspecified") \
D(BEARER_NIMPL, 0x41 /* 65*/, ATTR, Q.850, "Bearer capability not implemented") \
D(CHANNEL_NIMPL,0x42 /* 66*/, CHANNEL, Q.850, "Channel type not implemented") \
D(FAC_NIMPL, 0x45 /* 69*/, FAC, Q.850, "Requested facility not implemented") \
D(RESTR_DIG, 0x46 /* 70*/, NONE, Q.850, "Only restricted digital information bearer capability is available") \
D(TRAFFIC_UNSUP,0x49 /* 73*/, NONE, Q.2971, "Unsupported combination of traffic parameters") \
N(AAL_UNSUP, 0x4c /* 78*/, NONE, UNI3.1, "AAL parameters cannot be supported") \
D(CREF_INV, 0x51 /* 81*/, NONE, Q.850, "Invalid call reference value") \
D(CHANNEL_NEX, 0x52 /* 82*/, CHANID, Q.850, "Identified channel does not exist") \
D(SUSPENDED, 0x53 /* 83*/, NONE, Q.850, "A suspended call exists, but this call identity does not") \
D(CID_INUSE, 0x54 /* 84*/, NONE, Q.850, "Call identity in use") \
D(NOTSUSP, 0x55 /* 85*/, NONE, Q.850, "No call suspended") \
D(CLEARED, 0x56 /* 86*/, CAUSE, Q.850, "Call having requested call identity has been cleared") \
D(NOT_MEMBER, 0x57 /* 87*/, NONE, Q.850, "User not member of CUG") \
D(INCOMP, 0x58 /* 88*/, PARAM, Q.850, "Incompatible destination") \
D(ENDP_INV, 0x59 /* 89*/, IE, UNI3.1, "Invalid endpoint reference") \
D(NEX_CUG, 0x5a /* 90*/, NONE, Q.850, "Non-existend CUG") \
D(TRANSIT_INV, 0x5b /* 91*/, NONE, Q.850, "Invalid transit network selection") \
D(AALNOTSUPP, 0x5d /* 93*/, NONE, Q.2610, "AAL parameters cannot be supported") \
D(INVMSG, 0x5f /* 95*/, NONE, Q.850, "Invalid message, unspecified") \
D(MANDAT, 0x60 /* 96*/, IE, Q.850, "Mandatory information element is missing") \
D(MTYPE_NIMPL, 0x61 /* 97*/, MTYPE, Q.850, "Message type non-existent or not implemented") \
D(MSG_NOTCOMP, 0x62 /* 98*/, MTYPE, Q.850, "Message not compatible with call state or message type non-existent or not implemented") \
D(IE_NIMPL, 0x63 /* 99*/, IE, Q.850, "Information element/parameter non-existent or not implemented") \
D(IE_INV, 0x64 /*100*/, IE, Q.850, "Invalid information element contents") \
D(MSG_INCOMP, 0x65 /*101*/, MTYPE, Q.850, "Message not compatible with call state") \
D(RECOVER, 0x66 /*102*/, TIMER, Q.850, "Recovery on timer expiry") \
D(PARAM_NEX, 0x67 /*103*/, PARAM, Q.850, "Parameter non-existent or not implemented, passed on") \
N(BAD_LENGTH, 0x68 /*104*/, NONE, UNI3.1, "Incorrect message length") \
D(PARAM_UNREC, 0x6e /*110*/, PARAM, Q.850, "Message with unrecognized parameter, discarded") \
D(PROTO, 0x6f /*111*/, NONE, Q.850, "Protocol error, unspecified") \
D(INTERWORKING, 0x7f /*127*/, NONE, Q.850, "Interworking, unspecified")
#define D(NAME,VAL,DIAG,STD,STR) UNI_CAUSE_##NAME = VAL,
#define N(NAME,VAL,DIAG,STD,STR) UNI_CAUSE_##NAME = VAL,
enum uni_cause {
UNI_DECLARE_CAUSE_VALUES
};
#undef D
#undef N
enum uni_cause_class {
UNI_CAUSE_CLASS_NORM = 0x0,
UNI_CAUSE_CLASS_NORM1 = 0x1,
UNI_CAUSE_CLASS_RES = 0x2,
UNI_CAUSE_CLASS_NAVL = 0x3,
UNI_CAUSE_CLASS_NIMPL = 0x4,
UNI_CAUSE_CLASS_INV = 0x5,
UNI_CAUSE_CLASS_PROTO = 0x6,
UNI_CAUSE_CLASS_INTER = 0x7,
};
enum uni_cause_pu {
UNI_CAUSE_PU_PROVIDER = 0,
UNI_CAUSE_PU_USER = 1,
};
enum uni_cause_na {
UNI_CAUSE_NA_NORMAL = 0,
UNI_CAUSE_NA_ABNORMAL = 1,
};
enum uni_cause_cond {
UNI_CAUSE_COND_UNKNOWN = 0,
UNI_CAUSE_COND_PERM = 1,
UNI_CAUSE_COND_TRANS = 2,
};
enum uni_cause_reason {
UNI_CAUSE_REASON_USER = 0x00,
UNI_CAUSE_REASON_IEMISS = 0x01,
UNI_CAUSE_REASON_IESUFF = 0x02,
};
enum uni_diag {
UNI_DIAG_NONE, /* no diagnostics */
UNI_DIAG_COND, /* Condition */
UNI_DIAG_TNS, /* Transit Network Selector */
UNI_DIAG_REJ, /* Call Rejected */
UNI_DIAG_NUMBER, /* New Destination */
UNI_DIAG_CRATE, /* Traffic descriptor subfield */
UNI_DIAG_ATTR, /* Attribute idendity */
UNI_DIAG_PARAM, /* Parameter, same as one IE */
UNI_DIAG_TIMER, /* timer in ASCII */
UNI_DIAG_MTYPE, /* Message type */
UNI_DIAG_IE, /* Information element */
UNI_DIAG_CHANID, /* VPCI/VCI */
UNI_DIAG_CAUSE = UNI_DIAG_NONE, /* Not specified */
UNI_DIAG_CHANNEL = UNI_DIAG_NONE, /* For N-ISDN */
UNI_DIAG_CCBS = UNI_DIAG_NONE, /* Not used in Q.931 */
UNI_DIAG_FAC = UNI_DIAG_NONE, /* Not specified */
};
enum {
UNI_CAUSE_TRAFFIC_N = 34-6,
UNI_CAUSE_IE_N = 34-6,
UNI_CAUSE_ATTR_N = (34-6)/3,
};
struct uni_ie_cause {
struct uni_iehdr h;
#define UNI_CAUSE_COND_P 0x0001
#define UNI_CAUSE_REJ_P 0x0002
#define UNI_CAUSE_REJ_USER_P 0x0004
#define UNI_CAUSE_REJ_IE_P 0x0008
#define UNI_CAUSE_IE_P 0x0010
#define UNI_CAUSE_TRAFFIC_P 0x0020
#define UNI_CAUSE_VPCI_P 0x0040
#define UNI_CAUSE_MTYPE_P 0x0080
#define UNI_CAUSE_TIMER_P 0x0100
#define UNI_CAUSE_TNS_P 0x0200
#define UNI_CAUSE_NUMBER_P 0x0400
#define UNI_CAUSE_ATTR_P 0x0800
#define UNI_CAUSE_PARAM_P 0x1000
enum uni_cause_loc loc;
enum uni_cause cause;
union {
struct {
enum uni_cause_pu pu;
enum uni_cause_na na;
enum uni_cause_cond cond;
} cond;
struct {
enum uni_cause_reason reason;
enum uni_cause_cond cond;
u_int user;
uint8_t ie;
} rej;
struct {
uint8_t ie[UNI_CAUSE_IE_N];
u_int len;
} ie;
struct {
uint8_t traffic[UNI_CAUSE_TRAFFIC_N];
u_int len;
} traffic;
struct {
uint16_t vpci;
uint16_t vci;
} vpci;
uint8_t mtype;
u_char timer[3];
struct uni_ie_tns tns;
struct uni_ie_called number; /* TNS does not fit */
uint8_t param;
struct {
u_int nattr;
u_char attr[UNI_CAUSE_ATTR_N][3];
} attr;
} u;
};
enum uni_diag uni_diag(enum uni_cause, enum uni_coding);
/* return a string for the cause (NULL if the coding/cause are illegal) */
const char *uni_ie_cause2str(enum uni_coding, u_int);
/*************************************************************************
*
* Connection identifier information element
*/
enum uni_connid_type {
UNI_CONNID_VCI = 0,
UNI_CONNID_ANYVCI = 1,
UNI_CONNID_NOVCI = 4,
};
enum uni_connid_assoc {
UNI_CONNID_ASSOC = 0,
UNI_CONNID_NONASSOC = 1,
};
struct uni_ie_connid {
struct uni_iehdr h;
enum uni_connid_assoc assoc;
enum uni_connid_type type;
u_int vpci : 16;
u_int vci : 16;
};
/*************************************************************************
*
* End point reference IE
*/
struct uni_ie_epref {
struct uni_iehdr h;
u_int flag : 1;
u_int epref : 15;
};
/*************************************************************************
*
* End point state IE
*/
enum uni_epstate {
UNI_EPSTATE_NULL = 0x00,
UNI_EPSTATE_ADD_INIT = 0x01,
UNI_EPSTATE_ALERT_DLVD = 0x04,
UNI_EPSTATE_ADD_RCVD = 0x06,
UNI_EPSTATE_ALERT_RCVD = 0x07,
UNI_EPSTATE_ACTIVE = 0x0a,
UNI_EPSTATE_DROP_INIT = 0x0b,
UNI_EPSTATE_DROP_RCVD = 0x0c,
};
struct uni_ie_epstate {
struct uni_iehdr h;
enum uni_epstate state;
};
/*************************************************************************
*
* Q.2932 Facility IE
*/
enum {
UNI_FACILITY_ROSE = 0x11,
UNI_FACILITY_MAXAPDU = 128,
};
struct uni_ie_facility {
struct uni_iehdr h;
u_char proto;
u_char apdu[UNI_FACILITY_MAXAPDU];
u_int len;
};
/*************************************************************************
*
* Notification indicator
*/
enum {
UNI_NOTIFY_MAXLEN = 128, /* maximum info length */
};
struct uni_ie_notify {
struct uni_iehdr h;
u_int len;
u_char notify[UNI_NOTIFY_MAXLEN];
};
/*************************************************************************
*
* QoS information element
*/
enum uni_qos {
UNI_QOS_CLASS0 = 0x00,
UNI_QOS_CLASS1 = 0x01,
UNI_QOS_CLASS2 = 0x02,
UNI_QOS_CLASS3 = 0x03,
UNI_QOS_CLASS4 = 0x04,
};
struct uni_ie_qos {
struct uni_iehdr h;
enum uni_qos fwd;
enum uni_qos bwd;
};
/*************************************************************************
*
* Broadband repeat indicator information element
*/
enum uni_repeat_type {
UNI_REPEAT_PRIDESC = 0x02,
UNI_REPEAT_STACK = 0x0a, /* PNNI */
};
struct uni_ie_repeat {
struct uni_iehdr h;
enum uni_repeat_type type;
};
/*************************************************************************
*
* Restart indicator information element
*/
enum uni_restart_type {
UNI_RESTART_CHANNEL = 0x0,
UNI_RESTART_PATH = 0x1,
UNI_RESTART_ALL = 0x2,
};
struct uni_ie_restart {
struct uni_iehdr h;
enum uni_restart_type rclass;
};
/*************************************************************************
*
* Broadband sending complete indicator information element
*/
struct uni_ie_scompl {
struct uni_iehdr h;
};
/*************************************************************************
*
* ATM traffic descriptor information element
*/
enum {
UNI_TRAFFIC_FMDCR_ID = 0x00,
UNI_TRAFFIC_BMDCR_ID = 0x02,
UNI_TRAFFIC_FPCR0_ID = 0x82,
UNI_TRAFFIC_BPCR0_ID = 0x83,
UNI_TRAFFIC_FPCR1_ID = 0x84,
UNI_TRAFFIC_BPCR1_ID = 0x85,
UNI_TRAFFIC_FSCR0_ID = 0x88,
UNI_TRAFFIC_BSCR0_ID = 0x89,
UNI_TRAFFIC_FSCR1_ID = 0x90,
UNI_TRAFFIC_BSCR1_ID = 0x91,
UNI_TRAFFIC_FABR1_ID = 0x92,
UNI_TRAFFIC_BABR1_ID = 0x93,
UNI_TRAFFIC_FMBS0_ID = 0xa0,
UNI_TRAFFIC_BMBS0_ID = 0xa1,
UNI_TRAFFIC_FMBS1_ID = 0xb0,
UNI_TRAFFIC_BMBS1_ID = 0xb1,
UNI_TRAFFIC_BEST_ID = 0xbe,
UNI_TRAFFIC_MOPT_ID = 0xbf,
UNI_TRAFFIC_FTAG = 0x01,
UNI_TRAFFIC_BTAG = 0x02,
UNI_TRAFFIC_FDISC = 0x80,
UNI_TRAFFIC_BDISC = 0x40,
UNI_MINTRAFFIC_FPCR0_ID = 0x82,
UNI_MINTRAFFIC_BPCR0_ID = 0x83,
UNI_MINTRAFFIC_FPCR1_ID = 0x84,
UNI_MINTRAFFIC_BPCR1_ID = 0x85,
UNI_MINTRAFFIC_FABR1_ID = 0x92,
UNI_MINTRAFFIC_BABR1_ID = 0x93,
UNI_MDCR_ORIGIN_USER = 0x00,
UNI_MDCR_ORIGIN_NET = 0x01,
};
#define UNI_TRAFFIC_FPCR0_P 0x0001
#define UNI_TRAFFIC_BPCR0_P 0x0002
#define UNI_TRAFFIC_FPCR1_P 0x0004
#define UNI_TRAFFIC_BPCR1_P 0x0008
#define UNI_TRAFFIC_FSCR0_P 0x0010
#define UNI_TRAFFIC_BSCR0_P 0x0020
#define UNI_TRAFFIC_FSCR1_P 0x0040
#define UNI_TRAFFIC_BSCR1_P 0x0080
#define UNI_TRAFFIC_FMBS0_P 0x0100
#define UNI_TRAFFIC_BMBS0_P 0x0200
#define UNI_TRAFFIC_FMBS1_P 0x0400
#define UNI_TRAFFIC_BMBS1_P 0x0800
#define UNI_TRAFFIC_BEST_P 0x1000
#define UNI_TRAFFIC_MOPT_P 0x2000
#define UNI_TRAFFIC_FABR1_P 0x4000
#define UNI_TRAFFIC_BABR1_P 0x8000
struct uni_xtraffic {
u_int fpcr0, bpcr0;
u_int fpcr1, bpcr1;
u_int fscr0, bscr0;
u_int fscr1, bscr1;
u_int fmbs0, bmbs0;
u_int fmbs1, bmbs1;
u_int fabr1, babr1;
u_int ftag, btag;
u_int fdisc, bdisc;
};
struct uni_ie_traffic {
struct uni_iehdr h;
struct uni_xtraffic t;
};
struct uni_ie_atraffic {
struct uni_iehdr h;
struct uni_xtraffic t;
};
/*
* Q.2961 minimum traffic descriptor
*/
struct uni_ie_mintraffic {
struct uni_iehdr h;
#define UNI_MINTRAFFIC_FPCR0_P 0x0001
#define UNI_MINTRAFFIC_BPCR0_P 0x0002
#define UNI_MINTRAFFIC_FPCR1_P 0x0004
#define UNI_MINTRAFFIC_BPCR1_P 0x0008
#define UNI_MINTRAFFIC_FABR1_P 0x0010
#define UNI_MINTRAFFIC_BABR1_P 0x0020
u_int fpcr0, bpcr0;
u_int fpcr1, bpcr1;
u_int fabr1, babr1;
};
/*
* UNI4.0+ (af-cs-0147.000) Minimum Desired Cell Rate
*/
struct uni_ie_mdcr {
struct uni_iehdr h;
u_int origin;
u_int fmdcr, bmdcr;
};
/*************************************************************************
*
* User-user information information element
*/
struct uni_ie_uu {
struct uni_iehdr h;
u_int len;
u_char uu[UNI_UU_MAXLEN];
};
/*************************************************************************
*
* Generic identifier transport
*/
enum uni_git_std {
UNI_GIT_STD_DSMCC = 0x01, /* DSM-CC */
UNI_GIT_STD_H245 = 0x02, /* H.245 */
};
enum uni_git_type {
UNI_GIT_TYPE_SESS = 0x01, /* session id */
UNI_GIT_TYPE_RES = 0x02, /* resource id */
};
enum {
UNI_GIT_MAXSESS = 20, /* max session value length */
UNI_GIT_MAXRES = 4, /* max resource value length */
UNI_GIT_MAXVAL = 20, /* the maximum of the above */
UNI_GIT_MAXSUB = 2, /* maximum number of og. 6 */
};
struct uni_ie_git {
struct uni_iehdr h;
enum uni_git_std std; /* identifier related standard/application */
u_int numsub;
struct {
enum uni_git_type type;
u_int len;
u_char val[UNI_GIT_MAXVAL];
} sub[UNI_GIT_MAXSUB];
};
/*************************************************************************
*
* End-to-end transit delay
*/
enum {
UNI_EETD_CTD_ID = 0x01, /* cumulative transit delay */
UNI_EETD_MTD_ID = 0x03, /* maximum transit delay */
UNI_EETD_NET_ID = 0x0a, /* network generated */
UNI_EETD_PMTD_ID = 0x0b, /* PNNI acceptable forward maximum ctd */
UNI_EETD_PCTD_ID = 0x11, /* PNNI cumulative forward maximum ctd */
UNI_EETD_ANYMAX = 0xffff,
UNI_EETD_MAXVAL = 0xffff, /* maximum value */
};
struct uni_ie_eetd {
struct uni_iehdr h;
#define UNI_EETD_CUM_P 0x0001
#define UNI_EETD_MAX_P 0x0002
#define UNI_EETD_NET_P 0x0004 /* UNI4.0 9.1.2.1 */
#define UNI_EETD_PMTD_P 0x0008 /* PNNI1.0 6.4.5.24 */
#define UNI_EETD_PCTD_P 0x0010 /* PNNI1.0 6.4.5.24 */
u_int cumulative;
u_int maximum;
u_int pmtd;
u_int pctd;
};
/*************************************************************************
*
* Leaf-initiated-join call identifier
*/
enum uni_lij_idtype {
UNI_LIJ_IDTYPE_ROOT = 0x0, /* root created */
};
struct uni_ie_lij_callid {
struct uni_iehdr h;
enum uni_lij_idtype type;
u_int callid;
};
/*
* LIJ parameters
*/
enum uni_lij_screen {
UNI_LIJ_SCREEN_NETJOIN = 0x0, /* without root notification */
};
struct uni_ie_lij_param {
struct uni_iehdr h;
enum uni_lij_screen screen;
};
/*
* LIJ sequence number
*/
struct uni_ie_lij_seqno {
struct uni_iehdr h;
u_int seqno;
};
/*************************************************************************
*
* Locking/Non-locking shift not supported
*/
struct uni_ie_lshift {
struct uni_iehdr h;
u_int set:3;
};
struct uni_ie_nlshift {
struct uni_iehdr h;
u_int set:3;
};
/*************************************************************************
*
* Externded QoS information element
*/
enum {
UNI_EXQOS_FACC_ID = 0x94,
UNI_EXQOS_BACC_ID = 0x95,
UNI_EXQOS_FCUM_ID = 0x96,
UNI_EXQOS_BCUM_ID = 0x97,
UNI_EXQOS_FCLR_ID = 0xa2,
UNI_EXQOS_BCLR_ID = 0xa3,
};
enum uni_exqos_origin {
UNI_EXQOS_USER = 0,
UNI_EXQOS_NET = 1,
};
enum {
UNI_EXQOS_ANY_CDV = 0xffffff,
UNI_EXQOS_ANY_CLR = 0xff,
};
struct uni_ie_exqos {
struct uni_iehdr h;
#define UNI_EXQOS_FACC_P 0x0001
#define UNI_EXQOS_BACC_P 0x0002
#define UNI_EXQOS_FCUM_P 0x0004
#define UNI_EXQOS_BCUM_P 0x0008
#define UNI_EXQOS_FCLR_P 0x0010
#define UNI_EXQOS_BCLR_P 0x0020
enum uni_exqos_origin origin;
u_int facc;
u_int bacc;
u_int fcum;
u_int bcum;
u_int fclr;
u_int bclr;
};
/*************************************************************************
*
* Additional ABR parameters
* ABR setup parameters
*/
enum {
UNI_ABRADD_FADD_ID = 0xc2,
UNI_ABRADD_BADD_ID = 0xc3,
UNI_ABRSETUP_FICR_ID = 0xc2,
UNI_ABRSETUP_BICR_ID = 0xc3,
UNI_ABRSETUP_FTBE_ID = 0xc4,
UNI_ABRSETUP_BTBE_ID = 0xc5,
UNI_ABRSETUP_RMFRT_ID = 0xc6,
UNI_ABRSETUP_FRIF_ID = 0xc8,
UNI_ABRSETUP_BRIF_ID = 0xc9,
UNI_ABRSETUP_FRDF_ID = 0xca,
UNI_ABRSETUP_BRDF_ID = 0xcb,
};
struct uni_abr_rec {
u_int present;
#define UNI_ABR_REC_NRM_P 0x80000000
#define UNI_ABR_REC_TRM_P 0x40000000
#define UNI_ABR_REC_CDF_P 0x20000000
#define UNI_ABR_REC_ADTF_P 0x10000000
u_int nrm:3;
u_int trm:3;
u_int cdf:3;
u_int adtf:10;
};
struct uni_ie_abradd {
struct uni_iehdr h;
struct uni_abr_rec fwd, bwd;
};
struct uni_ie_abrsetup {
struct uni_iehdr h;
#define UNI_ABRSETUP_FICR_P 0x0001
#define UNI_ABRSETUP_BICR_P 0x0002
#define UNI_ABRSETUP_FTBE_P 0x0004
#define UNI_ABRSETUP_BTBE_P 0x0008
#define UNI_ABRSETUP_FRIF_P 0x0010
#define UNI_ABRSETUP_BRIF_P 0x0020
#define UNI_ABRSETUP_FRDF_P 0x0040
#define UNI_ABRSETUP_BRDF_P 0x0080
#define UNI_ABRSETUP_RMFRT_P 0x0100
u_int ficr, bicr;
u_int ftbe, btbe;
u_int rmfrt;
u_int frif, brif;
u_int frdf, brdf;
};
/*************************************************************************
*
* Connection scope information element
*/
enum uni_cscope {
UNI_CSCOPE_ORG = 0x01,
};
enum {
UNI_CSCOPE_ORG_LOC = 0x01,
UNI_CSCOPE_ORG_LOC_P1 = 0x02,
UNI_CSCOPE_ORG_LOC_P2 = 0x03,
UNI_CSCOPE_ORG_SITE_M1 = 0x04,
UNI_CSCOPE_ORG_SITE = 0x05,
UNI_CSCOPE_ORG_SITE_P1 = 0x06,
UNI_CSCOPE_ORG_ORG_M1 = 0x07,
UNI_CSCOPE_ORG_ORG = 0x08,
UNI_CSCOPE_ORG_ORG_P1 = 0x09,
UNI_CSCOPE_ORG_COMM_M1 = 0x0a,
UNI_CSCOPE_ORG_COMM = 0x0b,
UNI_CSCOPE_ORG_COMM_P1 = 0x0c,
UNI_CSCOPE_ORG_REG = 0x0d,
UNI_CSCOPE_ORG_INTER = 0x0e,
UNI_CSCOPE_ORG_GLOBAL = 0x0f,
};
struct uni_ie_cscope {
struct uni_iehdr h;
enum uni_cscope type;
u_int scope:8;
};
/*************************************************************************
*
* Connection scope information element
*/
enum uni_report {
UNI_REPORT_MODCONF = 0x01,
UNI_REPORT_CLOCK = 0x02,
UNI_REPORT_EEAVAIL = 0x04,
UNI_REPORT_EEREQ = 0x05,
UNI_REPORT_EECOMPL = 0x06,
};
struct uni_ie_report {
struct uni_iehdr h;
enum uni_report report;
};
/*************************************************************************
*
* PNNI Designated transit list information element
*/
enum {
UNI_DTL_LOGNP = 0x01,
UNI_DTL_LOGNP_SIZE = 27,
};
struct uni_ie_dtl {
struct uni_iehdr h;
u_int ptr:16;
u_int num;
struct {
u_char node_level;
u_char node_id[21];
u_int port_id;
} dtl[UNI_DTL_MAXNUM];
};
/*************************************************************************
*
* PNNI Crankback information element
*/
enum uni_crankback {
UNI_CRANKBACK_IF = 0x02,
UNI_CRANKBACK_NODE = 0x03,
UNI_CRANKBACK_LINK = 0x04,
};
enum {
UNI_CAUSE_NXNODE_UNREACH = 128,
UNI_CAUSE_DTL_NOT_MY_ID = 160,
};
struct uni_ie_crankback {
struct uni_iehdr h;
#define UNI_CRANKBACK_TOP_P 0x0001
#define UNI_CRANKBACK_TOPX_P 0x0002
#define UNI_CRANKBACK_QOS_P 0x0004
u_int level:8;
enum uni_crankback type;
union {
struct {
u_char level;
u_char id[21];
} node;
struct {
u_char plevel;
u_char pid[21];
u_int port;
u_char slevel;
u_char sid[21];
} link;
} id;
u_int cause:8;
union {
struct {
u_int dir:8;
u_int port;
u_int avcr;
u_int crm;
u_int vf;
} top;
struct {
u_int ctd:1;
u_int cdv:1;
u_int clr:1;
u_int other:1;
} qos;
} diag;
};
/*************************************************************************
*
* PNNI Call_ing/called party soft PVPC/PVCC information element
*/
enum uni_soft_sel {
UNI_SOFT_SEL_ANY = 0x00,
UNI_SOFT_SEL_REQ = 0x02,
UNI_SOFT_SEL_ASS = 0x04,
};
struct uni_ie_calling_soft {
struct uni_iehdr h;
#define UNI_CALLING_SOFT_VCI_P 0x0001
u_int vpi:12;
u_int vci:16;
};
struct uni_ie_called_soft {
struct uni_iehdr h;
#define UNI_CALLED_SOFT_VPI_P 0x0001
#define UNI_CALLED_SOFT_VCI_P 0x0002
enum uni_soft_sel sel;
u_int vpi:12;
u_int vci:16;
};
/*************************************************************************/
#include <netnatm/msg/uni_ie.h>
#include <netnatm/msg/uni_msg.h>
struct uni_all {
enum uni_msgtype mtype;
union uni_msgall u;
};
struct uni_ie {
enum uni_ietype ietype;
union uni_ieall u;
};
#endif