mirror of
https://github.com/reactos/reactos.git
synced 2025-01-01 03:54:02 +00:00
58cef01422
We only support IPv4 and UDP_TABLE_BASIC, UDP_TABLE_OWNER_PID for now CORE-5126
118 lines
3.8 KiB
C
118 lines
3.8 KiB
C
/* ipstats.h
|
|
* Copyright (C) 2003 Juan Lang
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*
|
|
* This module implements functions shared by DLLs that need to get network-
|
|
* related statistics. It's meant to hide some platform-specificisms, and
|
|
* share code that was previously duplicated.
|
|
*/
|
|
#ifndef WINE_IPSTATS_H_
|
|
#define WINE_IPSTATS_H_
|
|
|
|
//#include <stdarg.h>
|
|
|
|
//#include "windef.h"
|
|
//#include "winbase.h"
|
|
//#include "iprtrmib.h"
|
|
|
|
/* Fills in entry's interface stats, using name to find them.
|
|
* Returns ERROR_INVALID_PARAMETER if name or entry is NULL, NO_ERROR otherwise.
|
|
*/
|
|
DWORD getInterfaceStatsByName(const char *name, PMIB_IFROW entry);
|
|
|
|
/* Ditto above by index. */
|
|
DWORD getInterfaceStatsByIndex(DWORD index, PMIB_IFROW entry);
|
|
|
|
/* Gets ICMP statistics into stats. Returns ERROR_INVALID_PARAMETER if stats is
|
|
* NULL, NO_ERROR otherwise.
|
|
*/
|
|
DWORD getICMPStats(MIB_ICMP *stats);
|
|
|
|
/* Gets IP statistics into stats. Returns ERROR_INVALID_PARAMETER if stats is
|
|
* NULL, NO_ERROR otherwise.
|
|
*/
|
|
DWORD getIPStats(PMIB_IPSTATS stats, DWORD family);
|
|
|
|
/* Gets TCP statistics into stats. Returns ERROR_INVALID_PARAMETER if stats is
|
|
* NULL, NO_ERROR otherwise.
|
|
*/
|
|
DWORD getTCPStats(MIB_TCPSTATS *stats, DWORD family);
|
|
|
|
/* Gets UDP statistics into stats. Returns ERROR_INVALID_PARAMETER if stats is
|
|
* NULL, NO_ERROR otherwise.
|
|
*/
|
|
DWORD getUDPStats(MIB_UDPSTATS *stats, DWORD family);
|
|
|
|
/* Route table functions */
|
|
|
|
DWORD getNumRoutes(void);
|
|
|
|
/* Minimalist route entry, only has the fields I can actually fill in. How
|
|
* these map to the different windows route data structures is up to you.
|
|
*/
|
|
typedef struct _RouteEntry {
|
|
DWORD dest;
|
|
DWORD mask;
|
|
DWORD gateway;
|
|
DWORD ifIndex;
|
|
DWORD metric;
|
|
} RouteEntry;
|
|
|
|
typedef struct _RouteTable {
|
|
DWORD numRoutes;
|
|
RouteEntry routes[1];
|
|
} RouteTable;
|
|
|
|
/* Allocates and returns to you the route table, or NULL if it can't allocate
|
|
* enough memory. free() the returned table.
|
|
*/
|
|
RouteTable *getRouteTable(void);
|
|
|
|
/* Returns the number of entries in the arp table. */
|
|
DWORD getNumArpEntries(void);
|
|
|
|
/* Allocates and returns to you the arp table, or NULL if it can't allocate
|
|
* enough memory. free() the returned table.
|
|
*/
|
|
PMIB_IPNETTABLE getArpTable(void);
|
|
|
|
/* Returns the number of entries in the UDP state table. */
|
|
DWORD getNumUdpEntries(void);
|
|
|
|
/* Allocates and returns to you the UDP state table, or NULL if it can't
|
|
* allocate enough memory. free() the returned table.
|
|
*/
|
|
PMIB_UDPTABLE getUdpTable(void);
|
|
|
|
/* Allocates and returns to you the UDP state table with owner PID,
|
|
* or NULL if it can't allocate enough memory. free() the returned table.
|
|
*/
|
|
PMIB_UDPTABLE_OWNER_PID getOwnerUdpTable(void);
|
|
|
|
/* Returns the number of entries in the TCP state table. */
|
|
DWORD getNumTcpEntries(void);
|
|
|
|
/* Allocates and returns to you the TCP state table, or NULL if it can't
|
|
* allocate enough memory. free() the returned table.
|
|
*/
|
|
PMIB_TCPTABLE getTcpTable(void);
|
|
|
|
/* Allocates and returns to you the TCP state table with owner PID,
|
|
* or NULL if it can't allocate enough memory. free() the returned table.
|
|
*/
|
|
PMIB_TCPTABLE_OWNER_PID getOwnerTcpTable(void);
|
|
|
|
#endif /* ndef WINE_IPSTATS_H_ */
|