Internet Protocol Control Protocol

Last updated

In computer networking, Internet Protocol Control Protocol (IPCP) is a Network Control Protocol (NCP) for establishing and configuring Internet Protocol over a Point-to-Point Protocol link. IPCP is responsible for configuring the IP addresses as well as for enabling and disabling the IP protocol modules on both ends of the point-to-point link. IPCP uses the same packet exchange mechanism as the Link Control Protocol. IPCP packets may not be exchanged until PPP has reached the Network-Layer Protocol phase, and any IPCP packets received before this phase is reached should be silently discarded. IPCP has the NCP protocol code number 0x8021.

Contents

Each of the two endpoints of a PPP connection must send an IPCP configure request to its peer because the TCP/IP options are independent for each direction of a PPP connection. [1]

A PPP endpoint can request a specific IP address from its peer. It can also ask the peer to suggest an IP address by requesting the address 0.0.0.0; the peer then sends its suggestion in an IPCP Nak packet, which the first peer must subsequently request in order to complete the negotiation. In practice, in protocols like PPPoE which is commonly used in home broadband connections, the latter method (request suggestion, nak with suggestion, request suggested address) is used to set the IP address of the ISP's client endpoint (i.e. the customer-premises equipment), while the former method (request address) is used to inform the client of the ISP endpoint IP (provider edge equipment).[ clarification needed ]

A similar NCP, the IPv6 Control Protocol exists for IPv6. It can be used together with IPCP on the same PPP connection for a dual stack link. (When interfacing newer and older equipment that doesn't support IPv6 one sees LCP ProtRej messages for protocol 0x8057 from the side that doesn't support IPV6CP.)

IP Frame

After the configuration is done, the link is able to carry IP data as a payload of the PPP frame. This code indicates that IP data is being carried.

PPP headerIPCP headerData:::

IPCP header:

Offsets Octet 0123
Octet Bit 012345678910111213141516171819202122232425262728293031
00CodeIdentifierLength

Code.

8 bits.
Specifies the function to be performed.

CodeDescriptionReferences
0Vendor Specific.RFC  2153
1Configure-Request. 
2Configure-Ack. 
3Configure-Nak. 
4Configure-Reject. 
5Terminate-Request. 
6Terminate-Ack. 
7Code-Reject. 

Identifier. 8 bits.

Used to match requests and replies.

Length. 16 bits.
Size of the packet including the header.

Data. Variable length.
Zero or more bytes of data as indicated by the Length. This field may contain one or more Options.

Configuration Options

IPCP Configuration Options allow negotiatiation of desirable Internet Protocol parameters. IPCP uses the same Configuration Option format defined for LCP Link Control Protocol, with a separate set of Options.

IPCP Configuration Options:

00010203040506070809101112131415
OptionLength
Data

Option. 8 bits.

OptionLengthDescriptionReferences
110IP-Addresses (deprecated)RFC  1172, RFC  1332
2≥4IP-Compression-ProtocolRFC  1332, RFC  3241, RFC  3544
36IP-Address.RFC  1332
46Mobile-IPv4.RFC  2290
1296Primary DNS Server Address.RFC  1877
1306Primary NBNS Server Address.RFC  1877
1316Secondary DNS Server Address.RFC  1877
1326Secondary NBNS Server Address.RFC  1877

Length. 8 bits.

Data. Variable length.

IP-Compression-Protocol

TypeLengthIP-Compression-ProtocolData
1 byte1 byte2 bytesvariable

IP-Address

TypeLengthIP address
1 byte1 byte4 bytes

Microsoft

In the Microsoft implementation, "Common IPCP options include an IP address and the IP addresses of DNS and NetBIOS name servers." [2]

See also

References