Leaked source code of windows server 2003
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.

130 lines
5.7 KiB

  1. /********************************************************************/
  2. /** Microsoft LAN Manager **/
  3. /** Copyright(c) Microsoft Corp., 1990-2000 **/
  4. /********************************************************************/
  5. /* :ts=4 */
  6. //** IPINIT.H - IP initialization definitions.
  7. //
  8. // This file contains all of the definitions for IP that are
  9. // init. time specific.
  10. #ifndef _IPINIT_H_
  11. #define _IPINIT_H_ 1
  12. #define IP_INIT_FAILURE 0 // If we fail.
  13. #define IP_INIT_SUCCESS 1
  14. #define CFG_REQUIRED 1
  15. #define CFG_OPTIONAL 0
  16. #define NET_TYPE_LAN 0 // The local net interface is a LAN.
  17. #define NET_TYPE_WAN 1 // Point to point or other non-LAN network.
  18. #define DEFAULT_TTL 128
  19. #define DEFAULT_TOS 0
  20. #define MINIMUM_MAX_NORM_LOOKUP_MEM 100000 // Bytes => A small value
  21. #define MINIMUM_MAX_FAST_LOOKUP_MEM 100000 // Bytes => A small value
  22. // Small System [ 19 MB- Srv ]
  23. #define DEFAULT_MAX_NORM_LOOKUP_MEM_SMALL 150000 // Bytes => ~1000 Routes
  24. #define DEFAULT_MAX_FAST_LOOKUP_MEM_SMALL 0 // FTrie Disabled
  25. #define DEFAULT_EXPN_LEVELS_SMALL 0 // FTrie Disabled
  26. // Medium System [ 19 to 64 MB Srv ]
  27. #define DEFAULT_MAX_NORM_LOOKUP_MEM_MEDIUM 1500000 // Bytes => ~10000 Routes
  28. #define DEFAULT_MAX_FAST_LOOKUP_MEM_MEDIUM 2500000 // Bytes => A 2.5 MB limit
  29. #define DEFAULT_EXPN_LEVELS_MEDIUM 0x80808080 // Levels =>{8, 16, 24, 32}
  30. // Large System [ 64 MB+ Srv ]
  31. #define DEFAULT_MAX_NORM_LOOKUP_MEM_LARGE 5000000 // Bytes => ~40000 Routes
  32. #define DEFAULT_MAX_FAST_LOOKUP_MEM_LARGE 5000000 // Bytes => A 5.0 MB limit
  33. #define DEFAULT_EXPN_LEVELS_LARGE 0x80808080 // Levels =>{8, 16, 24, 32}
  34. #define MAX_DEFAULT_GWS 5 // Maximum number of default gateways per net.
  35. #define MAX_NAME_SIZE 32 // Maximum length of an adapter name.
  36. #define DEFAULT_FW_PACKETS 50 // Default number of packets for forwarding.
  37. #define DEFAULT_FW_BUFSIZE 74240 // Enough for 50 1480-byte Ethernet packets,
  38. // rounded up to a multiple of 256.
  39. #define DEFAULT_MAX_FW_PACKETS 0xffffffff
  40. //#define DEFAULT_MAX_FW_BUFSIZE 0xffffffff
  41. #define DEFAULT_MAX_FW_BUFSIZE 2097152 // put the limit as 2 Mb
  42. #define DEFAULT_MAX_PENDING 5000
  43. #define TR_RII_ALL 0x80
  44. #define TR_RII_SINGLE 0xC0
  45. #define DEFAULT_ARP_CACHE_LIFE (2L*60L) // 2 minutes
  46. #define DEFAULT_ARP_MIN_VALID_CACHE_LIFE (10L*60L) // 10 miniutes
  47. #define DEFAULT_ARP_RETRY_COUNT 1
  48. /*NOINC*/
  49. // Per-net config structures
  50. typedef struct IFGeneralConfig {
  51. uint igc_zerobcast; // Type of broadcast to be used on this net.
  52. uint igc_mtu; // Max MSS for this net.
  53. uint igc_maxpending; // Max FW pending on this IF.
  54. uint igc_numgws; // Number of default gateways for this
  55. // interface.
  56. IPAddr igc_gw[MAX_DEFAULT_GWS]; // Array of IPaddresses for gateways
  57. uint igc_gwmetric[MAX_DEFAULT_GWS];
  58. uint igc_metric; // metric for NTE routes
  59. uchar igc_dfencap;
  60. uchar igc_rtrdiscovery; // Router discovery enabled
  61. IPAddr igc_rtrdiscaddr; // Multicast or BCast?
  62. uint igc_TcpWindowSize; //IF specific window size
  63. uint igc_TcpInitialRTT; // initial rtt in msecs
  64. uchar igc_TcpDelAckTicks; // delayed ack timer in ticks
  65. uchar igc_TcpAckFrequency;// sends before an ack is sent
  66. uchar igc_iftype; // type of interface: allow unicast/mcast/both
  67. uchar igc_disablemediasense; // allow mediasense on interface?
  68. } IFGeneralConfig;
  69. typedef struct IFAddrList {
  70. IPAddr ial_addr; // Address for this interface.
  71. IPMask ial_mask; // Mask to go with this.
  72. } IFAddrList;
  73. /*INC*/
  74. //* Structure of configuration information. A pointer to this information
  75. // is returned from a system-specific config. information routine.
  76. typedef struct IPConfigInfo {
  77. uint ici_gateway; // 1 if we are a gateway, 0 otherwise
  78. uint ici_fwbcast; // 1 if bcasts should be forwarded. Else 0.
  79. uint ici_fwbufsize; // Total size of FW buf size.
  80. uint ici_fwpackets; // Total number of FW packets to have.
  81. uint ici_maxfwbufsize; // Maximum size of FW buffer.
  82. uint ici_maxfwpackets; // Maximum number of FW packets.
  83. uint ici_deadgwdetect; // True if we're doing dead GW detection.
  84. uint ici_pmtudiscovery; // True if we're doing Path MTU discovery.
  85. uint ici_igmplevel; // Level of IGMP we're doing.
  86. uint ici_ttl; // Default TTL.
  87. uint ici_tos; // Default TOS;
  88. uint ici_addrmaskreply; // 0 by default
  89. uint ici_fastroutelookup; // True if we have 'fast route lookup' enabled
  90. uint ici_fastlookuplevels; // Bitmap of levels in the fast lookup scheme
  91. uint ici_maxnormlookupmemory;// Max memory used for the norm lookup scheme
  92. uint ici_maxfastlookupmemory;// Max memory used for the fast lookup scheme
  93. uint ici_TrFunctionalMcst; //Defaults to true, RFC 1469
  94. } IPConfigInfo;
  95. extern uchar TrRii;
  96. typedef struct SetAddrControl {
  97. void *sac_rtn; // Pointer to routine to call when completing request.
  98. void *interface;
  99. ushort nte_context;
  100. BOOLEAN StaticAddr;
  101. } SetAddrControl;
  102. /*NOINC*/
  103. typedef void (*SetAddrRtn)(void *, IP_STATUS);
  104. /*INC*/
  105. #endif // _IPINIT_H_