source: Daodan/MSYS2/mingw32/i686-w64-mingw32/include/iprtrmib.h@ 1181

Last change on this file since 1181 was 1166, checked in by rossy, 3 years ago

Daodan: Replace MinGW build env with an up-to-date MSYS2 env

File size: 21.6 KB
Line 
1/**
2 * This file has no copyright assigned and is placed in the Public Domain.
3 * This file is part of the mingw-w64 runtime package.
4 * No warranty is given; refer to the file DISCLAIMER.PD within this package.
5 */
6#ifndef __ROUTING_IPRTRMIB_H__
7#define __ROUTING_IPRTRMIB_H__
8
9#include <winapifamily.h>
10#if WINAPI_FAMILY_PARTITION (WINAPI_PARTITION_DESKTOP)
11
12#include <mprapi.h>
13#include <ipmib.h>
14#include <ipifcons.h>
15#include <udpmib.h>
16#include <tcpmib.h>
17
18#define IPRTRMGR_PID 10000
19
20#ifndef ANY_SIZE
21#define ANY_SIZE 1
22#endif
23
24#define TCPIP_OWNING_MODULE_SIZE 16
25
26#define IF_NUMBER 0
27#define IF_TABLE (IF_NUMBER + 1)
28#define IF_ROW (IF_TABLE + 1)
29#define IP_STATS (IF_ROW + 1)
30#define IP_ADDRTABLE (IP_STATS + 1)
31#define IP_ADDRROW (IP_ADDRTABLE + 1)
32#define IP_FORWARDNUMBER (IP_ADDRROW + 1)
33#define IP_FORWARDTABLE (IP_FORWARDNUMBER + 1)
34#define IP_FORWARDROW (IP_FORWARDTABLE + 1)
35#define IP_NETTABLE (IP_FORWARDROW + 1)
36#define IP_NETROW (IP_NETTABLE + 1)
37#define ICMP_STATS (IP_NETROW + 1)
38#define TCP_STATS (ICMP_STATS + 1)
39#define TCP_TABLE (TCP_STATS + 1)
40#define TCP_ROW (TCP_TABLE + 1)
41#define UDP_STATS (TCP_ROW + 1)
42#define UDP_TABLE (UDP_STATS + 1)
43#define UDP_ROW (UDP_TABLE + 1)
44#define MCAST_MFE (UDP_ROW + 1)
45#define MCAST_MFE_STATS (MCAST_MFE + 1)
46#define BEST_IF (MCAST_MFE_STATS + 1)
47#define BEST_ROUTE (BEST_IF + 1)
48#define PROXY_ARP (BEST_ROUTE + 1)
49#define MCAST_IF_ENTRY (PROXY_ARP + 1)
50#define MCAST_GLOBAL (MCAST_IF_ENTRY + 1)
51#define IF_STATUS (MCAST_GLOBAL + 1)
52#define MCAST_BOUNDARY (IF_STATUS + 1)
53#define MCAST_SCOPE (MCAST_BOUNDARY + 1)
54#define DEST_MATCHING (MCAST_SCOPE + 1)
55#define DEST_LONGER (DEST_MATCHING + 1)
56#define DEST_SHORTER (DEST_LONGER + 1)
57#define ROUTE_MATCHING (DEST_SHORTER + 1)
58#define ROUTE_LONGER (ROUTE_MATCHING + 1)
59#define ROUTE_SHORTER (ROUTE_LONGER + 1)
60#define ROUTE_STATE (ROUTE_SHORTER + 1)
61#define MCAST_MFE_STATS_EX (ROUTE_STATE + 1)
62#define IP6_STATS (MCAST_MFE_STATS_EX + 1)
63#define UDP6_STATS (IP6_STATS + 1)
64#define TCP6_STATS (UDP6_STATS + 1)
65
66#define NUMBER_OF_EXPORTED_VARIABLES (TCP6_STATS + 1)
67
68typedef struct _MIB_OPAQUE_QUERY {
69 DWORD dwVarId;
70 DWORD rgdwVarIndex[ANY_SIZE];
71} MIB_OPAQUE_QUERY,*PMIB_OPAQUE_QUERY;
72
73typedef struct _MIB_IFNUMBER {
74 DWORD dwValue;
75} MIB_IFNUMBER,*PMIB_IFNUMBER;
76
77#define MAXLEN_IFDESCR 256
78#define MAXLEN_PHYSADDR 8
79
80typedef struct _MIB_IFROW {
81 WCHAR wszName[MAX_INTERFACE_NAME_LEN];
82 DWORD dwIndex;
83 DWORD dwType;
84 DWORD dwMtu;
85 DWORD dwSpeed;
86 DWORD dwPhysAddrLen;
87 BYTE bPhysAddr[MAXLEN_PHYSADDR];
88 DWORD dwAdminStatus;
89 DWORD dwOperStatus;
90 DWORD dwLastChange;
91 DWORD dwInOctets;
92 DWORD dwInUcastPkts;
93 DWORD dwInNUcastPkts;
94 DWORD dwInDiscards;
95 DWORD dwInErrors;
96 DWORD dwInUnknownProtos;
97 DWORD dwOutOctets;
98 DWORD dwOutUcastPkts;
99 DWORD dwOutNUcastPkts;
100 DWORD dwOutDiscards;
101 DWORD dwOutErrors;
102 DWORD dwOutQLen;
103 DWORD dwDescrLen;
104 BYTE bDescr[MAXLEN_IFDESCR];
105} MIB_IFROW,*PMIB_IFROW;
106
107typedef struct _MIB_IFTABLE {
108 DWORD dwNumEntries;
109 MIB_IFROW table[ANY_SIZE];
110} MIB_IFTABLE,*PMIB_IFTABLE;
111
112#define SIZEOF_IFTABLE(X) (FIELD_OFFSET(MIB_IFTABLE,table[0]) + ((X) *sizeof(MIB_IFROW)) + ALIGN_SIZE)
113
114typedef struct _MIBICMPSTATS {
115 DWORD dwMsgs;
116 DWORD dwErrors;
117 DWORD dwDestUnreachs;
118 DWORD dwTimeExcds;
119 DWORD dwParmProbs;
120 DWORD dwSrcQuenchs;
121 DWORD dwRedirects;
122 DWORD dwEchos;
123 DWORD dwEchoReps;
124 DWORD dwTimestamps;
125 DWORD dwTimestampReps;
126 DWORD dwAddrMasks;
127 DWORD dwAddrMaskReps;
128} MIBICMPSTATS,*PMIBICMPSTATS;
129
130typedef struct _MIBICMPINFO {
131 MIBICMPSTATS icmpInStats;
132 MIBICMPSTATS icmpOutStats;
133} MIBICMPINFO;
134
135typedef struct _MIB_ICMP {
136 MIBICMPINFO stats;
137} MIB_ICMP,*PMIB_ICMP;
138
139typedef enum {
140 ICMP6_DST_UNREACH = 1,ICMP6_PACKET_TOO_BIG = 2,ICMP6_TIME_EXCEEDED = 3,ICMP6_PARAM_PROB = 4,ICMP6_ECHO_REQUEST = 128,
141 ICMP6_ECHO_REPLY = 129,ICMP6_MEMBERSHIP_QUERY = 130,ICMP6_MEMBERSHIP_REPORT = 131,ICMP6_MEMBERSHIP_REDUCTION = 132,
142 ND_ROUTER_SOLICIT = 133,ND_ROUTER_ADVERT = 134,ND_NEIGHBOR_SOLICIT = 135,ND_NEIGHBOR_ADVERT = 136,ND_REDIRECT = 137
143} ICMP6_TYPE,*PICMP6_TYPE;
144
145typedef enum {
146 ICMP4_ECHO_REPLY = 0,ICMP4_DST_UNREACH = 3,ICMP4_SOURCE_QUENCH = 4,ICMP4_REDIRECT = 5,ICMP4_ECHO_REQUEST = 8,ICMP4_ROUTER_ADVERT = 9,
147 ICMP4_ROUTER_SOLICIT = 10,ICMP4_TIME_EXCEEDED = 11,ICMP4_PARAM_PROB = 12,ICMP4_TIMESTAMP_REQUEST = 13,ICMP4_TIMESTAMP_REPLY = 14,
148 ICMP4_MASK_REQUEST = 17,ICMP4_MASK_REPLY = 18
149} ICMP4_TYPE,*PICMP4_TYPE;
150
151typedef struct _MIBICMPSTATS_EX {
152 DWORD dwMsgs;
153 DWORD dwErrors;
154 DWORD rgdwTypeCount[256];
155} MIBICMPSTATS_EX,*PMIBICMPSTATS_EX;
156
157typedef struct _MIB_ICMP_EX {
158 MIBICMPSTATS_EX icmpInStats;
159 MIBICMPSTATS_EX icmpOutStats;
160} MIB_ICMP_EX,*PMIB_ICMP_EX;
161
162typedef struct _MIB_UDPSTATS {
163 DWORD dwInDatagrams;
164 DWORD dwNoPorts;
165 DWORD dwInErrors;
166 DWORD dwOutDatagrams;
167 DWORD dwNumAddrs;
168} MIB_UDPSTATS,*PMIB_UDPSTATS;
169
170typedef struct _MIB_UDPROW {
171 DWORD dwLocalAddr;
172 DWORD dwLocalPort;
173} MIB_UDPROW,*PMIB_UDPROW;
174
175typedef MIB_UDPROW MIB_UDPROW_BASIC,*PMIB_UDPROW_BASIC;
176
177typedef struct _MIB_UDPROW_OWNER_PID {
178 DWORD dwLocalAddr;
179 DWORD dwLocalPort;
180 DWORD dwOwningPid;
181} MIB_UDPROW_OWNER_PID,*PMIB_UDPROW_OWNER_PID;
182
183typedef struct _MIB_UDPROW_OWNER_MODULE {
184 DWORD dwLocalAddr;
185 DWORD dwLocalPort;
186 DWORD dwOwningPid;
187 LARGE_INTEGER liCreateTimestamp;
188 __C89_NAMELESS union {
189 __C89_NAMELESS struct {
190 DWORD SpecificPortBind : 1;
191 };
192 DWORD dwFlags;
193 };
194 ULONGLONG OwningModuleInfo[TCPIP_OWNING_MODULE_SIZE];
195} MIB_UDPROW_OWNER_MODULE,*PMIB_UDPROW_OWNER_MODULE;
196
197typedef struct _MIB_UDP6ROW_OWNER_PID {
198 UCHAR ucLocalAddr[16];
199 DWORD dwLocalScopeId;
200 DWORD dwLocalPort;
201 DWORD dwOwningPid;
202} MIB_UDP6ROW_OWNER_PID,*PMIB_UDP6ROW_OWNER_PID;
203
204typedef struct _MIB_UDP6ROW_OWNER_MODULE {
205 UCHAR ucLocalAddr[16];
206 DWORD dwLocalScopeId;
207 DWORD dwLocalPort;
208 DWORD dwOwningPid;
209 LARGE_INTEGER liCreateTimestamp;
210 __C89_NAMELESS union {
211 __C89_NAMELESS struct {
212 DWORD SpecificPortBind : 1;
213 };
214 DWORD dwFlags;
215 };
216 ULONGLONG OwningModuleInfo[TCPIP_OWNING_MODULE_SIZE];
217} MIB_UDP6ROW_OWNER_MODULE,*PMIB_UDP6ROW_OWNER_MODULE;
218
219typedef struct _MIB_UDPTABLE {
220 DWORD dwNumEntries;
221 MIB_UDPROW table[ANY_SIZE];
222} MIB_UDPTABLE,*PMIB_UDPTABLE;
223
224typedef MIB_UDPTABLE MIB_UDPTABLE_BASIC,*PMIB_UDPTABLE_BASIC;
225
226#define SIZEOF_UDPTABLE(X) (FIELD_OFFSET(MIB_UDPTABLE,table[0]) + ((X) *sizeof(MIB_UDPROW)) + ALIGN_SIZE)
227#define SIZEOF_UDPTABLE_BASIC(X) SIZEOF_UDPTABLE(X)
228
229typedef struct _MIB_UDPTABLE_OWNER_PID {
230 DWORD dwNumEntries;
231 MIB_UDPROW_OWNER_PID table[ANY_SIZE];
232} MIB_UDPTABLE_OWNER_PID,*PMIB_UDPTABLE_OWNER_PID;
233
234#define SIZEOF_UDPTABLE_OWNER_PID(X) (FIELD_OFFSET(MIB_UDPTABLE_OWNER_PID,table[0]) + ((X) *sizeof(MIB_UDPROW_OWNER_PID)) + ALIGN_SIZE)
235
236typedef struct _MIB_UDPTABLE_OWNER_MODULE {
237 DWORD dwNumEntries;
238 MIB_UDPROW_OWNER_MODULE table[ANY_SIZE];
239} MIB_UDPTABLE_OWNER_MODULE,*PMIB_UDPTABLE_OWNER_MODULE;
240
241#define SIZEOF_UDPTABLE_OWNER_MODULE(X) (FIELD_OFFSET(MIB_UDPTABLE_OWNER_MODULE,table[0]) + ((X) *sizeof(MIB_UDPROW_OWNER_MODULE)) + ALIGN_SIZE)
242
243typedef struct _MIB_UDP6TABLE_OWNER_PID {
244 DWORD dwNumEntries;
245 MIB_UDP6ROW_OWNER_PID table[ANY_SIZE];
246} MIB_UDP6TABLE_OWNER_PID,*PMIB_UDP6TABLE_OWNER_PID;
247
248#define SIZEOF_UDP6TABLE_OWNER_PID(X) (FIELD_OFFSET(MIB_UDP6TABLE_OWNER_PID,table[0]) + ((X) *sizeof(MIB_UDP6ROW_OWNER_PID)) + ALIGN_SIZE)
249
250typedef struct _MIB_UDP6TABLE_OWNER_MODULE {
251 DWORD dwNumEntries;
252 MIB_UDP6ROW_OWNER_MODULE table[ANY_SIZE];
253} MIB_UDP6TABLE_OWNER_MODULE,*PMIB_UDP6TABLE_OWNER_MODULE;
254
255#define SIZEOF_UDP6TABLE_OWNER_MODULE(X) (FIELD_OFFSET(MIB_UDP6TABLE_OWNER_MODULE,table[0]) + ((X) *sizeof(MIB_UDP6ROW_OWNER_MODULE)) + ALIGN_SIZE)
256
257typedef struct _MIB_TCPSTATS {
258 DWORD dwRtoAlgorithm;
259 DWORD dwRtoMin;
260 DWORD dwRtoMax;
261 DWORD dwMaxConn;
262 DWORD dwActiveOpens;
263 DWORD dwPassiveOpens;
264 DWORD dwAttemptFails;
265 DWORD dwEstabResets;
266 DWORD dwCurrEstab;
267 DWORD dwInSegs;
268 DWORD dwOutSegs;
269 DWORD dwRetransSegs;
270 DWORD dwInErrs;
271 DWORD dwOutRsts;
272 DWORD dwNumConns;
273} MIB_TCPSTATS,*PMIB_TCPSTATS;
274
275#define MIB_TCP_RTO_OTHER 1
276#define MIB_TCP_RTO_CONSTANT 2
277#define MIB_TCP_RTO_RSRE 3
278#define MIB_TCP_RTO_VANJ 4
279
280#define MIB_TCP_MAXCONN_DYNAMIC (DWORD)-1
281
282typedef enum _TCP_TABLE_CLASS {
283 TCP_TABLE_BASIC_LISTENER,
284 TCP_TABLE_BASIC_CONNECTIONS,
285 TCP_TABLE_BASIC_ALL,
286 TCP_TABLE_OWNER_PID_LISTENER,
287 TCP_TABLE_OWNER_PID_CONNECTIONS,
288 TCP_TABLE_OWNER_PID_ALL,
289 TCP_TABLE_OWNER_MODULE_LISTENER,
290 TCP_TABLE_OWNER_MODULE_CONNECTIONS,
291 TCP_TABLE_OWNER_MODULE_ALL
292} TCP_TABLE_CLASS, *PTCP_TABLE_CLASS;
293
294typedef struct _MIB_TCPROW {
295 DWORD dwState;
296 DWORD dwLocalAddr;
297 DWORD dwLocalPort;
298 DWORD dwRemoteAddr;
299 DWORD dwRemotePort;
300} MIB_TCPROW,*PMIB_TCPROW;
301
302typedef MIB_TCPROW MIB_TCPROW_BASIC,*PMIB_TCPROW_BASIC;
303
304typedef struct _MIB_TCPROW_OWNER_PID {
305 DWORD dwState;
306 DWORD dwLocalAddr;
307 DWORD dwLocalPort;
308 DWORD dwRemoteAddr;
309 DWORD dwRemotePort;
310 DWORD dwOwningPid;
311} MIB_TCPROW_OWNER_PID,*PMIB_TCPROW_OWNER_PID;
312
313typedef struct _MIB_TCPROW_OWNER_MODULE {
314 DWORD dwState;
315 DWORD dwLocalAddr;
316 DWORD dwLocalPort;
317 DWORD dwRemoteAddr;
318 DWORD dwRemotePort;
319 DWORD dwOwningPid;
320 LARGE_INTEGER liCreateTimestamp;
321 ULONGLONG OwningModuleInfo[TCPIP_OWNING_MODULE_SIZE];
322} MIB_TCPROW_OWNER_MODULE,*PMIB_TCPROW_OWNER_MODULE;
323
324typedef struct _MIB_TCP6ROW_OWNER_PID {
325 UCHAR ucLocalAddr[16];
326 DWORD dwLocalScopeId;
327 DWORD dwLocalPort;
328 UCHAR ucRemoteAddr[16];
329 DWORD dwRemoteScopeId;
330 DWORD dwRemotePort;
331 DWORD dwState;
332 DWORD dwOwningPid;
333} MIB_TCP6ROW_OWNER_PID,*PMIB_TCP6ROW_OWNER_PID;
334
335typedef struct _MIB_TCP6ROW_OWNER_MODULE {
336 UCHAR ucLocalAddr[16];
337 DWORD dwLocalScopeId;
338 DWORD dwLocalPort;
339 UCHAR ucRemoteAddr[16];
340 DWORD dwRemoteScopeId;
341 DWORD dwRemotePort;
342 DWORD dwState;
343 DWORD dwOwningPid;
344 LARGE_INTEGER liCreateTimestamp;
345 ULONGLONG OwningModuleInfo[TCPIP_OWNING_MODULE_SIZE];
346} MIB_TCP6ROW_OWNER_MODULE,*PMIB_TCP6ROW_OWNER_MODULE;
347
348#define MIB_TCP_STATE_CLOSED 1
349#define MIB_TCP_STATE_LISTEN 2
350#define MIB_TCP_STATE_SYN_SENT 3
351#define MIB_TCP_STATE_SYN_RCVD 4
352#define MIB_TCP_STATE_ESTAB 5
353#define MIB_TCP_STATE_FIN_WAIT1 6
354#define MIB_TCP_STATE_FIN_WAIT2 7
355#define MIB_TCP_STATE_CLOSE_WAIT 8
356#define MIB_TCP_STATE_CLOSING 9
357#define MIB_TCP_STATE_LAST_ACK 10
358#define MIB_TCP_STATE_TIME_WAIT 11
359#define MIB_TCP_STATE_DELETE_TCB 12
360
361typedef struct _MIB_TCPTABLE {
362 DWORD dwNumEntries;
363 MIB_TCPROW table[ANY_SIZE];
364} MIB_TCPTABLE,*PMIB_TCPTABLE;
365
366typedef MIB_TCPTABLE MIB_TCPTABLE_BASIC,*PMIB_TCPTABLE_BASIC;
367
368#define SIZEOF_TCPTABLE(X) (FIELD_OFFSET(MIB_TCPTABLE,table[0]) + ((X) *sizeof(MIB_TCPROW)) + ALIGN_SIZE)
369#define SIZEOF_TCPTABLE_BASIC(X) SIZEOF_TCPTABLE(X)
370
371typedef struct _MIB_TCPTABLE_OWNER_PID {
372 DWORD dwNumEntries;
373 MIB_TCPROW_OWNER_PID table[ANY_SIZE];
374} MIB_TCPTABLE_OWNER_PID,*PMIB_TCPTABLE_OWNER_PID;
375
376#define SIZEOF_TCPTABLE_OWNER_PID(X) (FIELD_OFFSET(MIB_TCPTABLE_OWNER_PID,table[0]) + ((X) *sizeof(MIB_TCPROW_OWNER_PID)) + ALIGN_SIZE)
377
378typedef struct _MIB_TCPTABLE_OWNER_MODULE {
379 DWORD dwNumEntries;
380 MIB_TCPROW_OWNER_MODULE table[ANY_SIZE];
381} MIB_TCPTABLE_OWNER_MODULE,*PMIB_TCPTABLE_OWNER_MODULE;
382
383#define SIZEOF_TCPTABLE_OWNER_MODULE(X) (FIELD_OFFSET(MIB_TCPTABLE_OWNER_MODULE,table[0]) + ((X) *sizeof(MIB_TCPROW_OWNER_MODULE)) + ALIGN_SIZE)
384
385typedef struct _MIB_TCP6TABLE_OWNER_PID {
386 DWORD dwNumEntries;
387 MIB_TCP6ROW_OWNER_PID table[ANY_SIZE];
388} MIB_TCP6TABLE_OWNER_PID,*PMIB_TCP6TABLE_OWNER_PID;
389
390#define SIZEOF_TCP6TABLE_OWNER_PID(X) (FIELD_OFFSET(MIB_TCP6TABLE_OWNER_PID,table[0]) + ((X) *sizeof(MIB_TCP6ROW_OWNER_PID)) + ALIGN_SIZE)
391
392typedef struct _MIB_TCP6TABLE_OWNER_MODULE {
393 DWORD dwNumEntries;
394 MIB_TCP6ROW_OWNER_MODULE table[ANY_SIZE];
395} MIB_TCP6TABLE_OWNER_MODULE,*PMIB_TCP6TABLE_OWNER_MODULE;
396
397#define SIZEOF_TCP6TABLE_OWNER_MODULE(X) (FIELD_OFFSET(MIB_TCP6TABLE_OWNER_MODULE,table[0]) + ((X) *sizeof(MIB_TCP6ROW_OWNER_PID)) + ALIGN_SIZE)
398
399#define MIB_SECURITY_TCP_SYN_ATTACK 0x00000001
400
401#define MIB_USE_CURRENT_TTL ((DWORD)-1)
402#define MIB_USE_CURRENT_FORWARDING ((DWORD)-1)
403
404typedef struct _MIB_IPSTATS {
405 DWORD dwForwarding;
406 DWORD dwDefaultTTL;
407 DWORD dwInReceives;
408 DWORD dwInHdrErrors;
409 DWORD dwInAddrErrors;
410 DWORD dwForwDatagrams;
411 DWORD dwInUnknownProtos;
412 DWORD dwInDiscards;
413 DWORD dwInDelivers;
414 DWORD dwOutRequests;
415 DWORD dwRoutingDiscards;
416 DWORD dwOutDiscards;
417 DWORD dwOutNoRoutes;
418 DWORD dwReasmTimeout;
419 DWORD dwReasmReqds;
420 DWORD dwReasmOks;
421 DWORD dwReasmFails;
422 DWORD dwFragOks;
423 DWORD dwFragFails;
424 DWORD dwFragCreates;
425 DWORD dwNumIf;
426 DWORD dwNumAddr;
427 DWORD dwNumRoutes;
428} MIB_IPSTATS,*PMIB_IPSTATS;
429
430#define MIB_IP_FORWARDING 1
431#define MIB_IP_NOT_FORWARDING 2
432
433#define MIB_IPADDR_PRIMARY 0x0001
434#define MIB_IPADDR_DYNAMIC 0x0004
435#define MIB_IPADDR_DISCONNECTED 0x0008
436#define MIB_IPADDR_DELETED 0x0040
437#define MIB_IPADDR_TRANSIENT 0x0080
438
439typedef struct _MIB_IPADDRROW {
440 DWORD dwAddr;
441 DWORD dwIndex;
442 DWORD dwMask;
443 DWORD dwBCastAddr;
444 DWORD dwReasmSize;
445 unsigned short unused1;
446 unsigned short wType;
447} MIB_IPADDRROW,*PMIB_IPADDRROW;
448
449typedef struct _MIB_IPADDRTABLE {
450 DWORD dwNumEntries;
451 MIB_IPADDRROW table[ANY_SIZE];
452} MIB_IPADDRTABLE,*PMIB_IPADDRTABLE;
453
454#define SIZEOF_IPADDRTABLE(X) (FIELD_OFFSET(MIB_IPADDRTABLE,table[0]) + ((X) *sizeof(MIB_IPADDRROW)) + ALIGN_SIZE)
455
456typedef struct _MIB_IPFORWARDNUMBER {
457 DWORD dwValue;
458} MIB_IPFORWARDNUMBER,*PMIB_IPFORWARDNUMBER;
459
460typedef struct _MIB_IPFORWARDROW {
461 DWORD dwForwardDest;
462 DWORD dwForwardMask;
463 DWORD dwForwardPolicy;
464 DWORD dwForwardNextHop;
465 DWORD dwForwardIfIndex;
466 DWORD dwForwardType;
467 DWORD dwForwardProto;
468 DWORD dwForwardAge;
469 DWORD dwForwardNextHopAS;
470 DWORD dwForwardMetric1;
471 DWORD dwForwardMetric2;
472 DWORD dwForwardMetric3;
473 DWORD dwForwardMetric4;
474 DWORD dwForwardMetric5;
475} MIB_IPFORWARDROW,*PMIB_IPFORWARDROW;
476
477#define MIB_IPROUTE_TYPE_OTHER 1
478#define MIB_IPROUTE_TYPE_INVALID 2
479#define MIB_IPROUTE_TYPE_DIRECT 3
480#define MIB_IPROUTE_TYPE_INDIRECT 4
481
482#define MIB_IPROUTE_METRIC_UNUSED (DWORD)-1
483
484#define MIB_IPPROTO_OTHER 1
485#define MIB_IPPROTO_LOCAL 2
486#define MIB_IPPROTO_NETMGMT 3
487#define MIB_IPPROTO_ICMP 4
488#define MIB_IPPROTO_EGP 5
489#define MIB_IPPROTO_GGP 6
490#define MIB_IPPROTO_HELLO 7
491#define MIB_IPPROTO_RIP 8
492#define MIB_IPPROTO_IS_IS 9
493#define MIB_IPPROTO_ES_IS 10
494#define MIB_IPPROTO_CISCO 11
495#define MIB_IPPROTO_BBN 12
496#define MIB_IPPROTO_OSPF 13
497#define MIB_IPPROTO_BGP 14
498
499#define MIB_IPPROTO_NT_AUTOSTATIC 10002
500#define MIB_IPPROTO_NT_STATIC 10006
501#define MIB_IPPROTO_NT_STATIC_NON_DOD 10007
502
503typedef struct _MIB_IPFORWARDTABLE {
504 DWORD dwNumEntries;
505 MIB_IPFORWARDROW table[ANY_SIZE];
506} MIB_IPFORWARDTABLE,*PMIB_IPFORWARDTABLE;
507
508#define SIZEOF_IPFORWARDTABLE(X) (FIELD_OFFSET(MIB_IPFORWARDTABLE,table[0]) + ((X) *sizeof(MIB_IPFORWARDROW)) + ALIGN_SIZE)
509
510typedef struct _MIB_IPNETROW {
511 DWORD dwIndex;
512 DWORD dwPhysAddrLen;
513 BYTE bPhysAddr[MAXLEN_PHYSADDR];
514 DWORD dwAddr;
515 DWORD dwType;
516} MIB_IPNETROW,*PMIB_IPNETROW;
517
518#define MIB_IPNET_TYPE_OTHER 1
519#define MIB_IPNET_TYPE_INVALID 2
520#define MIB_IPNET_TYPE_DYNAMIC 3
521#define MIB_IPNET_TYPE_STATIC 4
522
523typedef struct _MIB_IPNETTABLE {
524 DWORD dwNumEntries;
525 MIB_IPNETROW table[ANY_SIZE];
526} MIB_IPNETTABLE,*PMIB_IPNETTABLE;
527
528#define SIZEOF_IPNETTABLE(X) (FIELD_OFFSET(MIB_IPNETTABLE,table[0]) + ((X) *sizeof(MIB_IPNETROW)) + ALIGN_SIZE)
529
530typedef struct _MIB_IPMCAST_OIF {
531 DWORD dwOutIfIndex;
532 DWORD dwNextHopAddr;
533 DWORD dwReserved;
534 DWORD dwReserved1;
535} MIB_IPMCAST_OIF,*PMIB_IPMCAST_OIF;
536
537typedef struct _MIB_IPMCAST_MFE {
538 DWORD dwGroup;
539 DWORD dwSource;
540 DWORD dwSrcMask;
541 DWORD dwUpStrmNgbr;
542 DWORD dwInIfIndex;
543 DWORD dwInIfProtocol;
544 DWORD dwRouteProtocol;
545 DWORD dwRouteNetwork;
546 DWORD dwRouteMask;
547 ULONG ulUpTime;
548 ULONG ulExpiryTime;
549 ULONG ulTimeOut;
550 ULONG ulNumOutIf;
551 DWORD fFlags;
552 DWORD dwReserved;
553 MIB_IPMCAST_OIF rgmioOutInfo[ANY_SIZE];
554} MIB_IPMCAST_MFE,*PMIB_IPMCAST_MFE;
555
556typedef struct _MIB_MFE_TABLE {
557 DWORD dwNumEntries;
558 MIB_IPMCAST_MFE table[ANY_SIZE];
559} MIB_MFE_TABLE,*PMIB_MFE_TABLE;
560
561#define SIZEOF_BASIC_MIB_MFE (ULONG)(FIELD_OFFSET(MIB_IPMCAST_MFE,rgmioOutInfo[0]))
562
563#define SIZEOF_MIB_MFE(X) (SIZEOF_BASIC_MIB_MFE + ((X) *sizeof(MIB_IPMCAST_OIF)))
564
565typedef struct _MIB_IPMCAST_OIF_STATS {
566 DWORD dwOutIfIndex;
567 DWORD dwNextHopAddr;
568 DWORD dwDialContext;
569 ULONG ulTtlTooLow;
570 ULONG ulFragNeeded;
571 ULONG ulOutPackets;
572 ULONG ulOutDiscards;
573} MIB_IPMCAST_OIF_STATS,*PMIB_IPMCAST_OIF_STATS;
574
575typedef struct _MIB_IPMCAST_MFE_STATS {
576 DWORD dwGroup;
577 DWORD dwSource;
578 DWORD dwSrcMask;
579 DWORD dwUpStrmNgbr;
580 DWORD dwInIfIndex;
581 DWORD dwInIfProtocol;
582 DWORD dwRouteProtocol;
583 DWORD dwRouteNetwork;
584 DWORD dwRouteMask;
585 ULONG ulUpTime;
586 ULONG ulExpiryTime;
587 ULONG ulNumOutIf;
588 ULONG ulInPkts;
589 ULONG ulInOctets;
590 ULONG ulPktsDifferentIf;
591 ULONG ulQueueOverflow;
592 MIB_IPMCAST_OIF_STATS rgmiosOutStats[ANY_SIZE];
593} MIB_IPMCAST_MFE_STATS,*PMIB_IPMCAST_MFE_STATS;
594
595typedef struct _MIB_MFE_STATS_TABLE {
596 DWORD dwNumEntries;
597 MIB_IPMCAST_MFE_STATS table[ANY_SIZE];
598} MIB_MFE_STATS_TABLE,*PMIB_MFE_STATS_TABLE;
599
600#define SIZEOF_BASIC_MIB_MFE_STATS (ULONG)(FIELD_OFFSET(MIB_IPMCAST_MFE_STATS,rgmiosOutStats[0]))
601#define SIZEOF_MIB_MFE_STATS(X) (SIZEOF_BASIC_MIB_MFE_STATS + ((X) *sizeof(MIB_IPMCAST_OIF_STATS)))
602
603typedef struct _MIB_IPMCAST_MFE_STATS_EX {
604 DWORD dwGroup;
605 DWORD dwSource;
606 DWORD dwSrcMask;
607 DWORD dwUpStrmNgbr;
608 DWORD dwInIfIndex;
609 DWORD dwInIfProtocol;
610 DWORD dwRouteProtocol;
611 DWORD dwRouteNetwork;
612 DWORD dwRouteMask;
613 ULONG ulUpTime;
614 ULONG ulExpiryTime;
615 ULONG ulNumOutIf;
616 ULONG ulInPkts;
617 ULONG ulInOctets;
618 ULONG ulPktsDifferentIf;
619 ULONG ulQueueOverflow;
620 ULONG ulUninitMfe;
621 ULONG ulNegativeMfe;
622 ULONG ulInDiscards;
623 ULONG ulInHdrErrors;
624 ULONG ulTotalOutPackets;
625 MIB_IPMCAST_OIF_STATS rgmiosOutStats[ANY_SIZE];
626} MIB_IPMCAST_MFE_STATS_EX,*PMIB_IPMCAST_MFE_STATS_EX;
627
628typedef struct _MIB_MFE_STATS_TABLE_EX {
629 DWORD dwNumEntries;
630 MIB_IPMCAST_MFE_STATS_EX table[ANY_SIZE];
631} MIB_MFE_STATS_TABLE_EX,*PMIB_MFE_STATS_TABLE_EX;
632
633#define SIZEOF_BASIC_MIB_MFE_STATS_EX (ULONG)(FIELD_OFFSET(MIB_IPMCAST_MFE_STATS_EX,rgmiosOutStats[0]))
634#define SIZEOF_MIB_MFE_STATS_EX(X) (SIZEOF_BASIC_MIB_MFE_STATS_EX + ((X) *sizeof(MIB_IPMCAST_OIF_STATS)))
635
636typedef struct _MIB_IPMCAST_GLOBAL {
637 DWORD dwEnable;
638} MIB_IPMCAST_GLOBAL,*PMIB_IPMCAST_GLOBAL;
639
640typedef struct _MIB_IPMCAST_IF_ENTRY {
641 DWORD dwIfIndex;
642 DWORD dwTtl;
643 DWORD dwProtocol;
644 DWORD dwRateLimit;
645 ULONG ulInMcastOctets;
646 ULONG ulOutMcastOctets;
647} MIB_IPMCAST_IF_ENTRY,*PMIB_IPMCAST_IF_ENTRY;
648
649typedef struct _MIB_IPMCAST_IF_TABLE {
650 DWORD dwNumEntries;
651 MIB_IPMCAST_IF_ENTRY table[ANY_SIZE];
652} MIB_IPMCAST_IF_TABLE,*PMIB_IPMCAST_IF_TABLE;
653
654#define SIZEOF_MCAST_IF_TABLE(X) (FIELD_OFFSET(MIB_IPMCAST_IF_TABLE,table[0]) + ((X) *sizeof(MIB_IPMCAST_IF_ENTRY)) + ALIGN_SIZE)
655
656typedef struct _MIB_IPMCAST_BOUNDARY {
657 DWORD dwIfIndex;
658 DWORD dwGroupAddress;
659 DWORD dwGroupMask;
660 DWORD dwStatus;
661} MIB_IPMCAST_BOUNDARY,*PMIB_IPMCAST_BOUNDARY;
662
663typedef struct _MIB_IPMCAST_BOUNDARY_TABLE {
664 DWORD dwNumEntries;
665 MIB_IPMCAST_BOUNDARY table[ANY_SIZE];
666} MIB_IPMCAST_BOUNDARY_TABLE,*PMIB_IPMCAST_BOUNDARY_TABLE;
667
668#define SIZEOF_BOUNDARY_TABLE(X) (FIELD_OFFSET(MIB_IPMCAST_BOUNDARY_TABLE,table[0]) + ((X) *sizeof(MIB_IPMCAST_BOUNDARY)) + ALIGN_SIZE)
669
670typedef struct {
671 DWORD dwGroupAddress;
672 DWORD dwGroupMask;
673} MIB_BOUNDARYROW,*PMIB_BOUNDARYROW;
674
675typedef struct {
676 DWORD dwTtl;
677 DWORD dwRateLimit;
678} MIB_MCAST_LIMIT_ROW,*PMIB_MCAST_LIMIT_ROW;
679
680#define MAX_SCOPE_NAME_LEN 255
681
682#define SN_UNICODE
683typedef WCHAR SN_CHAR;
684typedef SN_CHAR SCOPE_NAME_BUFFER[MAX_SCOPE_NAME_LEN+1],*SCOPE_NAME;
685
686typedef struct _MIB_IPMCAST_SCOPE {
687 DWORD dwGroupAddress;
688 DWORD dwGroupMask;
689 SCOPE_NAME_BUFFER snNameBuffer;
690 DWORD dwStatus;
691} MIB_IPMCAST_SCOPE,*PMIB_IPMCAST_SCOPE;
692
693typedef struct _MIB_IPDESTROW {
694#ifdef __cplusplus
695 MIB_IPFORWARDROW ForwardRow;
696#else
697 __C89_NAMELESS union {
698 DWORD dwForwardDest;
699 DWORD dwForwardMask;
700 DWORD dwForwardPolicy;
701 DWORD dwForwardNextHop;
702 DWORD dwForwardIfIndex;
703 DWORD dwForwardType;
704 DWORD dwForwardProto;
705 DWORD dwForwardAge;
706 DWORD dwForwardNextHopAS;
707 DWORD dwForwardMetric1;
708 DWORD dwForwardMetric2;
709 DWORD dwForwardMetric3;
710 DWORD dwForwardMetric4;
711 DWORD dwForwardMetric5;
712 }; /* see MIB_IPFORWARDROW */
713#endif
714 DWORD dwForwardPreference;
715 DWORD dwForwardViewSet;
716} MIB_IPDESTROW,*PMIB_IPDESTROW;
717
718typedef struct _MIB_IPDESTTABLE {
719 DWORD dwNumEntries;
720 MIB_IPDESTROW table[ANY_SIZE];
721} MIB_IPDESTTABLE,*PMIB_IPDESTTABLE;
722
723typedef struct _MIB_BEST_IF {
724 DWORD dwDestAddr;
725 DWORD dwIfIndex;
726} MIB_BEST_IF,*PMIB_BEST_IF;
727
728typedef struct _MIB_PROXYARP {
729 DWORD dwAddress;
730 DWORD dwMask;
731 DWORD dwIfIndex;
732} MIB_PROXYARP,*PMIB_PROXYARP;
733
734typedef struct _MIB_IFSTATUS {
735 DWORD dwIfIndex;
736 DWORD dwAdminStatus;
737 DWORD dwOperationalStatus;
738 WINBOOL bMHbeatActive;
739 WINBOOL bMHbeatAlive;
740} MIB_IFSTATUS,*PMIB_IFSTATUS;
741
742typedef struct _MIB_ROUTESTATE {
743 WINBOOL bRoutesSetToStack;
744} MIB_ROUTESTATE,*PMIB_ROUTESTATE;
745
746typedef struct _MIB_OPAQUE_INFO {
747 DWORD dwId;
748 __C89_NAMELESS union {
749 ULONGLONG ullAlign;
750 BYTE rgbyData[1];
751 };
752} MIB_OPAQUE_INFO,*PMIB_OPAQUE_INFO;
753
754typedef struct _TCPIP_OWNER_MODULE_BASIC_INFO {
755 PWCHAR pModuleName;
756 PWCHAR pModulePath;
757} TCPIP_OWNER_MODULE_BASIC_INFO, *PTCPIP_OWNER_MODULE_BASIC_INFO;
758
759typedef enum _UDP_TABLE_CLASS {
760 UDP_TABLE_BASIC,
761 UDP_TABLE_OWNER_PID,
762 UDP_TABLE_OWNER_MODULE
763} UDP_TABLE_CLASS, *PUDP_TABLE_CLASS;
764
765typedef enum _TCPIP_OWNER_MODULE_INFO_CLASS {
766 TCPIP_OWNER_MODULE_INFO_BASIC
767} TCPIP_OWNER_MODULE_INFO_CLASS, *PTCPIP_OWNER_MODULE_INFO_CLASS;
768
769#define MAX_MIB_OFFSET 8
770
771#define MIB_INFO_SIZE(S) (MAX_MIB_OFFSET + sizeof(S))
772#define MIB_INFO_SIZE_IN_DWORDS(S) ((MIB_INFO_SIZE(S))/sizeof(DWORD) + 1)
773
774#define DEFINE_MIB_BUFFER(X,Y,Z) DWORD __rgdwBuff[MIB_INFO_SIZE_IN_DWORDS(Y)]; PMIB_OPAQUE_INFO X = (PMIB_OPAQUE_INFO)__rgdwBuff; Y *Z = (Y *)(X->rgbyData)
775
776#define CAST_MIB_INFO(X,Y,Z) Z = (Y)(X->rgbyData)
777
778#endif /*WINAPI_FAMILY_PARTITION (WINAPI_PARTITION_DESKTOP)*/
779
780#endif /* __ROUTING_IPRTRMIB_H__ */
Note: See TracBrowser for help on using the repository browser.