DHCP: since we are only installing routes while handling an OFFER, request gateway in DISCOVER. Fixes an issue where the gateway address is not configured.
git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@20506 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
5d4d5313c7
commit
a073ba1aa8
@ -126,11 +126,13 @@ struct dhcp_message {
|
|||||||
message_type Type() const;
|
message_type Type() const;
|
||||||
const uint8* LastOption() const;
|
const uint8* LastOption() const;
|
||||||
|
|
||||||
|
uint8* PrepareMessage(uint8 type);
|
||||||
uint8* PutOption(uint8* options, message_option option);
|
uint8* PutOption(uint8* options, message_option option);
|
||||||
uint8* PutOption(uint8* options, message_option option, uint8 data);
|
uint8* PutOption(uint8* options, message_option option, uint8 data);
|
||||||
uint8* PutOption(uint8* options, message_option option, uint16 data);
|
uint8* PutOption(uint8* options, message_option option, uint16 data);
|
||||||
uint8* PutOption(uint8* options, message_option option, uint32 data);
|
uint8* PutOption(uint8* options, message_option option, uint32 data);
|
||||||
uint8* PutOption(uint8* options, message_option option, const uint8* data, uint32 size);
|
uint8* PutOption(uint8* options, message_option option, const uint8* data, uint32 size);
|
||||||
|
uint8* FinishOptions(uint8 *);
|
||||||
} _PACKED;
|
} _PACKED;
|
||||||
|
|
||||||
#define DHCP_FLAG_BROADCAST 0x8000
|
#define DHCP_FLAG_BROADCAST 0x8000
|
||||||
@ -150,10 +152,8 @@ dhcp_message::dhcp_message(message_type type)
|
|||||||
memset(this, 0, sizeof(*this));
|
memset(this, 0, sizeof(*this));
|
||||||
options_magic = htonl(OPTION_MAGIC);
|
options_magic = htonl(OPTION_MAGIC);
|
||||||
|
|
||||||
uint8* next = options;
|
uint8* next = PrepareMessage(type);
|
||||||
next = PutOption(next, OPTION_MESSAGE_TYPE, (uint8)type);
|
FinishOptions(next);
|
||||||
next = PutOption(next, OPTION_MESSAGE_SIZE, (uint16)htons(sizeof(dhcp_message)));
|
|
||||||
next = PutOption(next, OPTION_END);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -267,6 +267,15 @@ dhcp_message::Size() const
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
uint8*
|
||||||
|
dhcp_message::PrepareMessage(uint8 type)
|
||||||
|
{
|
||||||
|
uint8 *next = options;
|
||||||
|
next = PutOption(next, OPTION_MESSAGE_TYPE, type);
|
||||||
|
next = PutOption(next, OPTION_MESSAGE_SIZE, (uint16)htons(sizeof(dhcp_message)));
|
||||||
|
return next;
|
||||||
|
}
|
||||||
|
|
||||||
uint8*
|
uint8*
|
||||||
dhcp_message::PutOption(uint8* options, message_option option)
|
dhcp_message::PutOption(uint8* options, message_option option)
|
||||||
{
|
{
|
||||||
@ -307,6 +316,13 @@ dhcp_message::PutOption(uint8* options, message_option option, const uint8* data
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
uint8*
|
||||||
|
dhcp_message::FinishOptions(uint8 *next)
|
||||||
|
{
|
||||||
|
return PutOption(next, OPTION_END);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// #pragma mark -
|
// #pragma mark -
|
||||||
|
|
||||||
|
|
||||||
@ -653,10 +669,7 @@ DHCPClient::_PrepareMessage(dhcp_message& message, dhcp_state state)
|
|||||||
case DHCP_RELEASE:
|
case DHCP_RELEASE:
|
||||||
{
|
{
|
||||||
// add server identifier option
|
// add server identifier option
|
||||||
uint8* next = message.options;
|
uint8* next = message.PrepareMessage(type);
|
||||||
next = message.PutOption(next, OPTION_MESSAGE_TYPE, (uint8)DHCP_REQUEST);
|
|
||||||
next = message.PutOption(next, OPTION_MESSAGE_SIZE,
|
|
||||||
(uint16)htons(sizeof(dhcp_message)));
|
|
||||||
next = message.PutOption(next, OPTION_SERVER_ADDRESS,
|
next = message.PutOption(next, OPTION_SERVER_ADDRESS,
|
||||||
(uint32)fServer.sin_addr.s_addr);
|
(uint32)fServer.sin_addr.s_addr);
|
||||||
|
|
||||||
@ -669,7 +682,16 @@ DHCPClient::_PrepareMessage(dhcp_message& message, dhcp_state state)
|
|||||||
} else
|
} else
|
||||||
message.client_address = fAssignedAddress;
|
message.client_address = fAssignedAddress;
|
||||||
|
|
||||||
next = message.PutOption(next, OPTION_END);
|
message.FinishOptions(next);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case DHCP_DISCOVER:
|
||||||
|
{
|
||||||
|
uint8 *next = message.PrepareMessage(type);
|
||||||
|
next = message.PutOption(next, OPTION_REQUEST_PARAMETERS,
|
||||||
|
kRequiredParameters, sizeof(kRequiredParameters));
|
||||||
|
message.FinishOptions(next);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user