174 lines
5.6 KiB
C
174 lines
5.6 KiB
C
/* wscontrol.h
|
|
*
|
|
* This header file includes #defines, structure and type definitions,
|
|
* and function declarations that support the implementation of the
|
|
* (undocumented) Winsock 1 call WsControl.
|
|
*
|
|
* The functionality of WsControl was created by observing its behaviour
|
|
* in Windows 98, so there are likely to be bugs with the assumptions
|
|
* that were made. A significant amount of help came from
|
|
* http://tangentsoft.net/wskfaq/articles/wscontrol.html , especially the
|
|
* trace by Thomas Divine (www.pcausa.net).
|
|
*
|
|
* Copyright 2000 James Hatheway
|
|
* Copyright 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
*/
|
|
|
|
#ifndef WSCONTROL_H_INCLUDED
|
|
#define WSCONTROL_H_INCLUDED
|
|
|
|
#define WSCTL_SUCCESS 0
|
|
|
|
/*
|
|
* TCP/IP action codes.
|
|
*/
|
|
#define WSCNTL_TCPIP_QUERY_INFO 0x00000000
|
|
#define WSCNTL_TCPIP_SET_INFO 0x00000001
|
|
#define WSCNTL_TCPIP_ICMP_ECHO 0x00000002
|
|
#define WSCNTL_TCPIP_TEST 0x00000003
|
|
|
|
|
|
/* Structure of an entity ID */
|
|
typedef struct TDIEntityID
|
|
{
|
|
unsigned long tei_entity;
|
|
unsigned long tei_instance;
|
|
} TDIEntityID;
|
|
|
|
/* Structure of an object ID */
|
|
typedef struct TDIObjectID
|
|
{
|
|
TDIEntityID toi_entity;
|
|
unsigned long toi_class;
|
|
unsigned long toi_type;
|
|
unsigned long toi_id;
|
|
} TDIObjectID;
|
|
|
|
#ifdef if_type
|
|
#undef if_type
|
|
#endif
|
|
#ifdef if_mtu
|
|
#undef if_mtu
|
|
#endif
|
|
#ifdef if_lastchange
|
|
#undef if_lastchange
|
|
#endif
|
|
|
|
#define MAX_PHYSADDR_SIZE 8
|
|
#define MAX_IFDESCR_LEN 256
|
|
typedef struct IFEntry
|
|
{
|
|
unsigned long if_index;
|
|
unsigned long if_type;
|
|
unsigned long if_mtu;
|
|
unsigned long if_speed;
|
|
unsigned long if_physaddrlen;
|
|
unsigned char if_physaddr[MAX_PHYSADDR_SIZE];
|
|
unsigned long if_adminstatus;
|
|
unsigned long if_operstatus;
|
|
unsigned long if_lastchange;
|
|
unsigned long if_inoctets;
|
|
unsigned long if_inucastpkts;
|
|
unsigned long if_innucastpkts;
|
|
unsigned long if_indiscards;
|
|
unsigned long if_inerrors;
|
|
unsigned long if_inunknownprotos;
|
|
unsigned long if_outoctets;
|
|
unsigned long if_outucastpkts;
|
|
unsigned long if_outnucastpkts;
|
|
unsigned long if_outdiscards;
|
|
unsigned long if_outerrors;
|
|
unsigned long if_outqlen;
|
|
unsigned long if_descrlen;
|
|
unsigned char if_descr[1];
|
|
} IFEntry;
|
|
|
|
|
|
/* FIXME: real name and definition of this struct that contains
|
|
* an IP route table entry is unknown */
|
|
typedef struct IPRouteEntry {
|
|
unsigned long ire_addr;
|
|
unsigned long ire_index; /*matches if_index in IFEntry and iae_index in IPAddrEntry */
|
|
unsigned long ire_metric;
|
|
unsigned long ire_option4;
|
|
unsigned long ire_option5;
|
|
unsigned long ire_option6;
|
|
unsigned long ire_gw;
|
|
unsigned long ire_option8;
|
|
unsigned long ire_option9;
|
|
unsigned long ire_option10;
|
|
unsigned long ire_mask;
|
|
unsigned long ire_option12;
|
|
} IPRouteEntry;
|
|
|
|
|
|
/* Constants for use in the toi_id field */
|
|
#define ENTITY_LIST_ID 0 /* to get the list of entity IDs */
|
|
#define ENTITY_TYPE_ID 1 /* it's an interface; what type of interface is it? */
|
|
#define IP_MIB_ROUTETABLE_ENTRY_ID 0x101 /* not real name */
|
|
#define IP_MIB_ADDRTABLE_ENTRY_ID 0x102
|
|
|
|
/* Constants for use in the toi_class field */
|
|
#define INFO_CLASS_GENERIC 0x100
|
|
#define INFO_CLASS_PROTOCOL 0x200
|
|
|
|
/* Constants for use in the toi_type field */
|
|
#define INFO_TYPE_PROVIDER 0x100
|
|
|
|
/* Interface types. The first one can be returned in the entity ID list--it's
|
|
* an interface, and it can be further queried for what type of interface it is.
|
|
*/
|
|
#define IF_GENERIC 0x200 /* generic interface */
|
|
#define IF_MIB 0x202 /* supports MIB-2 interface */
|
|
|
|
/* address translation types. The first can be turned in the entity ID list--
|
|
* it supports address translation of some type, and it can be further queried
|
|
* for what type of address translation it supports (I think).
|
|
*/
|
|
#define AT_ENTITY 0x280
|
|
#define AT_ARP 0x280
|
|
#define AT_NULL 0x282 /* doesn't do address translation after all (liar) */
|
|
|
|
/* network layer service providers. The first one can be returned in the
|
|
* entity list ID--it supports a network layer (datagram) service, and it can
|
|
* be further queried for what type of network layer service it provides.
|
|
*/
|
|
#define CL_NL_ENTITY 0x301
|
|
#define CL_NL_IPX 0x301 /* implements IPX--probably won't see this, since
|
|
* we're querying the TCP protocol */
|
|
#define CL_NL_IP 0x303 /* implements IP */
|
|
|
|
/* echo request/response types. The first can be returned in the entity ID
|
|
* list--it can be further queried for what type of echo it supports (I think).
|
|
*/
|
|
#define ER_ENTITY 0x380
|
|
#define ER_ICMP 0x380
|
|
|
|
/* connection-oriented transport layer protocols--you know the drill by now */
|
|
#define CO_TL_ENTITY 0x400
|
|
#define CO_TL_NBF 0x400
|
|
#define CO_TL_SPX 0x402
|
|
#define CO_TL_TCP 0x404
|
|
#define CO_TL_SPP 0x406
|
|
|
|
/* connectionless transport layer protocols--you know the drill by now */
|
|
#define CL_TL_ENTITY 0x401
|
|
#define CL_TL_NBF 0x401
|
|
#define CL_TL_UDP 0x403
|
|
|
|
#endif /* WSCONTROL_H_INCLUDED */
|