インターフェースのネットマスクを取得する
ネットワークプログラミングを行っていると自分のネットワークインターフェース(NIC)に設定されているIPアドレスだけでなく、ネットマスクも知りたくなる事があると思います。 ここでは、Linuxでインターフェースに設定されているネットマスクを取得する方法を説明したいと思います。
単純なネットマスク取得プログラム
Linuxでの簡単なネットマスク取得プログラムのサンプルを以下に示します。
#include <stdio.h>
#include <string.h> /* for strncpy */
#include <sys/types.h>
#include <sys/socket.h>
#include <sys/ioctl.h>
#include <netinet/in.h>
#include <net/if.h>
int
main()
{
int fd;
struct ifreq ifr;
fd = socket(AF_INET, SOCK_DGRAM, 0);
/* IPv4のネットマスクを取得したい */
ifr.ifr_addr.sa_family = AF_INET;
/* eth0のネットマスクを取得したい */
strncpy(ifr.ifr_name, "eth0", IFNAMSIZ-1);
ioctl(fd, SIOCGIFNETMASK, &ifr);
close(fd);
/* 結果を表示 */
printf("%s\n", inet_ntoa(((struct sockaddr_in *)&ifr.ifr_addr)->sin_addr));
return 0;
}
Linuxでは、IPアドレス取得と同様にネットマスク情報を取得するためにioctlを利用します。 ioctlを使用するにはソケットを開く必要があります。 IPアドレスを取得するために既にソケットを開いていたり、他の用途で作成したソケットがある場合にはそれを利用することも可能です。 作るソケットはAF_INETであればTCP(SOCK_STREAM)でもUDP(SOCK_DGRAM)でもかまいません。 このサンプルではUDPのソケットを利用しています。
ネットマスクを取得するために開いたソケットは、アドレス情報の取得とともにcloseしてしまっても大丈夫です。 もちろん、ソケットをそのまま使い続ける事も可能です。