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:
Hugo Santos 2007-04-01 23:46:24 +00:00
parent 5d4d5313c7
commit a073ba1aa8

View File

@ -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;
} }