|
|
1.1 ! root 1: /* ! 2: * Copyright (c) 2000 Apple Computer, Inc. All rights reserved. ! 3: * ! 4: * @APPLE_LICENSE_HEADER_START@ ! 5: * ! 6: * The contents of this file constitute Original Code as defined in and ! 7: * are subject to the Apple Public Source License Version 1.1 (the ! 8: * "License"). You may not use this file except in compliance with the ! 9: * License. Please obtain a copy of the License at ! 10: * http://www.apple.com/publicsource and read it before using this file. ! 11: * ! 12: * This Original Code and all software distributed under the License are ! 13: * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER ! 14: * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, ! 15: * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, ! 16: * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the ! 17: * License for the specific language governing rights and limitations ! 18: * under the License. ! 19: * ! 20: * @APPLE_LICENSE_HEADER_END@ ! 21: */ ! 22: /* ! 23: * Copyright (c) Computing Centre, University of British Columbia, 1985 ! 24: * Copyright (C) Computer Science Department IV, ! 25: * University of Erlangen-Nuremberg, Germany, 1990, 1991, 1992 ! 26: * Copyright (c) 1992, 1993 ! 27: * The Regents of the University of California. All rights reserved. ! 28: * ! 29: * This code is derived from software contributed to Berkeley by the ! 30: * Laboratory for Computation Vision and the Computer Science Department ! 31: * of the the University of British Columbia and the Computer Science ! 32: * Department (IV) of the University of Erlangen-Nuremberg, Germany. ! 33: * ! 34: * Redistribution and use in source and binary forms, with or without ! 35: * modification, are permitted provided that the following conditions ! 36: * are met: ! 37: * 1. Redistributions of source code must retain the above copyright ! 38: * notice, this list of conditions and the following disclaimer. ! 39: * 2. Redistributions in binary form must reproduce the above copyright ! 40: * notice, this list of conditions and the following disclaimer in the ! 41: * documentation and/or other materials provided with the distribution. ! 42: * 3. All advertising materials mentioning features or use of this software ! 43: * must display the following acknowledgement: ! 44: * This product includes software developed by the University of ! 45: * California, Berkeley and its contributors. ! 46: * 4. Neither the name of the University nor the names of its contributors ! 47: * may be used to endorse or promote products derived from this software ! 48: * without specific prior written permission. ! 49: * ! 50: * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND ! 51: * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE ! 52: * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ! 53: * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE ! 54: * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL ! 55: * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS ! 56: * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) ! 57: * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT ! 58: * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY ! 59: * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF ! 60: * SUCH DAMAGE. ! 61: * ! 62: * @(#)pk_var.h 8.1 (Berkeley) 6/10/93 ! 63: */ ! 64: ! 65: /* ! 66: * ! 67: * X.25 Logical Channel Descriptor ! 68: * ! 69: */ ! 70: ! 71: struct pklcd { ! 72: struct pklcd_q { ! 73: struct pklcd_q *q_forw; /* debugging chain */ ! 74: struct pklcd_q *q_back; /* debugging chain */ ! 75: } lcd_q; ! 76: int (*lcd_upper)(); /* switch to socket vs datagram vs ...*/ ! 77: caddr_t lcd_upnext; /* reference for lcd_upper() */ ! 78: int (*lcd_send)(); /* if X.25 front end, direct connect */ ! 79: caddr_t lcd_downnext; /* reference for lcd_send() */ ! 80: short lcd_lcn; /* Logical channel number */ ! 81: short lcd_state; /* Logical Channel state */ ! 82: short lcd_timer; /* Various timer values */ ! 83: short lcd_dg_timer; /* to reclaim idle datagram circuits */ ! 84: bool lcd_intrconf_pending; /* Interrupt confirmation pending */ ! 85: octet lcd_intrdata; /* Octet of incoming intr data */ ! 86: char lcd_retry; /* Timer retry count */ ! 87: char lcd_rsn; /* Seq no of last received packet */ ! 88: char lcd_ssn; /* Seq no of next packet to send */ ! 89: char lcd_output_window; /* Output flow control window */ ! 90: char lcd_input_window; /* Input flow control window */ ! 91: char lcd_last_transmitted_pr;/* Last Pr value transmitted */ ! 92: bool lcd_rnr_condition; /* Remote in busy condition */ ! 93: bool lcd_window_condition; /* Output window size exceeded */ ! 94: bool lcd_reset_condition; /* True, if waiting reset confirm */ ! 95: bool lcd_rxrnr_condition; /* True, if we have sent rnr */ ! 96: char lcd_packetsize; /* Maximum packet size */ ! 97: char lcd_windowsize; /* Window size - both directions */ ! 98: octet lcd_closed_user_group; /* Closed user group specification */ ! 99: char lcd_flags; /* copy of sockaddr_x25 op_flags */ ! 100: struct mbuf *lcd_facilities; /* user supplied facilities for cr */ ! 101: struct mbuf *lcd_template; /* Address of response packet */ ! 102: struct socket *lcd_so; /* Socket addr for connection */ ! 103: struct sockaddr_x25 *lcd_craddr;/* Calling address pointer */ ! 104: struct sockaddr_x25 *lcd_ceaddr;/* Called address pointer */ ! 105: time_t lcd_stime; /* time circuit established */ ! 106: long lcd_txcnt; /* Data packet transmit count */ ! 107: long lcd_rxcnt; /* Data packet receive count */ ! 108: short lcd_intrcnt; /* Interrupt packet transmit count */ ! 109: struct pklcd *lcd_listen; /* Next lcd on listen queue */ ! 110: struct pkcb *lcd_pkp; /* Network this lcd is attached to */ ! 111: struct mbuf *lcd_cps; /* Complete Packet Sequence reassembly*/ ! 112: long lcd_cpsmax; /* Max length for CPS */ ! 113: struct sockaddr_x25 lcd_faddr; /* Remote Address (Calling) */ ! 114: struct sockaddr_x25 lcd_laddr; /* Local Address (Called) */ ! 115: struct sockbuf lcd_sb; /* alternate for datagram service */ ! 116: }; ! 117: ! 118: /* ! 119: * Per network information, allocated dynamically ! 120: * when a new network is configured. ! 121: */ ! 122: ! 123: struct pkcb { ! 124: struct pkcb_q { ! 125: struct pkcb_q *q_forw; ! 126: struct pkcb_q *q_backw; ! 127: } pk_q; ! 128: short pk_state; /* packet level status */ ! 129: short pk_maxlcn; /* local copy of xc_maxlcn */ ! 130: int (*pk_lloutput) (); /* link level output procedure */ ! 131: caddr_t (*pk_llctlinput) (); /* link level ctloutput procedure */ ! 132: caddr_t pk_llnext; /* handle for next level down */ ! 133: struct x25config *pk_xcp; /* network specific configuration */ ! 134: struct x25_ifaddr *pk_ia; /* backpointer to ifaddr */ ! 135: struct pklcd **pk_chan; /* actual size == xc_maxlcn+1 */ ! 136: short pk_dxerole; /* DXE role of PLE over LLC2 */ ! 137: short pk_restartcolls; /* counting RESTART collisions til resolved */ ! 138: struct rtentry *pk_rt; /* back pointer to route */ ! 139: struct rtentry *pk_llrt; /* pointer to reverse mapping */ ! 140: u_short pk_refcount; /* ref count */ ! 141: }; ! 142: ! 143: #define FOR_ALL_PKCBS(p) for((p) = (struct pkcb *)(pkcb_q.q_forw); \ ! 144: (pkcb_q.q_forw != &pkcb_q) && ((struct pkcb_q *)(p) != &pkcb_q); \ ! 145: (p) = (struct pkcb *)((p) -> pk_q.q_forw)) ! 146: ! 147: #define PQEMPTY (pkcb_q.q_forw == &pkcb_q) ! 148: ! 149: /* ! 150: * Interface address, x25 version. Exactly one of these structures is ! 151: * allocated for each interface with an x25 address. ! 152: * ! 153: * The ifaddr structure conatins the protocol-independent part ! 154: * of the structure, and is assumed to be first. ! 155: */ ! 156: struct x25_ifaddr { ! 157: struct ifaddr ia_ifa; /* protocol-independent info */ ! 158: #define ia_ifp ia_ifa.ifa_ifp ! 159: #define ia_flags ia_ifa.ifa_flags ! 160: struct x25config ia_xc; /* network specific configuration */ ! 161: struct pkcb *ia_pkcb; ! 162: #define ia_maxlcn ia_xc.xc_maxlcn ! 163: int (*ia_start) (); /* connect, confirm method */ ! 164: struct sockaddr_x25 ia_dstaddr; /* reserve space for route dst */ ! 165: }; ! 166: ! 167: /* ! 168: * ``Link-Level'' extension to Routing Entry for upper level ! 169: * packet switching via X.25 virtual circuits. ! 170: */ ! 171: struct llinfo_x25 { ! 172: struct llinfo_x25 *lx_next; /* chain together in linked list */ ! 173: struct llinfo_x25 *lx_prev; /* chain together in linked list */ ! 174: struct rtentry *lx_rt; /* back pointer to route */ ! 175: struct pklcd *lx_lcd; /* local connection block */ ! 176: struct x25_ifaddr *lx_ia; /* may not be same as rt_ifa */ ! 177: int lx_state; /* can't trust lcd->lcd_state */ ! 178: int lx_flags; ! 179: int lx_timer; /* for idle timeout */ ! 180: int lx_family; /* for dispatch */ ! 181: }; ! 182: ! 183: /* States for lx_state */ ! 184: #define LXS_NEWBORN 0 ! 185: #define LXS_RESOLVING 1 ! 186: #define LXS_FREE 2 ! 187: #define LXS_CONNECTING 3 ! 188: #define LXS_CONNECTED 4 ! 189: #define LXS_DISCONNECTING 5 ! 190: #define LXS_LISTENING 6 ! 191: ! 192: /* flags */ ! 193: #define LXF_VALID 0x1 /* Circuit is live, etc. */ ! 194: #define LXF_RTHELD 0x2 /* this lcb references rtentry */ ! 195: #define LXF_LISTEN 0x4 /* accepting incoming calls */ ! 196: ! 197: /* ! 198: * Definitions for accessing bitfields/bitslices inside X.25 structs ! 199: */ ! 200: ! 201: ! 202: struct x25bitslice { ! 203: unsigned int bs_mask; ! 204: unsigned int bs_shift; ! 205: }; ! 206: ! 207: #define calling_addrlen 0 ! 208: #define called_addrlen 1 ! 209: #define q_bit 2 ! 210: #define d_bit 3 ! 211: #define fmt_identifier 4 ! 212: #define lc_group_number 1 ! 213: #define p_r 5 ! 214: #define m_bit 6 ! 215: #define p_s 7 ! 216: #define zilch 8 ! 217: ! 218: #define X25GBITS(Arg, Index) (((Arg) & x25_bitslice[(Index)].bs_mask) >> x25_bitslice[(Index)].bs_shift) ! 219: #define X25SBITS(Arg, Index, Val) (Arg) |= (((Val) << x25_bitslice[(Index)].bs_shift) & x25_bitslice[(Index)].bs_mask) ! 220: #define X25CSBITS(Arg, Index, Val) (Arg) = (((Val) << x25_bitslice[(Index)].bs_shift) & x25_bitslice[(Index)].bs_mask) ! 221: ! 222: extern struct x25bitslice x25_bitslice[]; ! 223: ! 224: ! 225: #define ISOFIFTTYPE(i,t) ((i)->if_type == (t)) ! 226: #define ISISO8802(i) ((ISOFIFTTYPE(i, IFT_ETHER) || \ ! 227: ISOFIFTTYPE(i, IFT_ISO88023) || \ ! 228: ISOFIFTTYPE(i, IFT_ISO88024) || \ ! 229: ISOFIFTTYPE(i, IFT_ISO88025) || \ ! 230: ISOFIFTTYPE(i, IFT_ISO88026) || \ ! 231: ISOFIFTTYPE(i, IFT_P10) || \ ! 232: ISOFIFTTYPE(i, IFT_P80) || \ ! 233: ISOFIFTTYPE(i, IFT_FDDI))) ! 234: ! 235: /* ! 236: * miscellenous debugging info ! 237: */ ! 238: struct mbuf_cache { ! 239: int mbc_size; ! 240: int mbc_num; ! 241: int mbc_oldsize; ! 242: struct mbuf **mbc_cache; ! 243: }; ! 244: ! 245: #if defined(KERNEL) && defined(CCITT) ! 246: extern struct pkcb_q pkcb_q; ! 247: struct pklcd *pk_listenhead; ! 248: struct pklcd *pk_attach(); ! 249: ! 250: extern char *pk_name[], *pk_state[]; ! 251: int pk_t20, pk_t21, pk_t22, pk_t23; ! 252: #endif
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.