* Implemented AddInterface(), and RemoveInterface().

* Added comment explaining why using AF_INET is not really a good idea.


git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@38057 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Axel Dörfler 2010-08-12 13:30:39 +00:00
parent b85c513ee7
commit 530f548320

View File

@ -15,6 +15,13 @@
#include <AutoDeleter.h> #include <AutoDeleter.h>
// TODO: using AF_INET for the socket isn't really a smart idea, as one
// could completely remove IPv4 support from the stack easily.
// Since in the stack, device_interfaces are pretty much interfaces now, we
// could get rid of them more or less, and make AF_LINK provide the same
// information as AF_INET for the interface functions mostly.
BNetworkRoster BNetworkRoster::sDefault; BNetworkRoster BNetworkRoster::sDefault;
@ -101,16 +108,37 @@ BNetworkRoster::GetNextInterface(uint32* cookie,
status_t status_t
BNetworkRoster::AddInterface(const BNetworkInterface& interface) BNetworkRoster::AddInterface(const BNetworkInterface& interface)
{ {
// TODO: implement me int socket = ::socket(AF_INET, SOCK_DGRAM, 0);
return B_NOT_SUPPORTED; if (socket < 0)
return errno;
ifaliasreq request;
memset(&request, 0, sizeof(ifaliasreq));
strlcpy(request.ifra_name, interface.Name(), IF_NAMESIZE);
if (ioctl(socket, SIOCAIFADDR, &request, sizeof(request)) != 0)
return errno;
return B_OK;
} }
status_t status_t
BNetworkRoster::RemoveInterface(const BNetworkInterface& interface) BNetworkRoster::RemoveInterface(const BNetworkInterface& interface)
{ {
// TODO: implement me int socket = ::socket(AF_INET, SOCK_DGRAM, 0);
return B_NOT_SUPPORTED; if (socket < 0)
return errno;
ifreq request;
strlcpy(request.ifr_name, interface.Name(), IF_NAMESIZE);
request.ifr_addr.sa_family = AF_UNSPEC;
if (ioctl(socket, SIOCDIFADDR, &request, sizeof(request)) != 0)
return errno;
return B_OK;
} }