Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

264 lines
7.9 KiB

  1. // Copyright (c) 1997, Microsoft Corporation, all rights reserved
  2. //
  3. // l2tprfc.h
  4. // RAS L2TP WAN mini-port/call-manager driver
  5. // L2TP RFC header
  6. //
  7. // 01/07/97 Steve Cobb
  8. //
  9. // This header contains definitions from the L2TP draft/RFC, currently
  10. // draft-12.
  11. //
  12. #ifndef _L2TPRFC_H_
  13. #define _L2TPRFC_H_
  14. //-----------------------------------------------------------------------------
  15. // Constants
  16. //-----------------------------------------------------------------------------
  17. // The UDP port at which L2TP messages will arrive.
  18. //
  19. #define L2TP_UdpPort 1701
  20. // The IP protocol number on which messages will arrive. (No number has been
  21. // assigned so this is a placeholder for now)
  22. //
  23. #define L2TP_IpProtocol 254
  24. // The standard value for the Hello timer in milliseconds.
  25. //
  26. #define L2TP_HelloMs 60000
  27. // The maximum number of bytes in a frame excluding all L2TP and PPP HDLC-ish
  28. // framing overhead.
  29. //
  30. #define L2TP_MaxFrameSize 1500
  31. // Maximum number of bytes in an L2TP control or payload header.
  32. //
  33. #define L2TP_MaxHeaderSize 14
  34. // The maximum number of bytes in the L2TP payload packet header including
  35. // padding. The 14 represents all possible fields defined in the RFC. The
  36. // "+8" represents allowance for up to 8 bytes of padding to be specified in
  37. // the header. While there is theoretically no limit to the padding, there is
  38. // no discussion in the L2TP forum indicating interest in more than 8 bytes.
  39. //
  40. #define L2TP_MaxPayloadHeader (14 + 8)
  41. // The default packet processing delay in 1/10 second, i.e. 1/2 second.
  42. //
  43. #define L2TP_LnsDefaultPpd 5
  44. // The default control send timeout in milliseconds, i.e. 1 second.
  45. //
  46. #define L2TP_DefaultSendTimeoutMs 1000
  47. // The default control/payload piggybacking acknowledge delay in milliseconds.
  48. //
  49. #define L2TP_MaxAckDelay 500
  50. // The implicit receive window offered control channels where no Receive
  51. // Window AVP is provided.
  52. //
  53. #define L2TP_DefaultReceiveWindow 4
  54. // Highest L2TP protocol version we support.
  55. //
  56. #define L2TP_ProtocolVersion 0x0100
  57. // Default maximum send timeout in milliseconds. The draft only says the cap
  58. // must be no less than 8 seconds, so 10 seconds is selected as reasonable and
  59. // safe.
  60. //
  61. #define L2TP_DefaultMaxSendTimeoutMs 10000
  62. // Default maximum retransmissions before assuming peer is unreachable.
  63. //
  64. #define L2TP_DefaultMaxRetransmits 5
  65. // Size in bytes of the fixed portion of a control message attribute/value
  66. // pair, i.e. the size of an AVP with zero length value.
  67. //
  68. #define L2TP_AvpHeaderSize 6
  69. // L2TP protocol control message types.
  70. //
  71. #define CMT_SCCRQ 1 // Start-Control-Connection-Request
  72. #define CMT_SCCRP 2 // Start-Control-Connection-Reply
  73. #define CMT_SCCCN 3 // Start-Control-Connection-Connected
  74. #define CMT_StopCCN 4 // Stop-Control-Connection-Notify
  75. #define CMT_StopCCRP 5 // Stop-Control-Connection-Reply (obsolete)
  76. #define CMT_Hello 6 // Hello, i.e. keep-alive
  77. #define CMT_OCRQ 7 // Outgoing-Call-Request
  78. #define CMT_OCRP 8 // Outgoing-Call-Reply
  79. #define CMT_OCCN 9 // Outgoing-Call-Connected
  80. #define CMT_ICRQ 10 // Incoming-Call-Request
  81. #define CMT_ICRP 11 // Incoming-Call-Reply
  82. #define CMT_ICCN 12 // Incoming-Call-Connected
  83. #define CMT_CCRQ 13 // Call-Clear-Request (obsolete)
  84. #define CMT_CDN 14 // Call-Disconnect-Notify
  85. #define CMT_WEN 15 // WAN-Error-Notify
  86. #define CMT_SLI 16 // Set-Link-Info
  87. // L2TP Attribute codes.
  88. //
  89. #define ATTR_MsgType 0
  90. #define ATTR_Result 1
  91. #define ATTR_ProtocolVersion 2
  92. #define ATTR_FramingCaps 3
  93. #define ATTR_BearerCaps 4
  94. #define ATTR_TieBreaker 5
  95. #define ATTR_FirmwareRevision 6
  96. #define ATTR_HostName 7
  97. #define ATTR_VendorName 8
  98. #define ATTR_AssignedTunnelId 9
  99. #define ATTR_RWindowSize 10
  100. #define ATTR_Challenge 11
  101. #define ATTR_Q931Cause 12
  102. #define ATTR_ChallengeResponse 13
  103. #define ATTR_AssignedCallId 14
  104. #define ATTR_CallSerialNumber 15
  105. #define ATTR_MinimumBps 16
  106. #define ATTR_MaximumBps 17
  107. #define ATTR_BearerType 18
  108. #define ATTR_FramingType 19
  109. #define ATTR_PacketProcDelay 20
  110. #define ATTR_DialedNumber 21
  111. #define ATTR_DialingNumber 22
  112. #define ATTR_SubAddress 23
  113. #define ATTR_TxConnectSpeed 24
  114. #define ATTR_PhysicalChannelId 25
  115. #define ATTR_InitialLcpConfig 26
  116. #define ATTR_LastSLcpConfig 27
  117. #define ATTR_LastRLcpConfig 28
  118. #define ATTR_ProxyAuthType 29
  119. #define ATTR_ProxyAuthName 30
  120. #define ATTR_ProxyAuthChallenge 31
  121. #define ATTR_ProxyAuthId 32
  122. #define ATTR_ProxyAuthResponse 33
  123. #define ATTR_CallErrors 34
  124. #define ATTR_Accm 35
  125. #define ATTR_RandomVector 36
  126. #define ATTR_PrivateGroupId 37
  127. #define ATTR_RxConnectSpeed 38
  128. #define ATTR_SequencingRequired 39
  129. #define ATTR_MAX 39
  130. // L2TP protocol general error codes.
  131. //
  132. #define GERR_None 0
  133. #define GERR_NoControlConnection 1
  134. #define GERR_BadLength 2
  135. #define GERR_BadValue 3
  136. #define GERR_NoResources 4
  137. #define GERR_BadCallId 5
  138. #define GERR_VendorSpecific 6
  139. #define GERR_TryAnother 7
  140. // Tunnel Result Code AVP values, used in StopCCN message.
  141. //
  142. #define TRESULT_General 1
  143. #define TRESULT_GeneralWithError 2
  144. #define TRESULT_CcExists 3
  145. #define TRESULT_NotAuthorized 4
  146. #define TRESULT_BadProtocolVersion 5
  147. #define TRESULT_Shutdown 6
  148. #define TRESULT_FsmError 7
  149. // Call Result Code values, used in CDN message.
  150. //
  151. #define CRESULT_LostCarrier 1
  152. #define CRESULT_GeneralWithError 2
  153. #define CRESULT_Administrative 3
  154. #define CRESULT_NoFacilitiesTemporary 4
  155. #define CRESULT_NoFacilitiesPermanent 5
  156. #define CRESULT_InvalidDestination 6
  157. #define CRESULT_NoCarrier 7
  158. #define CRESULT_Busy 8
  159. #define CRESULT_NoDialTone 9
  160. #define CRESULT_Timeout 10
  161. #define CRESULT_NoFraming 11
  162. // L2TP header bitmasks for the first 2 bytes of every L2TP message.
  163. //
  164. #define HBM_T 0x8000 // Control packet
  165. #define HBM_L 0x4000 // Length field present
  166. #define HBM_R 0x2000 // Reset Sr
  167. #define HBM_F 0x0800 // Nr/Ns fields present
  168. #define HBM_S 0x0200 // Offset field present
  169. #define HBM_P 0x0100 // Preferential treatment bit
  170. #define HBM_Bits 0xFFFC // All bits, excluding protocol version field
  171. #define HBM_Ver 0x0003 // Protocol version (L2TP or L2F)
  172. #define HBM_Control 0xc800 // Fixed value of bits in control message
  173. // The defined header bits version number field values.
  174. //
  175. #define VER_L2f 0x0000
  176. #define VER_L2tp 0x0002
  177. // AVP header bitmasks for the first 2 bytes of every Attribute Value Pair.
  178. //
  179. #define ABM_M 0x8000 // Mandatory
  180. #define ABM_H 0x4000 // Hidden
  181. #define ABM_Reserved 0x3C00 // Reserved bits, must be 0
  182. #define ABM_OverallLength 0x03FF // AVP's length including value
  183. // Bearer capabilties AVP bitmasks.
  184. //
  185. #define BBM_Analog 0x00000001
  186. #define BBM_Digital 0x00000002
  187. // Framing capabilities/type AVP bitmasks.
  188. //
  189. #define FBM_Sync 0x00000001
  190. #define FBM_Async 0x00000002
  191. // Proxy Authentication types.
  192. //
  193. #define PAT_Text 1
  194. #define PAT_Chap 2
  195. #define PAT_Pap 3
  196. #define PAT_None 4
  197. //-----------------------------------------------------------------------------
  198. // Data types
  199. //-----------------------------------------------------------------------------
  200. // The "Control Connection" state of a single L2TP tunnel.
  201. //
  202. typedef enum
  203. _L2TPCCSTATE
  204. {
  205. CCS_Idle = 0,
  206. CCS_WaitCtlReply,
  207. CCS_WaitCtlConnect,
  208. CCS_Established
  209. }
  210. L2TPCCSTATE;
  211. // The "LNS/LAC Outgoing/Incoming Call" state of a single L2TP VC. Only one
  212. // of the 4 call creation FSMs can be running or Established on a single VC at
  213. // once, so the states are combined in a single table.
  214. //
  215. typedef enum
  216. _L2TPCALLSTATE
  217. {
  218. CS_Idle = 0,
  219. CS_WaitTunnel,
  220. CS_WaitReply,
  221. CS_WaitConnect,
  222. CS_WaitDisconnect,
  223. CS_WaitCsAnswer,
  224. CS_Established
  225. }
  226. L2TPCALLSTATE;
  227. #endif // _L2TPRFC_H_