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.

465 lines
16 KiB

  1. /*++
  2. Copyright (c) 1992 Microsoft Corporation
  3. Module Name:
  4. data.c
  5. Abstract:
  6. This module defines global data for the appletalk transport.
  7. Author:
  8. Jameel Hyder (jameelh@microsoft.com)
  9. Revision History:
  10. 22 Feb 1997 Initial Version
  11. Notes: Tab stop: 4
  12. --*/
  13. #include <atalk.h>
  14. #pragma hdrstop
  15. // File module number for errorlogging
  16. #define FILENUM DATAX
  17. PWCHAR AtalkDeviceNames[] =
  18. {
  19. ATALKDDP_DEVICENAME,
  20. ATALKADSP_DEVICENAME,
  21. ATALKASPS_DEVICENAME,
  22. ATALKPAP_DEVICENAME,
  23. ATALKARAP_DEVICENAME,
  24. ATALKASPC_DEVICENAME
  25. };
  26. PATALK_DEV_OBJ AtalkDeviceObject[ATALK_NO_DEVICES] = {0};
  27. DWORD AtalkBindnUnloadStates = 0;
  28. LONG AtalkTimerCurrentTick = 0;
  29. PTIMERLIST atalkTimerList = NULL;
  30. ATALK_SPIN_LOCK atalkTimerLock = {0};
  31. LARGE_INTEGER atalkTimerTick = {0};
  32. KTIMER atalkTimer = {0};
  33. KDPC atalkTimerDpc = {0};
  34. KEVENT atalkTimerStopEvent = {0};
  35. BOOLEAN atalkTimerStopped = FALSE; // Set to TRUE if timer system stopped
  36. BOOLEAN atalkTimerRunning = FALSE; // Set to TRUE when timer Dpc is running
  37. BOOLEAN atalkRtmpVdtTmrRunning = FALSE;
  38. BOOLEAN atalkZipQryTmrRunning = FALSE;
  39. PRTE * AtalkRoutingTable = NULL; // Allocated at init time
  40. PRTE * AtalkRecentRoutes = NULL; // Allocated at init time
  41. ATALK_SPIN_LOCK AtalkRteLock = {0};
  42. TIMERLIST atalkRtmpVTimer = { 0 };
  43. TIMERLIST atalkZipQTimer = { 0 };
  44. ATALK_SKT_CACHE AtalkSktCache = {0};
  45. ATALK_SPIN_LOCK AtalkSktCacheLock = {0};
  46. PPORT_DESCRIPTOR AtalkPortList = NULL; // Head of the port list
  47. PPORT_DESCRIPTOR AtalkDefaultPort = NULL; // Ptr to the def port
  48. KEVENT AtalkDefaultPortEvent = { 0 }; // Signalled when default port is available
  49. UNICODE_STRING AtalkDefaultPortName = { 0 }; // Name of the default port
  50. ATALK_SPIN_LOCK AtalkPortLock = { 0 }; // Lock for AtalkPortList
  51. ATALK_NODEADDR AtalkUserNode1 = { 0 }; // Node address of user node
  52. ATALK_NODEADDR AtalkUserNode2 = { 0 }; // Node address of user node
  53. SHORT AtalkNumberOfPorts = 0; // Determine dynamically
  54. SHORT AtalkNumberOfActivePorts = 0; // Number of ports active
  55. BOOLEAN AtalkRouter = FALSE; // Are we a router?
  56. BOOLEAN AtalkFilterOurNames = TRUE; // If TRUE, Nbplookup fails on names on this machine
  57. KEVENT AtalkUnloadEvent = {0}; // Event for unloading
  58. NDIS_HANDLE AtalkNdisPacketPoolHandle = NULL;
  59. NDIS_HANDLE AtalkNdisBufferPoolHandle = NULL;
  60. LONG AtalkHandleCount = 0;
  61. UNICODE_STRING AtalkRegPath = { 0 };
  62. HANDLE TdiRegistrationHandle = NULL;
  63. PVOID TdiAddressChangeRegHandle = NULL;
  64. KMUTEX AtalkPgLkMutex = { 0 };
  65. ATALK_SPIN_LOCK AtalkPgLkLock = { 0 };
  66. LOCK_SECTION AtalkPgLkSection[LOCKABLE_SECTIONS] = { 0 };
  67. ATALK_SPIN_LOCK AtalkZoneLock = {0};
  68. PZONE * AtalkZonesTable = NULL;
  69. PZONE AtalkDesiredZone = NULL;
  70. BOOLEAN AtalkNoDefPortPrinted = FALSE; // If no default ATalk port print the message only once
  71. // Values for the 0.5, 1, 2, 4, 8 minute timer in ATP_RELEASE_TIMER_INTERVAL units.
  72. SHORT AtalkAtpRelTimerTicks[MAX_VALID_TIMERS] =
  73. {
  74. 300, 600, 2*600, 4*600, 8*600
  75. };
  76. // Bitmaps for the s=ence numbers in response packets.
  77. BYTE AtpBitmapForSeqNum[ATP_MAX_RESP_PKTS] =
  78. {
  79. 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80
  80. };
  81. BYTE AtpEomBitmapForSeqNum[ATP_MAX_RESP_PKTS] =
  82. {
  83. 0x01, 0x03, 0x07, 0x0F, 0x1F, 0x3F, 0x7F, 0xFF
  84. };
  85. ATALK_SPIN_LOCK atalkAspLock = {0};
  86. ASP_CONN_MAINT atalkAspConnMaint[NUM_ASP_CONN_LISTS] = { 0 };
  87. ASPC_CONN_MAINT atalkAspCConnMaint = { 0 };
  88. ATALK_SPIN_LOCK atalkAspCLock = {0};
  89. PASPC_ADDROBJ atalkAspCAddrList = NULL;
  90. PASPC_CONNOBJ atalkAspCConnList = NULL;
  91. PPAP_ADDROBJ atalkPapAddrList = NULL;
  92. PPAP_CONNOBJ atalkPapConnList = NULL;
  93. TIMERLIST atalkPapCMTTimer = { 0 };
  94. ATALK_SPIN_LOCK atalkPapLock = {0};
  95. NDIS_MEDIUM AtalkSupportedMedia[] =
  96. {
  97. NdisMedium802_3,
  98. NdisMediumFddi,
  99. NdisMedium802_5,
  100. NdisMediumLocalTalk,
  101. NdisMediumWan
  102. };
  103. ULONG AtalkSupportedMediaSize = sizeof(AtalkSupportedMedia)/sizeof(NDIS_MEDIUM);
  104. NDIS_HANDLE AtalkNdisProtocolHandle = NULL;
  105. BYTE AtalkElapBroadcastAddr[ELAP_ADDR_LEN] = ELAP_BROADCAST_ADDR_INIT;
  106. BYTE AtalkAlapBroadcastAddr[] = {0xFF};
  107. BYTE AtalkAarpProtocolType[IEEE8022_PROTO_TYPE_LEN] =
  108. {
  109. 0x00, 0x00, 0x00, 0x80, 0xF3
  110. };
  111. BYTE AtalkAppletalkProtocolType[IEEE8022_PROTO_TYPE_LEN] =
  112. {
  113. 0x08, 0x00, 0x07, 0x80, 0x9B
  114. };
  115. ATALK_NETWORKRANGE AtalkStartupNetworkRange =
  116. {
  117. FIRST_STARTUP_NETWORK, LAST_STARTUP_NETWORK
  118. };
  119. BYTE AtalkEthernetZoneMulticastAddrsHdr[ELAP_MCAST_HDR_LEN] =
  120. {
  121. 0x09, 0x00, 0x07, 0x00, 0x00
  122. };
  123. BYTE AtalkEthernetZoneMulticastAddrs[ELAP_ZONE_MULTICAST_ADDRS] =
  124. {
  125. 0x00 , 0x01 , 0x02 , 0x03 , 0x04 , 0x05 , 0x06 , 0x07 ,
  126. 0x08 , 0x09 , 0x0A , 0x0B , 0x0C , 0x0D , 0x0E , 0x0F ,
  127. 0x10 , 0x11 , 0x12 , 0x13 , 0x14 , 0x15 , 0x16 , 0x17 ,
  128. 0x18 , 0x19 , 0x1A , 0x1B , 0x1C , 0x1D , 0x1E , 0x1F ,
  129. 0x20 , 0x21 , 0x22 , 0x23 , 0x24 , 0x25 , 0x26 , 0x27 ,
  130. 0x28 , 0x29 , 0x2A , 0x2B , 0x2C , 0x2D , 0x2E , 0x2F ,
  131. 0x30 , 0x31 , 0x32 , 0x33 , 0x34 , 0x35 , 0x36 , 0x37 ,
  132. 0x38 , 0x39 , 0x3A , 0x3B , 0x3C , 0x3D , 0x3E , 0x3F ,
  133. 0x40 , 0x41 , 0x42 , 0x43 , 0x44 , 0x45 , 0x46 , 0x47 ,
  134. 0x48 , 0x49 , 0x4A , 0x4B , 0x4C , 0x4D , 0x4E , 0x4F ,
  135. 0x50 , 0x51 , 0x52 , 0x53 , 0x54 , 0x55 , 0x56 , 0x57 ,
  136. 0x58 , 0x59 , 0x5A , 0x5B , 0x5C , 0x5D , 0x5E , 0x5F ,
  137. 0x60 , 0x61 , 0x62 , 0x63 , 0x64 , 0x65 , 0x66 , 0x67 ,
  138. 0x68 , 0x69 , 0x6A , 0x6B , 0x6C , 0x6D , 0x6E , 0x6F ,
  139. 0x70 , 0x71 , 0x72 , 0x73 , 0x74 , 0x75 , 0x76 , 0x77 ,
  140. 0x78 , 0x79 , 0x7A , 0x7B , 0x7C , 0x7D , 0x7E , 0x7F ,
  141. 0x80 , 0x81 , 0x82 , 0x83 , 0x84 , 0x85 , 0x86 , 0x87 ,
  142. 0x88 , 0x89 , 0x8A , 0x8B , 0x8C , 0x8D , 0x8E , 0x8F ,
  143. 0x90 , 0x91 , 0x92 , 0x93 , 0x94 , 0x95 , 0x96 , 0x97 ,
  144. 0x98 , 0x99 , 0x9A , 0x9B , 0x9C , 0x9D , 0x9E , 0x9F ,
  145. 0xA0 , 0xA1 , 0xA2 , 0xA3 , 0xA4 , 0xA5 , 0xA6 , 0xA7 ,
  146. 0xA8 , 0xA9 , 0xAA , 0xAB , 0xAC , 0xAD , 0xAE , 0xAF ,
  147. 0xB0 , 0xB1 , 0xB2 , 0xB3 , 0xB4 , 0xB5 , 0xB6 , 0xB7 ,
  148. 0xB8 , 0xB9 , 0xBA , 0xBB , 0xBC , 0xBD , 0xBE , 0xBF ,
  149. 0xC0 , 0xC1 , 0xC2 , 0xC3 , 0xC4 , 0xC5 , 0xC6 , 0xC7 ,
  150. 0xC8 , 0xC9 , 0xCA , 0xCB , 0xCC , 0xCD , 0xCE , 0xCF ,
  151. 0xD0 , 0xD1 , 0xD2 , 0xD3 , 0xD4 , 0xD5 , 0xD6 , 0xD7 ,
  152. 0xD8 , 0xD9 , 0xDA , 0xDB , 0xDC , 0xDD , 0xDE , 0xDF ,
  153. 0xE0 , 0xE1 , 0xE2 , 0xE3 , 0xE4 , 0xE5 , 0xE6 , 0xE7 ,
  154. 0xE8 , 0xE9 , 0xEA , 0xEB , 0xEC , 0xED , 0xEE , 0xEF ,
  155. 0xF0 , 0xF1 , 0xF2 , 0xF3 , 0xF4 , 0xF5 , 0xF6 , 0xF7 ,
  156. 0xF8 , 0xF9 , 0xFA , 0xFB , 0xFC
  157. };
  158. BYTE AtalkTokenRingZoneMulticastAddrsHdr[TLAP_MCAST_HDR_LEN] = { 0xC0, 0x00 };
  159. BYTE AtalkTokenRingZoneMulticastAddrs[TLAP_ZONE_MULTICAST_ADDRS]
  160. [TLAP_ADDR_LEN - TLAP_MCAST_HDR_LEN] =
  161. {
  162. { 0x00, 0x00, 0x08, 0x00 },
  163. { 0x00, 0x00, 0x10, 0x00 },
  164. { 0x00, 0x00, 0x20, 0x00 },
  165. { 0x00, 0x00, 0x40, 0x00 },
  166. { 0x00, 0x00, 0x80, 0x00 },
  167. { 0x00, 0x01, 0x00, 0x00 },
  168. { 0x00, 0x02, 0x00, 0x00 },
  169. { 0x00, 0x04, 0x00, 0x00 },
  170. { 0x00, 0x08, 0x00, 0x00 },
  171. { 0x00, 0x10, 0x00, 0x00 },
  172. { 0x00, 0x20, 0x00, 0x00 },
  173. { 0x00, 0x40, 0x00, 0x00 },
  174. { 0x00, 0x80, 0x00, 0x00 },
  175. { 0x01, 0x00, 0x00, 0x00 },
  176. { 0x02, 0x00, 0x00, 0x00 },
  177. { 0x04, 0x00, 0x00, 0x00 },
  178. { 0x08, 0x00, 0x00, 0x00 },
  179. { 0x10, 0x00, 0x00, 0x00 },
  180. { 0x20, 0x00, 0x00, 0x00 }
  181. };
  182. BYTE AtalkTlapBroadcastAddr[TLAP_ADDR_LEN] = TLAP_BROADCAST_ADDR_INIT;
  183. //
  184. // Static "source routing" info for a TokenRing broadcast/multicast packet;
  185. // the following values are set: single-route broadcast, 2 bytes of routing
  186. // info, outgoing packet, broadcast (bigo) frame size.
  187. //
  188. BYTE AtalkBroadcastRouteInfo[TLAP_MIN_ROUTING_BYTES] = { 0xC2, 0x70 };
  189. //
  190. // Same stuff for a non-broadcast packet's simple routing info; the following
  191. // values are set: non-broadcast, 2 bytes of routing info, outgoing packet,
  192. //
  193. // 802.5-style frame.
  194. BYTE AtalkSimpleRouteInfo[TLAP_MIN_ROUTING_BYTES] = { 0x02, 0x30 };
  195. //
  196. // The following may not really be safe, but, we'll make the assumption that
  197. // all outgoing TokenTalk packets whos destination address starts with "0xC0
  198. // 0x00" are broadcast (or multicast). Further, we assume that no packets
  199. // that are intended to be boradcast/multicast will fail to meet this test.
  200. // If this proves not to be the case, we'll need to find a new way to determine
  201. // this from the destination address, or introduce a new perameter to the
  202. // various "buildHeader" routines. This is all for "source routing" support.
  203. //
  204. BYTE AtalkBroadcastDestHdr[TLAP_BROADCAST_DEST_LEN] = { 0xC0, 0x00};
  205. PORT_HANDLERS AtalkPortHandlers[LAST_PORTTYPE] =
  206. {
  207. {
  208. AtalkNdisAddMulticast,
  209. AtalkNdisRemoveMulticast,
  210. ELAP_BROADCAST_ADDR_INIT,
  211. MAX_HW_ADDR_LEN,
  212. AARP_ELAP_HW_TYPE,
  213. AARP_ATALK_PROTO_TYPE
  214. },
  215. {
  216. AtalkNdisAddMulticast,
  217. AtalkNdisRemoveMulticast,
  218. ELAP_BROADCAST_ADDR_INIT,
  219. MAX_HW_ADDR_LEN,
  220. AARP_ELAP_HW_TYPE,
  221. AARP_ATALK_PROTO_TYPE
  222. },
  223. {
  224. AtalkNdisAddFunctional,
  225. AtalkNdisRemoveFunctional,
  226. TLAP_BROADCAST_ADDR_INIT,
  227. MAX_HW_ADDR_LEN,
  228. AARP_TLAP_HW_TYPE,
  229. AARP_ATALK_PROTO_TYPE
  230. },
  231. {
  232. NULL,
  233. NULL,
  234. ALAP_BROADCAST_ADDR_INIT,
  235. 1,
  236. 0,
  237. 0
  238. },
  239. {
  240. NULL,
  241. NULL,
  242. ARAP_BROADCAST_ADDR_INIT,
  243. 1,
  244. 0,
  245. 0
  246. }
  247. };
  248. ATALK_STATS AtalkStatistics = {0};
  249. ATALK_SPIN_LOCK AtalkStatsLock = {0};
  250. // The following table ia taken from page D-3 of the Inside AppleTalk manual.
  251. BYTE AtalkUpCaseTable[256] =
  252. {
  253. 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, // 0x00 - 0x07
  254. 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F, // 0x08 - 0x0F
  255. 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, // 0x10 - 0x17
  256. 0x18, 0x19, 0x1A, 0x1B, 0x1C, 0x1D, 0x1E, 0x1F, // 0x18 - 0x1F
  257. 0x20, 0x21, 0x22, 0x23, 0x24, 0x25, 0x26, 0x27, // 0x20 - 0x27
  258. 0x28, 0x29, 0x2A, 0x2B, 0x2C, 0x2D, 0x2E, 0x2F, // 0x28 - 0x2F
  259. 0x30, 0x31, 0x32, 0x33, 0x34, 0x35, 0x36, 0x37, // 0x30 - 0x37
  260. 0x38, 0x39, 0x3A, 0x3B, 0x3C, 0x3D, 0x3E, 0x3F, // 0x38 - 0x3F
  261. 0x40, 0x41, 0x42, 0x43, 0x44, 0x45, 0x46, 0x47, // 0x40 - 0x47
  262. 0x48, 0x49, 0x4A, 0x4B, 0x4C, 0x4D, 0x4E, 0x4F, // 0x48 - 0x4F
  263. 0x50, 0x51, 0x52, 0x53, 0x54, 0x55, 0x56, 0x57, // 0x50 - 0x57
  264. 0x58, 0x59, 0x5A, 0x5B, 0x5C, 0x5D, 0x5E, 0x5F, // 0x58 - 0x5F
  265. 0x60, 0x41, 0x42, 0x43, 0x44, 0x45, 0x46, 0x47, // 0x60 - 0x67
  266. 0x48, 0x49, 0x4A, 0x4B, 0x4C, 0x4D, 0x4E, 0x4F, // 0x68 - 0x6F
  267. 0x50, 0x51, 0x52, 0x53, 0x54, 0x55, 0x56, 0x57, // 0x70 - 0x77
  268. 0x58, 0x59, 0x5A, 0x7B, 0x7C, 0x7D, 0x7E, 0x7F, // 0x78 - 0x7F
  269. 0x80, 0x81, 0x82, 0x83, 0x84, 0x85, 0x86, 0x87, // 0x80 - 0x87
  270. 0xCB, 0x89, 0x80, 0xCC, 0x81, 0x82, 0x83, 0x8F, // 0x88 - 0x8F
  271. 0x90, 0x91, 0x92, 0x93, 0x94, 0x95, 0x84, 0x97, // 0x90 - 0x97
  272. 0x98, 0x99, 0x85, 0xCD, 0x9C, 0x9D, 0x9E, 0x86, // 0x98 - 0x9F
  273. 0xA0, 0xA1, 0xA2, 0xA3, 0xA4, 0xA5, 0xA6, 0xA7, // 0xA0 - 0xA7
  274. 0xA8, 0xA9, 0xAA, 0xAB, 0xAC, 0xAD, 0xAE, 0xAF, // 0xA8 - 0xAF
  275. 0xB0, 0xB1, 0xB2, 0xB3, 0xB4, 0xB5, 0xB6, 0xB7, // 0xB0 - 0xB7
  276. 0xB8, 0xB9, 0xBA, 0xBB, 0xBC, 0xBD, 0xAE, 0xAF, // 0xB8 - 0xBF
  277. 0xC0, 0xC1, 0xC2, 0xC3, 0xC4, 0xC5, 0xC6, 0xC7, // 0xC0 - 0xC7
  278. 0xC8, 0xC9, 0xCA, 0xCB, 0xCC, 0xCB, 0xCE, 0xCE, // 0xC8 - 0xCF
  279. 0xD0, 0xD1, 0xD2, 0xD3, 0xD4, 0xD5, 0xD6, 0xD7, // 0xD0 - 0xD7
  280. 0xD8, 0xD9, 0xDA, 0xDB, 0xDC, 0xDD, 0xDE, 0xDF, // 0xD8 - 0xDF
  281. 0xE0, 0xE1, 0xE2, 0xE3, 0xE4, 0xE5, 0xE6, 0xE7, // 0xE0 - 0xE7
  282. 0xE8, 0xE9, 0xEA, 0xEB, 0xEC, 0xED, 0xEE, 0xEF, // 0xE8 - 0xEF
  283. 0xF0, 0xF1, 0xF2, 0xF3, 0xF4, 0xF5, 0xF6, 0xF7, // 0xF0 - 0xF7
  284. 0xF8, 0xF9, 0xFA, 0xFB, 0xFC, 0xFD, 0xFE, 0xFF // 0xF8 - 0xFF
  285. };
  286. USHORT atalkBlkSize[NUM_BLKIDS] = // Size of each block
  287. {
  288. BLOCK_SIZE(sizeof(BUFFER_DESC)), // BLKID_BUFFDESC
  289. BLOCK_SIZE(sizeof(AMT)), // BLKID_AMT
  290. BLOCK_SIZE(sizeof(AMT)+MAX_ROUTING_SPACE), // BLKID_AMT_ROUTE
  291. BLOCK_SIZE(sizeof(BRE)), // BLKID_BRE
  292. BLOCK_SIZE(sizeof(BRE)+MAX_ROUTING_SPACE), // BLKID_BRE_ROUTE
  293. BLOCK_SIZE(sizeof(ATP_REQ)), // BLKID_ATPREQ
  294. BLOCK_SIZE(sizeof(ATP_RESP)), // BLKID_ATPRESP
  295. BLOCK_SIZE(sizeof(ASP_REQUEST)), // BLKID_ASPREQ
  296. BLOCK_SIZE(sizeof(ARAPBUF)+ARAP_SMPKT_SIZE), // BLKID_ARAP_SMPKT
  297. BLOCK_SIZE(sizeof(ARAPBUF)+ARAP_MDPKT_SIZE), // BLKID_ARAP_MDPKT
  298. BLOCK_SIZE(sizeof(ARAPBUF)+ARAP_LGPKT_SIZE), // BLKID_ARAP_LGPKT
  299. BLOCK_SIZE(ARAP_SENDBUF_SIZE), // BLKID_ARAP_SNDPKT
  300. BLOCK_SIZE(sizeof(ARAPBUF)+ARAP_LGBUF_SIZE), // BLKID_ARAP_LGBUF
  301. BLOCK_SIZE(sizeof(AARP_BUFFER)), // BLKID_AARP
  302. BLOCK_SIZE(sizeof(DDP_SMBUFFER)), // BLKID_DDPSM
  303. BLOCK_SIZE(sizeof(DDP_LGBUFFER)), // BLKID_DDPLG
  304. BLOCK_SIZE(sizeof(SENDBUF)), // BLKID_SENDBUF
  305. BLOCK_SIZE(sizeof(MNPSENDBUF)+MNP_MINSEND_LEN), // BLKID_MNP_SMSENDBUF
  306. BLOCK_SIZE(sizeof(MNPSENDBUF)+MNP_MAXSEND_LEN) // BLKID_MNP_LGSENDBUF
  307. };
  308. USHORT atalkChunkSize[NUM_BLKIDS] = // Size of each Chunk
  309. {
  310. SM_BLK-BC_OVERHEAD, // BLKID_BUFFDESC
  311. SM_BLK-BC_OVERHEAD, // BLKID_AMT
  312. SM_BLK-BC_OVERHEAD, // BLKID_AMT_ROUTE
  313. SM_BLK-BC_OVERHEAD, // BLKID_BRE
  314. SM_BLK-BC_OVERHEAD, // BLKID_BRE_ROUTE
  315. LG_BLK-BC_OVERHEAD, // BLKID_ATPREQ
  316. LG_BLK-BC_OVERHEAD, // BLKID_ATPRESP
  317. LG_BLK-BC_OVERHEAD, // BLKID_ASPREQ
  318. SM_BLK-BC_OVERHEAD, // BLKID_ARAP_SMPKT
  319. SM_BLK-BC_OVERHEAD, // BLKID_ARAP_MDPKT
  320. LG_BLK-BC_OVERHEAD, // BLKID_ARAP_LGPKT
  321. XL_BLK-BC_OVERHEAD, // BLKID_ARAP_SNDPKT
  322. XL_BLK-BC_OVERHEAD, // BLKID_ARAP_LGBUF
  323. SM_BLK-BC_OVERHEAD, // BLKID_AARP
  324. SM_BLK-BC_OVERHEAD, // BLKID_DDPSM
  325. XL_BLK-BC_OVERHEAD, // BLKID_DDPLG
  326. LG_BLK-BC_OVERHEAD, // BLKID_SENDBUF
  327. SM_BLK-BC_OVERHEAD, // BLKID_MNP_SMSENDBUF
  328. LG_BLK-BC_OVERHEAD // BLKID_MNP_LGSENDBUF
  329. };
  330. BYTE atalkNumBlks[NUM_BLKIDS] = // Number of blocks per chunk
  331. {
  332. NUM_BLOCKS(sizeof(BUFFER_DESC), SM_BLK), // BLKID_BUFFDESC
  333. NUM_BLOCKS(sizeof(AMT), SM_BLK), // BLKID_AMT
  334. NUM_BLOCKS(sizeof(AMT)+MAX_ROUTING_SPACE,SM_BLK), // BLKID_AMT_ROUTE
  335. NUM_BLOCKS(sizeof(BRE), SM_BLK), // BLKID_BRE
  336. NUM_BLOCKS(sizeof(BRE)+MAX_ROUTING_SPACE,SM_BLK), // BLKID_BRE_ROUTE
  337. NUM_BLOCKS(sizeof(ATP_REQ), LG_BLK), // BLKID_ATPREQ
  338. NUM_BLOCKS(sizeof(ATP_RESP), LG_BLK), // BLKID_ATPRESP
  339. NUM_BLOCKS(sizeof(ASP_REQUEST), LG_BLK), // BLKID_ASPREQ
  340. NUM_BLOCKS(sizeof(ARAPBUF)+ARAP_SMPKT_SIZE,SM_BLK), // BLKID_ARAP_SMPKT
  341. NUM_BLOCKS(sizeof(ARAPBUF)+ARAP_MDPKT_SIZE,SM_BLK), // BLKID_ARAP_MDPKT
  342. NUM_BLOCKS(sizeof(ARAPBUF)+ARAP_LGPKT_SIZE,LG_BLK), // BLKID_ARAP_LGPKT
  343. NUM_BLOCKS(ARAP_SENDBUF_SIZE,XL_BLK), // BLKID_ARAP_SNDPKT
  344. NUM_BLOCKS(sizeof(ARAPBUF)+ARAP_LGBUF_SIZE,XL_BLK), // BLKID_ARAP_LGBUF
  345. NUM_BLOCKS(sizeof(AARP_BUFFER), SM_BLK), // BLKID_AARP
  346. NUM_BLOCKS(sizeof(DDP_SMBUFFER), SM_BLK), // BLKID_DDPSM
  347. NUM_BLOCKS(sizeof(DDP_LGBUFFER), XL_BLK), // BLKID_DDPLG
  348. NUM_BLOCKS(sizeof(SENDBUF), LG_BLK), // BLKID_SENDBUF
  349. NUM_BLOCKS(sizeof(MNPSENDBUF)+MNP_MINSEND_LEN,SM_BLK), // BLKID_MNP_SMSENDBUF
  350. NUM_BLOCKS(sizeof(MNPSENDBUF)+MNP_MAXSEND_LEN,LG_BLK) // BLKID_MNP_LGSENDBUF
  351. };
  352. ATALK_SPIN_LOCK atalkBPLock[NUM_BLKIDS] = { 0 };
  353. PBLK_CHUNK atalkBPHead[NUM_BLKIDS] = { 0 };
  354. TIMERLIST atalkBPTimer = { 0 };
  355. // List of all adsp address/connection objects.
  356. PADSP_ADDROBJ atalkAdspAddrList = NULL;
  357. PADSP_CONNOBJ atalkAdspConnList = NULL;
  358. ATALK_SPIN_LOCK atalkAdspLock = {0};
  359. //
  360. // ARAP data
  361. //
  362. struct _PORT_DESCRIPTOR *RasPortDesc EQU NULL;
  363. // spinlock to guard the all the Arap global things
  364. ATALK_SPIN_LOCK ArapSpinLock;
  365. // global configuration info
  366. ARAPGLOB ArapGlobs EQU {0};
  367. PIRP ArapSelectIrp EQU NULL;
  368. DWORD ArapConnections EQU 0;
  369. DWORD ArapStackState EQU ARAP_STATE_INACTIVE_WAITING;
  370. DWORD PPPConnections EQU 0;
  371. #if DBG
  372. ATALK_SPIN_LOCK AtalkDebugSpinLock;
  373. DWORD AtalkDbgMdlsAlloced EQU 0;
  374. DWORD AtalkDbgIrpsAlloced EQU 0;
  375. ULONG AtalkDebugDump = 0;
  376. LONG AtalkDumpInterval = DBG_DUMP_DEF_INTERVAL;
  377. ULONG AtalkDebugLevel = DBG_LEVEL_ERR;
  378. ULONG AtalkDebugSystems = DBG_MOST;
  379. TIMERLIST AtalkDumpTimerList = { 0 };
  380. LONG AtalkMemLimit = 10*1024*1024;
  381. LONG atalkNumChunksForId[NUM_BLKIDS] = { 0 };
  382. LONG atalkBlksForId[NUM_BLKIDS] = { 0 };
  383. PIRP ArapSniffIrp = NULL;
  384. ARAPSTATS ArapStatistics = {0,0,10000,10000,0,10000};
  385. DWORD ArapDumpLevel = 0;
  386. DWORD ArapDumpLen = 64;
  387. DWORD ArapDbgMnpSendSizes[30] = {0};
  388. DWORD ArapDbgMnpRecvSizes[30] = {0};
  389. DWORD ArapDbgArapSendSizes[15] = {0};
  390. DWORD ArapDbgArapRecvSizes[15] = {0};
  391. LARGE_INTEGER ArapDbgLastTraceTime;
  392. UCHAR ArapDbgLRPacket[30] = {0x1d,1,2,1,6,1,0,0,0,0,0xff,2,1,2,3,
  393. 1,8,4,2,0x40,0,8,1,3,0xe,4,3,0,8,0xfa};
  394. #endif