Provided by: manpages-ja_0.5.0.0.20131015+dfsg-2_all
名前
netdevice - Linux ネットワークデバイスへの低レベルアクセス
書式
#include <sys/ioctl.h> #include <net/if.h>
説明
この man ページでは、ネットワークデバイスを設定するために 用いるソケットインターフェースに ついて解説する。 Linux はネットワークデバイスを設定するための標準的な ioctl を いくつか備えている。これらは どんなソケットのファイルディスクリプタにも 用いることができる。ファミリーやタイプは何でも よい。 これらの ioctl は ifreq 構造体を渡す。 struct ifreq { char ifr_name[IFNAMSIZ]; /* Interface name */ union { struct sockaddr ifr_addr; struct sockaddr ifr_dstaddr; struct sockaddr ifr_broadaddr; struct sockaddr ifr_netmask; struct sockaddr ifr_hwaddr; short ifr_flags; int ifr_ifindex; int ifr_metric; int ifr_mtu; struct ifmap ifr_map; char ifr_slave[IFNAMSIZ]; char ifr_newname[IFNAMSIZ]; char *ifr_data; }; }; struct ifconf { int ifc_len; /* size of buffer */ union { char *ifc_buf; /* buffer address */ struct ifreq *ifc_req; /* array of structures */ }; }; 通常、ユーザーによる設定対象デバイスの指定は、 ifr_name にインターフェースの名前をセットす ることによって行う。 他の構造体の全てのメンバは、メモリを共有する。 ioctl 「特権が必要」と記述されている ioctl を実行するには、 実効ユーザー ID が 0 か、 CAP_NET_ADMIN 権限が必要である。これが満たされていない場合は EPERM が返される。 SIOCGIFNAME ifr_ifindex を受け取り、インターフェースの名前を ifr_name に入れて返す。これは結果 を ifr_name として返す唯一の ioctl である。 SIOCGIFINDEX インターフェースの interface index を取得し、 ifr_ifindex に入れて返す。 SIOCGIFFLAGS, SIOCSIFFLAGS デバイスの active フラグワードを取得または設定する。 ifr_flags には以下の値のビット マスクが入る。 デバイスフラグ IFF_UP インターフェースは動作中。 IFF_BROADCAST 有効なブロードキャストアドレスがセットされている。 IFF_DEBUG 内部のデバッグフラグ。 IFF_LOOPBACK インターフェースはループバックである。 IFF_POINTOPOINT インターフェースは point-to-point リンクである。 IFF_RUNNING リソースが割り当て済み。 IFF_NOARP arp プロトコルがない。 L2 宛先アドレスが設定されて いない。 IFF_PROMISC インターフェースは promiscuous モードである。 IFF_NOTRAILERS trailer の利用を避ける。 IFF_ALLMULTI 全てのマルチキャストパケットを受信する。 IFF_MASTER 負荷分散グループのマスターである。 IFF_SLAVE 負荷分散グループのスレーブである。 IFF_MULTICAST マルチキャストをサポートしている。 IFF_PORTSEL ifmap によってメディアタイプを選択できる。 IFF_AUTOMEDIA 自動メディア選択が有効になっている。 IFF_DYNAMIC このインターフェースが閉じると、アドレスは失われ る。 IFF_LOWER_UP ドライバからの L1 アップの通知 (Linux 2.6.17 以降) IFF_DORMANT ドライバからの休止状態の通知 (Linux 2.6.17 以降) IFF_ECHO 送られたパケットをエコーする (Linux 2.6.25 以降) active フラグワードの設定は特権が必要な操作である。 読み出しはどんなプロセスからも 可能である。 SIOCGIFPFLAGS, SIOCSIFPFLAGS デバイスの拡張 (プライベート) フラグを取得または設定する。 ifr_flags には以下の値の ビットマスクが入る。 プライベートフラグ IFF_802_1Q_VLAN インターフェースは 802.1Q VLAN デバイスである。 IFF_EBRIDGE インターフェースは Ethernet ブリッジデバイスである。 IFF_SLAVE_INACTIVE インターフェースは非アクティブな bonding のスレーブである。 IFF_MASTER_8023AD インターフェースは 802.3ad bonding のマスターである。 IFF_MASTER_ALB インターフェースは balanced-alb bonding のマスターである。 IFF_BONDING インターフェースは bonding のマスターかスレーブである。 IFF_SLAVE_NEEDARP インターフェースは検証に APR が必要である。 IFF_ISATAP インターフェースは RFC4214 ISATAP インターフェースである。 拡張 (プライベート) インターフェースフラグの設定には特権が必要である。 SIOCGIFADDR, SIOCSIFADDR ifr_addr を用いてデバイスのアドレスの設定/取得を行う。 インターフェースのアドレスの 設定は特権が必要な操作である。 互換性確保のため、設定/取得ができるのは AF_INET アド レスだけである。 SIOCGIFDSTADDR, SIOCSIFDSTADDR point-to-point デバイスの宛先アドレスを ifr_dstaddr を用いて 設定/取得する。互換性 確保のため、 設定/取得ができるのは AF_INET アドレスだけである。 宛先アドレスの設定 は特権が必要な操作である。 SIOCGIFBRDADDR, SIOCSIFBRDADDR デバイスのブロードキャストアドレスを ifr_brdaddr を用いて 設定/取得する。互換性確保 のため、 設定/取得ができるのは AF_INET アドレスだけである。 ブロードキャストアドレ スの設定は特権が必要な操作である。 SIOCGIFNETMASK, SIOCSIFNETMASK デバイスのネットワークマスクを ifr_netmask を用いて 設定/取得する。互換性確保のた め、 設定/取得ができるのは AF_INET アドレスだけである。 ネットワークマスクの設定は 特権が必要な操作である。 SIOCGIFMETRIC, SIOCSIFMETRIC デバイスのメトリックを ifr_metric を用いて取得・設定する。 これはまだ実装されていな い。読み出そうとすると ifr_metric に 0 をセットして返り、設定しようとすると EOPNOTSUPP が返る。 SIOCGIFMTU, SIOCSIFMTU デバイスの MTU (Maximum Transfer Unit) を ifr_mtu を用いて取得・設定する。 MTU の設 定は特権が必要な操作である。 MTU の値を小さくしすぎるとカーネルがクラッシュするかも しれない。 SIOCGIFHWADDR, SIOCSIFHWADDR デバイスのハードウェアアドレスを ifr_hwaddr を用いて取得・設定する。 ハードウェアア ドレスは sockaddr 構造体に設定される。 sa_family には ARPHRD_* デバイスタイプが入 り、 sa_data にはバイト 0 から始まる L2 ハードウェアアドレスが入る。 ハードウェアア ドレスの設定は特権が必要な操作である。 SIOCSIFHWBROADCAST デバイスのハードウェアブロードキャストアドレスを ifr_hwaddr の値に設定する。この操 作には特権が必要である。 SIOCGIFMAP, SIOCSIFMAP インターフェースのハードウェアのパラメータを ifr_map を用いて取得・設定する。 パラ メータの設定は特権が必要な操作である。 struct ifmap { unsigned long mem_start; unsigned long mem_end; unsigned short base_addr; unsigned char irq; unsigned char dma; unsigned char port; }; ifmap 構造体の解釈はデバイスドライバとアーキテクチャに依存する。 SIOCADDMULTI, SIOCDELMULTI デバイスのリンク層のマルチキャストフィルターから、 ifr_hwaddr のアドレスを追加・削 除する。これらの操作には特権が必要である。 別の方法が packet(7) で解説されている。 SIOCGIFTXQLEN, SIOCSIFTXQLEN デバイスの送信キューの長さを ifr_qlen に取得・設定する。送信キューの長さの設定には 特権が必要である。 SIOCSIFNAME ifr_name で指定したインターフェースの名前を ifr_newname に変更する。この操作には特 権が必要である。インターフェースが up していない 時にのみ使用できる。 SIOCGIFCONF インターフェース(トランスポート層)アドレスのリストを返す。 現在のところ、互換性のた めに AF_INET (IPv4) ファミリーのアドレスのみである。 ユーザーは ifconf 構造体を ioctl の引数として渡す。 ifconf 構造体には、 ifreq 構造体の配列へのポインタである ifc_req と、バイト単位の配列の長さを指定する ifc_len が含まれる。 カーネルは ifreqs を現在動作している全ての L3 インターフェースアドレスで埋める。 ifr_name にはイン ターフェース名 (eth0:1 など) が入り、 ifr_addr にはアドレスが入る。 カーネルは実際 の長さを ifc_len に返す。 ifc_len が元のバッファの長さと同じだった場合、 オーバーフ ローを起こしている可能性があるので、 全てのアドレスを取得するためにより大きなバッ ファで再試行するべきである。 エラーがなかった場合は ioctl は 0 を返す。 エラーが あった場合は -1 を返す。 オーバーフローはエラーとは見なされない。 ほとんどのプロトコルには、専用のインターフェースオプションを 設定するための独自の ioctl が 存在する。 説明は各プロトコルの man ページを見よ。 さらに、デバイスによってはプライベートな ioctl がある。 これらはここでは説明しない。
注意
厳密にいうと、 SIOCGIFCONF や、 AF_INET ソケットアドレスだけを 引き数に取ったり返したりす る他の ioctl は IP 固有であり、 ip(7) に属する。 アドレスがなかったり、 IFF_RUNNING フラグがセットされていないインターフェースの名前は /proc/net/dev で知ることができる。 ローカル IPV6 IP アドレスは /proc/net か rtnetlink(7) で知ることができる。
バグ
glibc 2.1 では <net/if.h> に ifr_newname マクロがない。 とりあえずの対応策として、以下の コードを追加しておくこと。 #ifndef ifr_newname #define ifr_newname ifr_ifru.ifru_slave #endif
関連項目
proc(5), capabilities(7), ip(7), rtnetlink(7)
この文書について
この man ページは Linux man-pages プロジェクトのリリース 3.54 の一部 である。プロジェクト の説明とバグ報告に関する情報は http://www.kernel.org/doc/man-pages/ に書かれている。