rtnetlink_socket = socket(AF_NETLINK, int socket_type, NETLINK_ROUTE);
struct rtattr {
unsigned short rta_len; /* Length of option */
unsigned short rta_type; /* Type of option */
/* Data follows */ };
これらの属性の操作は、 RTA_* マクロか libnetlink のみを使って行うべきである。 rtnetlink(3) を見よ。
| ルーティング属性 |
||
| rta_type | 値の型 | 説明 |
|
|
||
| IFLA_UNSPEC | - | 指定されていない |
| IFLA_ADDRESS | hardware address | インターフェース L2 アドレス |
| IFLA_BROADCAST | hardware address | L2 ブロードキャストアドレス |
| IFLA_IFNAME | asciiz string | デバイス名 |
| IFLA_MTU | unsigned int | デバイスの MTU |
| IFLA_LINK | int | リンクタイプ |
| IFLA_QDISC | asciiz string | キューイングのルール |
| IFLA_STATS | 下記参照 | インターフェースの統計 |
| 属性 |
||
| rta_type | 値の型 | 説明 |
|
|
||
| IFA_UNSPEC | - | 指定されていない |
| IFA_ADDRESS | raw protocol address | インターフェースアドレス |
| IFA_LOCAL | raw protocol address | ローカルアドレス |
| IFA_LABEL | asciiz string | インターフェースの名前 |
| IFA_BROADCAST | raw protocol address | ブロードキャストアドレス |
| IFA_ANYCAST | raw protocol address | anycast アドレス |
| IFA_CACHEINFO | struct ifa_cacheinfo | アドレス情報 |
unsigned int rtm_flags; };
| rtm_type | 経路のタイプ |
|
|
|
| RTN_UNSPEC | 未知の経路 |
| RTN_UNICAST | ゲートウェイまたはダイレクトな経路 |
| RTN_LOCAL | ローカルインターフェースの経路 |
| RTN_BROADCAST | ローカルなブロードキャスト経路 (ブロードキャストとして送信される) |
| RTN_ANYCAST | ローカルなブロードキャスト経路 (ユニキャストとして送信される) |
| RTN_MULTICAST | マルチキャスト経路 |
| RTN_BLACKHOLE | パケットを捨てる経路 |
| RTN_UNREACHABLE | 到達できない行き先 |
| RTN_PROHIBIT | パケットを拒否する経路 |
| RTN_THROW | 経路探索を別のテーブルで継続 |
| RTN_NAT | ネットワークアドレスの変換ルール |
| RTN_XRESOLVE | 外部レゾルバを参照 (実装されていない) |
| rtm_protocol | 経路の情報源 |
|
|
|
| RTPROT_UNSPEC | 不明 |
| RTPROT_REDIRECT | ICMP リダイレクトによる (現在は用いられない) |
| RTPROT_KERNEL | カーネルによる |
| RTPROT_BOOT | ブート時 |
| RTPROT_STATIC | 管理者による |
RTPROT_STATIC よりも大きな値はカーネルによって解釈されない。これは 単なるユーザーへの情報である。これらは経路情報の情報源を タグ付けしたり、複数のルーティングデーモンからの情報を 区別するために用いることができる。 既に割り当てられているルーティングデーモンの識別子については <linux/rtnetlink.h> を見よ。
| RT_SCOPE_UNIVERSE | グローバルな経路 |
| RT_SCOPE_SITE | ローカルな自律システムにおける内部経路 |
| RT_SCOPE_LINK | このリンク上の経路 |
| RT_SCOPE_HOST | ローカルホスト上の経路 |
| RT_SCOPE_NOWHERE | 行き先が存在しない |
ユーザーは RT_SCOPE_UNIVERSE と RT_SCOPE_SITE の間の値を用いることができる。
| RTM_F_NOTIFY | 経路が変更されると、 rtnetlink を通してユーザーに通知が行く。 |
| RTM_F_CLONED | 経路は他の経路によって複製された。 |
| RTM_F_EQUALIZE | マルチパスイコライザ (まだ実装されていない) |
rtm_table ではルーティングテーブルを指定する。
| RT_TABLE_UNSPEC | 指定されていないルーティングテーブル |
| RT_TABLE_DEFAULT | デフォルトのテーブル |
| RT_TABLE_MAIN | メインのテーブル |
| RT_TABLE_LOCAL | ローカルテーブル |
ユーザーは RT_TABLE_UNSPEC と RT_TABLE_DEFAULT. の間の任意の値を用いることができる。
| 属性 |
||
| rta_type | 値の型 | 説明 |
|
|
||
| RTA_UNSPEC | - | 無視される |
| RTA_DST | protocol address | 経路の行き先アドレス |
| RTA_SRC | protocol address | 経路の発信元アドレス |
| RTA_IIF | int | 入力インターフェースの index |
| RTA_OIF | int | 出力インターフェースの index |
| RTA_GATEWAY | protocol address | 経路のゲートウェイ |
| RTA_PRIORITY | int | 経路の優先度 |
| RTA_PREFSRC | protocol address | Preferred source address |
| RTA_METRICS | int | 経路のメトリック |
| RTA_MULTIPATH | Multipath nexthop data br (see below). |
|
| RTA_PROTOINFO | No longer used |
|
| RTA_FLOW | int | Route realm |
| RTA_CACHEINFO | struct rta_cacheinfo | (linux/rtnetlink.h 参照) |
| RTA_SESSION | No longer used |
|
| RTA_MP_ALGO | No longer used |
|
| RTA_TABLE | int | Routing table ID; if set, rtm_table is ignored |
| RTA_MARK | int | |
| RTA_MFC_STATS | struct rta_mfc_stats | (linux/rtnetlink.h 参照) |
| RTA_VIA | struct rtvia | Gateway in different AF (see below) |
| RTA_NEWDST | protocol address | パケットの経路の行き先アドレスを変更する |
| RTA_PREF | char | RFC4191 IPv6 router preference (see below) |
| RTA_ENCAP_TYPE | short | Encapsulation type for lwtunnels (下記参照) |
| RTA_ENCAP | Defined by RTA_ENCAP_TYPE |
|
| RTA_EXPIRES | int | Expire time for IPv6 routes (in seconds) |
struct nda_cacheinfo {
__u32 ndm_confirmed;
__u32 ndm_used;
__u32 ndm_updated;
__u32 ndm_refcnt; };
| NUD_INCOMPLETE | 現在レゾルブ中のキャッシュエントリー |
| NUD_REACHABLE | 動作確認済みのキャッシュエントリー |
| NUD_STALE | 期限切れのキャッシュエントリー |
| NUD_DELAY | タイマー待ちのキャッシュエントリー |
| NUD_PROBE | 再確認中のキャッシュエントリー |
| NUD_FAILED | 不正なキャッシュエントリー |
| NUD_NOARP | 行き先キャッシュのないデバイス |
| NUD_PERMANENT | 静的なエントリー |
有効な ndm_flags は以下の通り:
| NTF_PROXY | プロクシ arp エントリー |
| NTF_ROUTER | IPv6 ルータ |
rtattr 構造体は、 rta_type フィールドに応じてそれぞれ以下の意味を持つ:
| NDA_UNSPEC | 未知のタイプ |
| NDA_DST | 近傍キャッシュネットワーク層の行き先アドレス |
| NDA_LLADDR | 近傍キャッシュリンク層のアドレス |
| NDA_CACHEINFO | キャッシュの統計 |
rta_type フィールドが NDA_CACHEINFO の場合には、 struct nda_cacheinfo ヘッダーが続く。
| 属性 |
||
| rta_type | 値の型 | 説明 |
|
|
||
| TCA_UNSPEC | - | 指定されていない |
| TCA_KIND | asciiz string | キューイングルールの名前 |
| TCA_OPTIONS | byte sequence | Qdisc 特有のオプションが続く |
| TCA_STATS | struct tc_stats | Qdisc の統計 |
| TCA_XSTATS | qdisc-specific | モジュール特有の統計 |
| TCA_RATE | struct tc_estimator | レート制限 |
さらに、 qdisc モジュール特有の様々な属性を指定できる。 詳細な情報は適切なインクルードファイルを見よ。
[man1]
[man2]
[man3]
[man4]
[man5]
[man6]
[man7]
[man8]
[a]
[b]
[c]
[d]
[e]
[f]
[g]
[h]
[i]
[j]
[k]
[l]
[m]
[n]
[o]
[p]
[q]
[r]
[s]
[t]
[u]
[v]
[w]
[x]
[y]
[z]