The PROTOCOL_INFO structure contains information about a protocol.
typedef struct _PROTOCOL_INFO { DWORD dwServiceFlags; INT iAddressFamily; INT iMaxSockAddr; INT iMinSockAddr; INT iSocketType; INT iProtocol; DWORD dwMessageSize; LPTSTR lpProtocol; } PROTOCOL_INFO;
Value |
Meaning |
XP_CONNECTIONLESS |
If this flag is set, the protocol providesconnectionless (datagram) service. If this flag is clear, the protocol provides connection-oriented data transfer. |
XP_GUARANTEED_DELIVERY |
If this flag is set, the protocol guarantees that all data sent will reach the intended destination. If this flag is clear, there is no such guarantee. |
XP_GUARANTEED_ORDER |
If this flag is set, the protocol guarantees that data will arrive in the order in which it was sent. Note that this characteristic does not guarantee delivery of the data, but guarantees only its order. If this flag is clear, the order of data sent is not guaranteed. |
XP_MESSAGE_ORIENTED |
If this flag is set, the protocol is message-oriented. A message-oriented protocol honors message boundaries. If this flag is clear, the protocol is stream-oriented, and the concept of message boundaries is irrelevant. |
XP_PSEUDO_STREAM |
If this flag is set, the protocol is a message-oriented protocol that ignores message boundaries for all receive operations. This optional capability is useful when you do not want the protocol to frame messages. An application that requires stream-oriented characteristics can open a socket with type SOCK_STREAM for transport protocols that support this functionality, regardless of the value of iSocketType. |
XP_GRACEFUL_CLOSE |
If this flag is set, the protocol supports two-phase close operations, also known as “graceful” close operations. If this flag is clear, the protocol supports only abortive close operations. |
XP_EXPEDITED_DATA |
If this flag is set, the protocol supports expedited data, also known as “urgent data.” |
XP_CONNECT_DATA |
If this flag is set, the protocol supports connect data. |
XP_DISCONNECT_DATA |
If this flag is set, the protocol supports disconnect data. |
XP_SUPPORTS_BROADCAST |
If this flag is set, the protocol supports a broadcast mechanism. |
XP_SUPPORTS_MULTICAST |
If this flag is set, the protocol supports a multicast mechanism. |
XP_BANDWIDTH_ALLOCATION |
If this flag is set, the protocol supports a mechanism for allocating a guaranteed bandwidth to an application. |
XP_FRAGMENTATION |
If this flag isset, the protocol supports message fragmentation; physical network MTU is hidden from applications. |
XP_ENCRYPTS |
If this flag is set, the protocol supports data encryption. |
Note that if XP_PSEUDO_STREAM is set in dwServiceFlags, the application
can specify SOCK_STREAM as the type parameter to socket,
regardless of the value of iSocketType.
The following special message size values are defined:
Value |
Meaning |
0 |
The protocol is stream-oriented; the concept of message size is not relevant. |
0xFFFFFFFF |
The protocol is message-oriented, but there is no maximum message size. |
file: /Techref/os/win/api/win32/struc/src/str14_15.htm, 7KB, , updated: 2000/4/7 11:14, local time: 2025/1/15 13:09,
3.22.71.149:LOG IN
|
©2025 These pages are served without commercial sponsorship. (No popup ads, etc...).Bandwidth abuse increases hosting cost forcing sponsorship or shutdown. This server aggressively defends against automated copying for any reason including offline viewing, duplication, etc... Please respect this requirement and DO NOT RIP THIS SITE. Questions? <A HREF="http://linistepper.com/Techref/os/win/api/win32/struc/src/str14_15.htm"> PROTOCOL_INFO</A> |
Did you find what you needed? |