2 * COPYRIGHT: See COPYING in the top level directory
3 * PROJECT: ReactOS TCP/IP protocol driver
5 * PURPOSE: Internet Protocol related definitions
10 typedef VOID (*OBJECT_FREE_ROUTINE
)(PVOID Object
);
12 #define FOURCC(a,b,c,d) (((a)<<24)|((b)<<16)|((c)<<8)|(d))
14 /* Raw IPv4 style address */
15 typedef ULONG IPv4_RAW_ADDRESS
;
16 typedef IPv4_RAW_ADDRESS
*PIPv4_RAW_ADDRESS
;
18 /* Raw IPv6 style address */
19 typedef USHORT IPv6_RAW_ADDRESS
[8];
20 typedef IPv6_RAW_ADDRESS
*PIPv6_RAW_ADDRESS
;
22 /* IP style address */
23 typedef struct IP_ADDRESS
{
25 UCHAR Type
; /* Type of IP address */
27 IPv4_RAW_ADDRESS IPv4Address
;/* IPv4 address (in network byte order) */
28 IPv6_RAW_ADDRESS IPv6Address
;/* IPv6 address (in network byte order) */
30 } IP_ADDRESS
, *PIP_ADDRESS
;
32 /* IP type constants */
33 #define IP_ADDRESS_V4 0x04 /* IPv4 style address */
34 #define IP_ADDRESS_V6 0x06 /* IPv6 style address */
37 /* IPv4 header format */
38 typedef struct IPv4_HEADER
{
39 UCHAR VerIHL
; /* 4-bit version, 4-bit Internet Header Length */
40 UCHAR Tos
; /* Type of Service */
41 USHORT TotalLength
; /* Total Length */
42 USHORT Id
; /* Identification */
43 USHORT FlagsFragOfs
; /* 3-bit Flags, 13-bit Fragment Offset */
44 UCHAR Ttl
; /* Time to Live */
45 UCHAR Protocol
; /* Protocol */
46 USHORT Checksum
; /* Header Checksum */
47 IPv4_RAW_ADDRESS SrcAddr
; /* Source Address */
48 IPv4_RAW_ADDRESS DstAddr
; /* Destination Address */
49 } IPv4_HEADER
, *PIPv4_HEADER
;
51 /* IPv6 header format */
52 typedef struct IPv6_HEADER
{
53 ULONG VTF
; /* Version, Traffic Class, Flow Label */
55 UCHAR NextHeader
; /* Same as Protocol in IPv4 */
56 UCHAR HopLimit
; /* Same as Ttl in IPv4 */
57 IPv6_RAW_ADDRESS SrcAddr
;
58 IPv6_RAW_ADDRESS DstAddr
;
59 } IPv6_HEADER
, *PIPv6_HEADER
;
61 typedef union _IP_HEADER
{
64 } IP_HEADER
, *PIP_HEADER
;
66 #define IPv4_FRAGOFS_MASK 0x1FFF /* Fragment offset mask (host byte order) */
67 #define IPv4_MF_MASK 0x2000 /* More fragments (host byte order) */
68 #define IPv4_DF_MASK 0x4000 /* Don't fragment (host byte order) */
69 #define IPv4_MAX_HEADER_SIZE 60
71 /* Packet completion handler prototype */
72 typedef VOID (*PACKET_COMPLETION_ROUTINE
)(
74 PNDIS_PACKET NdisPacket
,
75 NDIS_STATUS NdisStatus
);
77 /* Structure for an IP packet */
78 typedef struct _IP_PACKET
{
80 OBJECT_FREE_ROUTINE Free
; /* Routine used to free resources for the object */
81 UCHAR Type
; /* Type of IP packet (see IP_ADDRESS_xx above) */
82 UCHAR Flags
; /* Flags for packet (see IP_PACKET_FLAG_xx below)*/
83 PVOID Header
; /* Pointer to IP header for this packet */
84 UINT HeaderSize
; /* Size of IP header */
85 PVOID Data
; /* Current pointer into packet data */
86 UINT TotalSize
; /* Total amount of data in packet (IP header and data) */
87 UINT ContigSize
; /* Number of contiguous bytes left in current buffer */
88 UINT Position
; /* Current logical offset into packet */
89 PNDIS_PACKET NdisPacket
; /* Pointer to NDIS packet */
90 IP_ADDRESS SrcAddr
; /* Source address */
91 IP_ADDRESS DstAddr
; /* Destination address */
92 } IP_PACKET
, *PIP_PACKET
;
94 #define IP_PACKET_FLAG_RAW 0x01 /* Raw IP packet */
98 typedef struct _PACKET_CONTEXT
{
99 PACKET_COMPLETION_ROUTINE DLComplete
; /* Data link level completion handler
100 * Also used to link to next packet
102 PVOID Context
; /* Context information for handler */
103 UINT PacketType
; /* Type of packet */
104 } PACKET_CONTEXT
, *PPACKET_CONTEXT
;
106 /* The ProtocolReserved field is structured as a PACKET_CONTEXT */
107 #define PC(Packet) ((PPACKET_CONTEXT)(&Packet->ProtocolReserved))
109 /* Values for address type -- also the interface flags */
110 /* These values are mean to overlap meaningfully with the BSD ones */
111 #define ADE_UNICAST 0x01
112 #define ADE_BROADCAST 0x02
113 #define ADE_ADDRMASK 0x04
114 #define ADE_POINTOPOINT 0x10
115 #define ADE_MULTICAST 0x8000
117 /* There is one NTE for each source (unicast) address assigned to an interface */
118 /* Link layer transmit prototype */
119 typedef VOID (*LL_TRANSMIT_ROUTINE
)(
121 PNDIS_PACKET NdisPacket
,
126 /* Link layer to IP binding information */
127 typedef struct _LLIP_BIND_INFO
{
128 PVOID Context
; /* Pointer to link layer context information */
129 UINT HeaderSize
; /* Size of link level header */
130 UINT MinFrameSize
; /* Minimum frame size in bytes */
131 UINT MTU
; /* Maximum transmission unit */
132 PUCHAR Address
; /* Pointer to interface address */
133 UINT AddressLength
; /* Length of address in bytes */
134 LL_TRANSMIT_ROUTINE Transmit
; /* Transmit function for this interface */
135 } LLIP_BIND_INFO
, *PLLIP_BIND_INFO
;
138 /* Information about an IP interface */
139 typedef struct _IP_INTERFACE
{
141 LIST_ENTRY ListEntry
; /* Entry on list */
142 OBJECT_FREE_ROUTINE Free
; /* Routine used to free resources used by the object */
143 KSPIN_LOCK Lock
; /* Spin lock for this object */
144 PVOID Context
; /* Pointer to link layer context information */
145 UINT HeaderSize
; /* Size of link level header */
146 UINT MinFrameSize
; /* Minimum frame size in bytes */
147 UINT MTU
; /* Maximum transmission unit */
148 IP_ADDRESS Unicast
; /* Unicast address */
149 IP_ADDRESS PointToPoint
; /* Point to point address */
150 IP_ADDRESS Netmask
; /* Netmask */
151 IP_ADDRESS Broadcast
; /* Broadcast */
152 UNICODE_STRING Name
; /* Adapter name */
153 PUCHAR Address
; /* Pointer to interface address */
154 UINT AddressLength
; /* Length of address in bytes */
155 LL_TRANSMIT_ROUTINE Transmit
; /* Pointer to transmit function */
156 PVOID TCPContext
; /* TCP Content for this interface */
157 } IP_INTERFACE
, *PIP_INTERFACE
;
160 #define IP_PROTOCOL_TABLE_SIZE 0x100
162 typedef VOID (*IP_PROTOCOL_HANDLER
)(
163 PIP_INTERFACE Interface
,
164 PIP_PACKET IPPacket
);
166 /* Loopback adapter address information (network byte order) */
167 #define LOOPBACK_ADDRESS_IPv4 ((IPv4_RAW_ADDRESS)DH2N(0x7F000001))
168 #define LOOPBACK_BCASTADDR_IPv4 ((IPv4_RAW_ADDRESS)DH2N(0x7F0000FF))
169 #define LOOPBACK_ADDRMASK_IPv4 ((IPv4_RAW_ADDRESS)DH2N(0xFFFFFF00))
171 /* Protocol definitions */
173 #define IPPROTO_RAW 0 /* Raw IP */
175 #define IPPROTO_ICMP 1 /* Internet Control Message Protocol */
176 #define IPPROTO_IGMP 2 /* Internet Group Management Protocol */
177 #define IPPROTO_TCP 6 /* Transmission Control Protocol */
178 #define IPPROTO_UDP 17 /* User Datagram Protocol */
180 /* Timeout timer constants */
181 #define IP_TICKS_SECOND 2 /* Two ticks per second */
182 #define IP_TIMEOUT (1000 / IP_TICKS_SECOND) /* Timeout in milliseconds */
185 extern LIST_ENTRY InterfaceListHead
;
186 extern KSPIN_LOCK InterfaceListLock
;
187 extern LIST_ENTRY NetTableListHead
;
188 extern KSPIN_LOCK NetTableListLock
;
189 extern UINT MaxLLHeaderSize
;
190 extern UINT MinLLFrameSize
;
192 PIP_PACKET
IPCreatePacket(
195 PIP_PACKET
IPInitializePacket(
199 PIP_INTERFACE
IPCreateInterface(
200 PLLIP_BIND_INFO BindInfo
);
202 VOID
IPDestroyInterface(
205 BOOLEAN
IPRegisterInterface(
208 VOID
IPUnregisterInterface(
211 VOID STDCALL
IPTimeout( PVOID Context
);
213 VOID
IPDispatchProtocol(
214 PIP_INTERFACE Interface
,
215 PIP_PACKET IPPacket
);
217 VOID
IPRegisterProtocol(
219 IP_PROTOCOL_HANDLER Handler
);
221 NTSTATUS
IPStartup(PUNICODE_STRING RegistryPath
);
223 NTSTATUS
IPShutdown(VOID
);