Now also supports setting a gateway through the configuration.

git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@19085 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Axel Dörfler 2006-10-19 12:20:44 +00:00
parent 53d1802e02
commit 535df2cff3

View File

@ -280,7 +280,7 @@ NetServer::_ConfigureInterface(int socket, BMessage& interface)
// retrieve addresses // retrieve addresses
bool hasAddress = false, hasMask = false, hasPeer = false, hasBroadcast = false; bool hasAddress = false, hasMask = false, hasPeer = false, hasBroadcast = false;
struct sockaddr address, mask, peer, broadcast; struct sockaddr address, mask, peer, broadcast, gateway;
const char* string; const char* string;
if (addressMessage.FindString("address", &string) == B_OK if (addressMessage.FindString("address", &string) == B_OK
@ -298,6 +298,23 @@ NetServer::_ConfigureInterface(int socket, BMessage& interface)
&& parse_address(familyIndex, string, broadcast)) && parse_address(familyIndex, string, broadcast))
hasBroadcast = true; hasBroadcast = true;
// add gateway route, if we're asked for it
if (addressMessage.FindString("gateway", &string) == B_OK
&& parse_address(familyIndex, string, gateway)) {
route_entry route;
memset(&route, 0, sizeof(route_entry));
route.gateway = &gateway;
route.flags = RTF_STATIC | RTF_DEFAULT | RTF_GATEWAY;
request.ifr_route = route;
if (ioctl(socket, SIOCADDRT, &request, sizeof(request)) < 0) {
fprintf(stderr, "%s: Could not add route for %s: %s\n",
Name(), device, strerror(errno));
}
}
// set addresses // set addresses
if (hasAddress) { if (hasAddress) {
@ -417,6 +434,7 @@ NetServer::_ConfigureDevice(int socket, const char* path)
BMessage address; BMessage address;
address.AddString("family", "inet"); address.AddString("family", "inet");
address.AddString("address", "192.168.0.56"); address.AddString("address", "192.168.0.56");
address.AddString("gateway", "192.168.0.254");
interface.AddMessage("address", &address); interface.AddMessage("address", &address);
return _ConfigureInterface(socket, interface); return _ConfigureInterface(socket, interface);