if_ppp.h 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. /* $OpenBSD: if_ppp.h,v 1.8 2002/07/01 19:31:34 deraadt Exp $ */
  2. /* $NetBSD: if_ppp.h,v 1.11 1996/03/15 02:28:05 paulus Exp $ */
  3. /*
  4. * if_ppp.h - Point-to-Point Protocol definitions.
  5. *
  6. * Copyright (c) 1984-2000 Carnegie Mellon University. All rights reserved.
  7. *
  8. * Redistribution and use in source and binary forms, with or without
  9. * modification, are permitted provided that the following conditions
  10. * are met:
  11. *
  12. * 1. Redistributions of source code must retain the above copyright
  13. * notice, this list of conditions and the following disclaimer.
  14. *
  15. * 2. Redistributions in binary form must reproduce the above copyright
  16. * notice, this list of conditions and the following disclaimer in
  17. * the documentation and/or other materials provided with the
  18. * distribution.
  19. *
  20. * 3. The name "Carnegie Mellon University" must not be used to
  21. * endorse or promote products derived from this software without
  22. * prior written permission. For permission or any legal
  23. * details, please contact
  24. * Office of Technology Transfer
  25. * Carnegie Mellon University
  26. * 5000 Forbes Avenue
  27. * Pittsburgh, PA 15213-3890
  28. * (412) 268-4387, fax: (412) 268-7395
  29. * tech-transfer@andrew.cmu.edu
  30. *
  31. * 4. Redistributions of any form whatsoever must retain the following
  32. * acknowledgment:
  33. * "This product includes software developed by Computing Services
  34. * at Carnegie Mellon University (http://www.cmu.edu/computing/)."
  35. *
  36. * CARNEGIE MELLON UNIVERSITY DISCLAIMS ALL WARRANTIES WITH REGARD TO
  37. * THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
  38. * AND FITNESS, IN NO EVENT SHALL CARNEGIE MELLON UNIVERSITY BE LIABLE
  39. * FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
  40. * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN
  41. * AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING
  42. * OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  43. */
  44. #ifndef _NET_IF_PPP_H_
  45. #define _NET_IF_PPP_H_
  46. /*
  47. * Packet sizes
  48. */
  49. #define PPP_MTU 1500 /* Default MTU (size of Info field) */
  50. #define PPP_MAXMRU 65000 /* Largest MRU we allow */
  51. /*
  52. * Bit definitions for flags.
  53. */
  54. #define SC_COMP_PROT 0x00000001 /* protocol compression (output) */
  55. #define SC_COMP_AC 0x00000002 /* header compression (output) */
  56. #define SC_COMP_TCP 0x00000004 /* TCP (VJ) compression (output) */
  57. #define SC_NO_TCP_CCID 0x00000008 /* disable VJ connection-id comp. */
  58. #define SC_REJ_COMP_AC 0x00000010 /* reject adrs/ctrl comp. on input */
  59. #define SC_REJ_COMP_TCP 0x00000020 /* reject TCP (VJ) comp. on input */
  60. #define SC_CCP_OPEN 0x00000040 /* Look at CCP packets */
  61. #define SC_CCP_UP 0x00000080 /* May send/recv compressed packets */
  62. #define SC_DEBUG 0x00010000 /* enable debug messages */
  63. #define SC_LOG_INPKT 0x00020000 /* log contents of good pkts recvd */
  64. #define SC_LOG_OUTPKT 0x00040000 /* log contents of pkts sent */
  65. #define SC_LOG_RAWIN 0x00080000 /* log all chars received */
  66. #define SC_LOG_FLUSH 0x00100000 /* log all chars flushed */
  67. #define SC_RCV_B7_0 0x01000000 /* have rcvd char with bit 7 = 0 */
  68. #define SC_RCV_B7_1 0x02000000 /* have rcvd char with bit 7 = 1 */
  69. #define SC_RCV_EVNP 0x04000000 /* have rcvd char with even parity */
  70. #define SC_RCV_ODDP 0x08000000 /* have rcvd char with odd parity */
  71. #define SC_MASK 0x0fff00ff /* bits that user can change */
  72. /*
  73. * State bits in sc_flags, not changeable by user.
  74. */
  75. #define SC_TIMEOUT 0x00000400 /* timeout is currently pending */
  76. #define SC_VJ_RESET 0x00000800 /* need to reset VJ decomp */
  77. #define SC_COMP_RUN 0x00001000 /* compressor has been inited */
  78. #define SC_DECOMP_RUN 0x00002000 /* decompressor has been inited */
  79. #define SC_DC_ERROR 0x00004000 /* non-fatal decomp error detected */
  80. #define SC_DC_FERROR 0x00008000 /* fatal decomp error detected */
  81. #define SC_TBUSY 0x10000000 /* xmitter doesn't need a packet yet */
  82. #define SC_PKTLOST 0x20000000 /* have lost or dropped a packet */
  83. #define SC_FLUSH 0x40000000 /* flush input until next PPP_FLAG */
  84. #define SC_ESCAPED 0x80000000 /* saw a PPP_ESCAPE */
  85. /*
  86. * Ioctl definitions.
  87. */
  88. struct npioctl {
  89. int protocol; /* PPP procotol, e.g. PPP_IP */
  90. enum NPmode mode;
  91. };
  92. /* Structure describing a CCP configuration option, for PPPIOCSCOMPRESS */
  93. struct ppp_option_data {
  94. u_char *ptr;
  95. u_int length;
  96. int transmit;
  97. };
  98. struct ifpppstatsreq {
  99. char ifr_name[IFNAMSIZ];
  100. struct ppp_stats stats;
  101. };
  102. struct ifpppcstatsreq {
  103. char ifr_name[IFNAMSIZ];
  104. struct ppp_comp_stats stats;
  105. };
  106. /*
  107. * Ioctl definitions.
  108. */
  109. #define PPPIOCGFLAGS _IOR('t', 90, int) /* get configuration flags */
  110. #define PPPIOCSFLAGS _IOW('t', 89, int) /* set configuration flags */
  111. #define PPPIOCGASYNCMAP _IOR('t', 88, int) /* get async map */
  112. #define PPPIOCSASYNCMAP _IOW('t', 87, int) /* set async map */
  113. #define PPPIOCGUNIT _IOR('t', 86, int) /* get ppp unit number */
  114. #define PPPIOCGRASYNCMAP _IOR('t', 85, int) /* get receive async map */
  115. #define PPPIOCSRASYNCMAP _IOW('t', 84, int) /* set receive async map */
  116. #define PPPIOCGMRU _IOR('t', 83, int) /* get max receive unit */
  117. #define PPPIOCSMRU _IOW('t', 82, int) /* set max receive unit */
  118. #define PPPIOCSMAXCID _IOW('t', 81, int) /* set VJ max slot ID */
  119. #define PPPIOCGXASYNCMAP _IOR('t', 80, ext_accm) /* get extended ACCM */
  120. #define PPPIOCSXASYNCMAP _IOW('t', 79, ext_accm) /* set extended ACCM */
  121. #define PPPIOCXFERUNIT _IO('t', 78) /* transfer PPP unit */
  122. #define PPPIOCSCOMPRESS _IOW('t', 77, struct ppp_option_data)
  123. #define PPPIOCGNPMODE _IOWR('t', 76, struct npioctl) /* get NP mode */
  124. #define PPPIOCSNPMODE _IOW('t', 75, struct npioctl) /* set NP mode */
  125. #define PPPIOCGIDLE _IOR('t', 74, struct ppp_idle) /* get idle time */
  126. #define PPPIOCSPASS _IOW('t', 71, struct bpf_program) /* set pass filter */
  127. #define PPPIOCSACTIVE _IOW('t', 70, struct bpf_program) /* set active filt */
  128. /* PPPIOC[GS]MTU are alternatives to SIOC[GS]IFMTU, used under Ultrix */
  129. #define PPPIOCGMTU _IOR('t', 73, int) /* get interface MTU */
  130. #define PPPIOCSMTU _IOW('t', 72, int) /* set interface MTU */
  131. /*
  132. * These two are interface ioctls so that pppstats can do them on
  133. * a socket without having to open the serial device.
  134. */
  135. #define SIOCGPPPSTATS _IOWR('i', 123, struct ifpppstatsreq)
  136. #define SIOCGPPPCSTATS _IOWR('i', 122, struct ifpppcstatsreq)
  137. #ifdef _KERNEL
  138. void pppattach(void);
  139. int pppoutput(struct ifnet *, struct mbuf *, struct sockaddr *,
  140. struct rtentry *);
  141. void pppintr(void);
  142. #endif
  143. #endif /* _NET_IF_PPP_H_ */