Man page - raw(7)
Packages contains this manual
- shm_overview(7)
- nss(5)
- proc_mtrr(5)
- intro(7)
- tcp(7)
- iso_8859-9(7)
- armscii-8(7)
- proc_kpagecount(5)
- initrd(4)
- mouse(4)
- proc_stat(5)
- x25(7)
- proc_interrupts(5)
- fifo(7)
- repertoiremap(5)
- icmp(7)
- futex(7)
- feature_test_macros(7)
- lp(4)
- bpf-helpers(7)
- epoll(7)
- proc_sys_dev(5)
- namespaces(7)
- proc_sysrq-trigger(5)
- proc_bus(5)
- cp1251(7)
- proc_pid_maps(5)
- proc_sys_vm(5)
- proc_pid_projid_map(5)
- st(4)
- proc_pid(5)
- issue(5)
- pid_namespaces(7)
- unicode(7)
- inode(7)
- hosts.equiv(5)
- iso-8859-13(7)
- proc_fb(5)
- proc_modules(5)
- proc_pid_autogroup(5)
- keyrings(7)
- sysvipc(7)
- proc_kmsg(5)
- cgroups(7)
- latin6(7)
- proc_pid_uid_map(5)
- unix(7)
- proc_pid_io(5)
- pts(4)
- packet(7)
- ld-linux.so(8)
- tzselect(8)
- iconv(1)
- proc_pid_syscall(5)
- proc_pid_net(5)
- proc_pid_pagemap(5)
- tty(4)
- proc_profile(5)
- standards(7)
- proc_pid_mounts(5)
- filesystems(5)
- iso-8859-15(7)
- locale(5)
- iso_8859_3(7)
- xattr(7)
- iso-8859-2(7)
- proc_uptime(5)
- persistent-keyring(7)
- credentials(7)
- proc_pid_timers(5)
- utmpx(5)
- vcsa(4)
- proc_pid_exe(5)
- proc_net(5)
- proc_timer_stats(5)
- ip(7)
- proc_pid_fd(5)
- ptmx(4)
- user_namespaces(7)
- resolv.conf(5)
- url(7)
- iso_8859_5(7)
- iso_8859-8(7)
- urn(7)
- process-keyring(7)
- proc_pid_auxv(5)
- proc_ksyms(5)
- proc_ide(5)
- veth(4)
- ldd(1)
- proc_swaps(5)
- landlock(7)
- proc_vmstat(5)
- system_data_types(7)
- cp1252(7)
- lirc(4)
- proc_kpageflags(5)
- random(7)
- precedence(7)
- cpuset(7)
- proc_pid_ns(5)
- acct(5)
- latin4(7)
- proc_pid_cgroup(5)
- proc_cpuinfo(5)
- iso_8859-2(7)
- proc_keys(5)
- charsets(7)
- pldd(1)
- proc_pid_stat(5)
- rtnetlink(7)
- netlink(7)
- ram(4)
- mem(4)
- iso-8859-6(7)
- proc_key-users(5)
- iso_8859_15(7)
- fanotify(7)
- proc_sys_net(5)
- sysfs(5)
- math_error(7)
- latin1(7)
- proc_pid_root(5)
- nptl(7)
- proc_cgroups(5)
- proc_iomem(5)
- proc_pid_statm(5)
- sem_overview(7)
- hier(7)
- full(4)
- proc_pid_status(5)
- proc_pid_cwd(5)
- proc_pid_cpuset(5)
- proc_scsi(5)
- uri(7)
- proc_diskstats(5)
- iso_8859_6(7)
- latin2(7)
- latin5(7)
- man-pages(7)
- ld.so(8)
- uts_namespaces(7)
- proc_pid_mountstats(5)
- intro(3)
- proc_pid_seccomp(5)
- proc_pid_wchan(5)
- attributes(7)
- symlink(7)
- mount_namespaces(7)
- charmap(5)
- tis-620(7)
- iso-8859-10(7)
- getent(1)
- proc_buddyinfo(5)
- ttytype(5)
- rtc(4)
- proc_malloc(5)
- suffixes(7)
- sln(8)
- signal(7)
- proc_sys_abi(5)
- signal-safety(7)
- time_namespaces(7)
- proc_pid_comm(5)
- raw(7)
- gai.conf(5)
- proc_crypto(5)
- locale(1)
- iso-8859-3(7)
- motd(5)
- proc_meminfo(5)
- iso-8859-8(7)
- protocols(5)
- proc_pid_map_files(5)
- pthreads(7)
- null(4)
- proc(5)
- zdump(8)
- socket(7)
- proc_sys_kernel(5)
- ddp(7)
- memusagestat(1)
- hd(4)
- iso-8859-14(7)
- shells(5)
- pipe(7)
- glob(7)
- proc_self(5)
- network_namespaces(7)
- utmp(5)
- proc_kcore(5)
- nsswitch.conf(5)
- sd(4)
- iso-8859-5(7)
- iso_8859_16(7)
- man(7)
- iso_8859-6(7)
- dir_colors(5)
- mq_overview(7)
- vsock(7)
- ascii(7)
- thread-keyring(7)
- fs(5)
- proc_pid_attr(5)
- proc_sys_debug(5)
- proc_sys(5)
- proc_pid_cmdline(5)
- pty(7)
- services(5)
- cgroup_namespaces(7)
- securetty(5)
- netdevice(7)
- iso_8859_13(7)
- host.conf(5)
- proc_pid_setgroups(5)
- proc_slabinfo(5)
- sock_diag(7)
- iso_8859-14(7)
- iso-8859-11(7)
- iso_8859_11(7)
- operator(7)
- regex(7)
- wavelan(4)
- proc_sys_fs(5)
- nologin(5)
- proc_pci(5)
- koi8-r(7)
- erofs(5)
- intro(2)
- utf8(7)
- proc_kallsyms(5)
- proc_sysvipc(5)
- queue(7)
- proc_sys_sunrpc(5)
- intro(5)
- latin8(7)
- mtrace(1)
- ipc_namespaces(7)
- dsp56k(4)
- iso_8859_4(7)
- proc_pid_smaps(5)
- proc_cmdline(5)
- rpc(5)
- proc_tty(5)
- proc_version(5)
- smartpqi(4)
- proc_pid_timerslack_ns(5)
- aio(7)
- session-keyring(7)
- resolver(5)
- slabinfo(5)
- wtmp(5)
- iso_8859_9(7)
- proc_locks(5)
- mailaddr(7)
- proc_pid_oom_score(5)
- kmem(4)
- iconvconfig(8)
- iso_8859-7(7)
- glibc(7)
- hostname(7)
- proc_thread-self(5)
- ipv6(7)
- iso_8859_7(7)
- proc_kpagecgroup(5)
- core(5)
- time(7)
- units(7)
- proc_dma(5)
- loop(4)
- address_families(7)
- zero(4)
- intro(4)
- procfs(5)
- iso_8859-4(7)
- vdso(7)
- tmpfs(5)
- iso-8859-16(7)
- iso_8859_10(7)
- user-session-keyring(7)
- libc(7)
- proc_fs(5)
- koi8-u(7)
- latin3(7)
- proc_tid_children(5)
- proc_pid_limits(5)
- proc_pid_coredump_filter(5)
- iso_8859-15(7)
- arp(7)
- urandom(4)
- iso_8859-10(7)
- hpsa(4)
- proc_pid_environ(5)
- boot(7)
- ftm(7)
- ld-linux(8)
- proc_driver(5)
- loop-control(4)
- iso_8859-16(7)
- proc_filesystems(5)
- tzfile(5)
- sprof(1)
- proc_pid_task(5)
- proc_pid_oom_score_adj(5)
- proc_mounts(5)
- iso-8859-4(7)
- iso_8859-1(7)
- utf-8(7)
- iso_8859-13(7)
- intro(6)
- proc_timer_list(5)
- rtld-audit(7)
- iso_8859-3(7)
- group(5)
- sched(7)
- proc_pid_clear_refs(5)
- hosts(5)
- iso_8859-11(7)
- numa(7)
- iso_8859_2(7)
- locale(7)
- iso-8859-1(7)
- fuse(4)
- proc_tid(5)
- proc_execdomains(5)
- proc_pid_mountinfo(5)
- intro(8)
- iso_8859_8(7)
- proc_loadavg(5)
- proc_pid_oom_adj(5)
- re_format(7)
- iso_8859_14(7)
- zic(8)
- bootparam(7)
- inotify(7)
- posixoptions(7)
- proc_partitions(5)
- iso-8859-9(7)
- proc_pid_mem(5)
- networks(5)
- proc_sys_user(5)
- udp(7)
- proc_zoneinfo(5)
- latin10(7)
- proc_pid_fdinfo(5)
- proc_pid_stack(5)
- memusage(1)
- spufs(7)
- pkeys(7)
- path_resolution(7)
- proc_ioports(5)
- intro(1)
- ldconfig(8)
- msr(4)
- svipc(7)
- port(4)
- proc_pid_personality(5)
- cciss(4)
- latin9(7)
- capabilities(7)
- localedef(1)
- vcs(4)
- iso_8859-5(7)
- elf(5)
- proc_sys_proc(5)
- console_codes(4)
- random(4)
- iso-8859-7(7)
- termcap(5)
- cpuid(4)
- environ(7)
- string_copying(7)
- proc_pid_gid_map(5)
- queue(3)
- termio(7)
- user-keyring(7)
- complex(7)
- latin7(7)
- proc_config.gz(5)
- udplite(7)
- kernel_lockdown(7)
- proc_devices(5)
- proc_apm(5)
- iso_8859_1(7)
- proc_pid_numa_maps(5)
apt-get install manpages
Available languages:
en fr pt_BR es ja ru ro zh_TW zh_CNManual
RAW
名 前書 式
説 明
ア ド レ ス の フ ォ ー マ ッ ト
ソ ケ ッ ト オ プ シ ョ ン
エ ラ ー 処 理
エ ラ ー
バ ー ジ ョ ン
注 意
バ グ
関 連 項 目
こ の 文 書 に つ い て
名 前
raw - Linux の IPv4 raw ソ ケ ッ ト
書 式
#include
<sys/socket.h>
#include <netinet/in.h>
raw_socket = socket(AF_INET, SOCK_RAW, int
protocol
);
説 明
raw ソ ケ ッ ト を 使 う と 、 新 し い IPv4 プ ロ ト コ ル を ユ ー ザ ー 空 間 で 実 装 で き る よ う に な る 。 raw ソ ケ ッ ト は 、 リ ン ク レ ベ ル ヘ ッ ダ ー を 含 ま な い raw デ ー タ グ ラ ム の 送 受 信 が で き る 。
IPv4 レ イ ヤ は 、 扱 っ て い る ソ ケ ッ ト で IP_HDRINCL ソ ケ ッ ト オ プ シ ョ ン が 有 効 に な っ て い な け れ ば 、 パ ケ ッ ト を 送 信 す る と き に IP ヘ ッ ダ ー を 生 成 す る 。 IP_HDRINCL オ プ シ ョ ン が 有 効 に な っ て い る と き は 、 パ ケ ッ ト に は IP ヘ ッ ダ ー が 含 ま れ て い な け れ ば な ら な い 。 受 信 時 に は 、 IP ヘ ッ ダ ー は 常 に パ ケ ッ ト に 含 ま れ て い る 。
In order to create a raw socket, a process must have the CAP_NET_RAW capability in the user namespace that governs its network namespace.
All packets or errors matching the protocol number specified for the raw socket are passed to this socket. For a list of the allowed protocols, see the IANA list of assigned protocol numbers at http://www.iana.org/assignments/protocol-numbers/ and getprotobyname (3).
IPPROTO_RAW の プ ロ ト コ ル は 暗 黙 の う ち に IP_HDRINCL を 有 効 に す る の で 、 渡 さ れ た ヘ ッ ダ ー で 指 定 さ れ た 、 あ ら ゆ る IP プ ロ ト コ ル を 送 信 で き る 。 IPPROTO_RAW 経 由 で の あ ら ゆ る IP プ ロ ト コ ル の 受 信 は 、 raw ソ ケ ッ ト を 用 い て は 行 え な い 。
IP_HERINCL が 指 定 さ れ て い て 、 IP ヘ ッ ダ ー に 0 で な い 送 信 先 ア ド レ ス が 記 入 さ れ て い た 場 合 は 、 そ の 送 信 先 ア ド レ ス が パ ケ ッ ト の 経 路 を 決 め る の に 用 い ら れ る 。 MSG_DONTROUTE が 指 定 さ れ て い る 時 に は 、 送 信 先 ア ド レ ス は ロ ー カ ル な イ ン タ ー フ ェ ー ス を 参 照 す る も の で な け れ ば な ら な い 。 さ も な い と 、 ル ー テ ィ ン グ テ ー ブ ル の 参 照 は い ず れ に せ よ 行 わ れ る が 、 ゲ ー ト ウ ェ イ が 必 要 な 経 路 は 無 視 さ れ る 。
IP_HDRINCL が セ ッ ト さ れ て い な け れ ば 、 raw ソ ケ ッ ト の IP ヘ ッ ダ ー オ プ シ ョ ン を setsockopt (2) を 用 い て 設 定 す る こ と が で き る 。 詳 細 な 情 報 は ip (7) を 見 よ 。
Linux 2.2 以 降 で は 、 IP ヘ ッ ダ ー の 全 て の フ ィ ー ル ド と オ プ シ ョ ン と を IP ソ ケ ッ ト オ プ シ ョ ン に よ っ て 設 定 で き る 。 し た が っ て raw ソ ケ ッ ト が 必 要 に な る の は 、 新 し い プ ロ ト コ ル を 設 計 す る 場 合 か 、 ユ ー ザ ー イ ン タ ー フ ェ ー ス を 持 た な い プ ロ ト コ ル (ICMP な ど ) を 扱 う 場 合 に 限 ら れ る 。
パ ケ ッ ト は 、 受 信 さ れ る と ま ず プ ロ ト コ ル に バ イ ン ド し て い る raw ソ ケ ッ ト に 渡 さ れ 、 そ の 後 で 他 の プ ロ ト コ ル ハ ン ド ラ ー (カ ー ネ ル の プ ロ ト コ ル モ ジ ュ ー ル な ど ) に 渡 さ れ る 。
ア ド レ ス の フ ォ ー マ ッ ト
For sending and receiving datagrams ( sendto (2), recvfrom (2), and similar), raw sockets use the standard sockaddr_in address structure defined in ip (7). The sin_port field could be used to specify the IP protocol number, but it is ignored for sending in Linux 2.2 and later, and should be always set to 0 (see BUGS). For incoming packets, sin_port is set to zero.
ソ ケ ッ ト オ プ シ ョ ン
raw ソ
ケ ッ ト の オ プ
シ ョ ン は 、
IPPROTO_RAW
フ ァ ミ リ
ー フ ラ グ を 与
え て
setsockopt
(2) を 呼
べ ば 設 定 で き
、
getsockopt
(2) を 呼 べ
ば 取 得 で き る
。
ICMP_FILTER
IPPROTO_ICMP プ ロ ト コ ル に バ イ ン ド さ れ た raw ソ ケ ッ ト の た め の 特 殊 な フ ィ ル タ を 有 効 に す る 。 こ の 値 は ICMP メ ッ セ ー ジ の タ イ プ そ れ ぞ れ に 対 し て 、 ど れ を フ ィ ル タ ー ア ウ ト す る か を 表 し た ビ ッ ト セ ッ ト で あ る 。 デ フ ォ ル ト で は ICMP メ ッ セ ー ジ は 全 く フ ィ ル タ ー し な い 。
さ ら に 、 デ ー タ グ ラ ム ソ ケ ッ ト に 使 え る 全 て の ip (7) SOL_IP ソ ケ ッ ト オ プ シ ョ ン が サ ポ ー ト さ れ て い る 。
エ ラ ー 処 理
ネ ッ ト ワ ー ク で 生 じ た エ ラ ー が ユ ー ザ ー に 渡 さ れ る の は 、 ソ ケ ッ ト が 接 続 済 み の 場 合 か IP_RECVERR フ ラ グ が 有 効 に な っ て い る 場 合 に 限 ら れ る 。 接 続 済 み の ソ ケ ッ ト に 対 し て は 、 EMSGSIZE お よ び EPROTO だ け が 渡 さ れ る (互 換 性 の た め )。 IP_RECVERR を 設 定 す る と 、 全 て の ネ ッ ト ワ ー ク エ ラ ー が エ ラ ー キ ュ ー に 保 存 さ れ る 。
エ ラ ー
|
EACCES |
ユ ー ザ ー が broadcast フ ラ グ を 設 定 し て い な い ソ ケ ッ ト を 用 い て ブ ロ ー ド キ ャ ス ト ア ド レ ス に 送 信 を 行 お う と し た 。 |
|||
|
EFAULT |
不 正 な メ モ リ ー ア ド レ ス が 与 え ら れ た 。 |
|||
|
EINVAL |
引 数 が 不 正 。 |
EMSGSIZE
パ ケ ッ ト が 大 き す ぎ る 。 Path MTU Discoverry が 有 効 に な っ て い る ( IP_MTU_DISCOVER ソ ケ ッ ト フ ラ グ ) か 、 パ ケ ッ ト の サ イ ズ が IPv4 で 許 さ れ て い る パ ケ ッ ト サ イ ズ の 最 大 値 64 KB を 越 え て い る 。
EOPNOTSUPP
ソ ケ ッ ト 呼 び 出 し に 不 正 な フ ラ グ ( MSG_OOB な ど ) が 渡 さ れ た 。
|
EPERM |
ユ ー ザ ー は raw ソ ケ ッ ト を オ ー プ ン す る 権 限 を 持 っ て い な い 。 実 行 ユ ー ザ ー ID が 0 の プ ロ セ ス か 、 CAP_NET_RAW 属 性 を 持 つ プ ロ セ ス だ け が こ れ を 行 う こ と が で き る 。 |
||
|
EPROTO |
パ ラ メ ー タ ー の 問 題 を 報 告 す る ICMP エ ラ ー を 受 け 取 っ た 。 |
バ ー ジ ョ ン
IP_RECVERR と ICMP_FILTER は Linux 2.2 で 登 場 し た 。 こ れ ら は Linux で の 拡 張 で あ り 、 移 植 性 の 必 要 な プ ロ グ ラ ム で は 用 い る べ き で な い 。
Linux 2.0 で は SO_BSDCOMPAT ソ ケ ッ ト オ プ シ ョ ン を セ ッ ト す る と 、 BSD の raw ソ ケ ッ ト に あ る バ グ に 互 換 性 を 取 る こ と が で き た — Linux 2.2 以 降 で は 、 こ の オ プ シ ョ ン は も は や 効 力 を 持 た な い 。
注 意
デ フ ォ ル ト で は 、 raw ソ ケ ッ ト は Path MTU Discovery を 行 う 。 つ ま り 、 カ ー ネ ル は 特 定 の 宛 先 IP ア ド レ ス の MTU (Maximum Transmission Unit; 最 大 転 送 単 位 ) を 記 録 し 、 raw パ ケ ッ ト の 書 き 込 み が MTU を 超 え た 場 合 EMSGSIZE を 返 す 。 EMSGSIZE を 返 さ れ た 場 合 、 ア プ リ ケ ー シ ョ ン は パ ケ ッ ト サ イ ズ を 小 さ く す べ き で あ る 。 ソ ケ ッ ト オ プ シ ョ ン IP_MTU_DISCOVER ま た は /proc/sys/net/ipv4/ip_no_pmtu_disc フ ァ イ ル を 使 っ て Path MTU Discovery を 無 効 に す る こ と も で き る (詳 細 は ip (7) を 参 照 )。 Path MTU Discovery を 無 効 に し た 場 合 は 、 パ ケ ッ ト サ イ ズ が イ ン タ ー フ ェ ー ス の MTU よ り も 大 き い と raw ソ ケ ッ ト は そ の パ ケ ッ ト を フ ラ グ メ ン ト 化 し て 送 出 す る 。 し か し な が ら 、 性 能 と 信 頼 性 の 理 由 か ら Path MTU Discovery を 無 効 に す る の は 推 奨 で き な い 。
bind (2) シ ス テ ム コ ー ル を 用 い る と 、 raw ソ ケ ッ ト を 特 定 の ロ ー カ ル ア ド レ ス に バ イ ン ド さ せ る こ と が で き る 。 こ の バ イ ン ド が さ れ て い な い 場 合 は 、 指 定 し た IP プ ロ ト コ ル の す べ て の パ ケ ッ ト が 受 信 さ れ る 。 さ ら に 、 SO_BINDTODEVICE を 用 い れ ば raw ソ ケ ッ ト を 特 定 の ネ ッ ト ワ ー ク デ バ イ ス に バ イ ン ド さ せ る こ と も で き る 。 socket (7) を 見 よ 。
IPPROTO_RAW ソ ケ ッ ト は 送 信 専 用 で あ る 。 も し ど う し て も す べ て の IP パ ケ ッ ト を 受 信 し た い 場 合 は 、 packet (7) ソ ケ ッ ト を ETH_P_IP プ ロ ト コ ル で 用 い る こ と 。 packet ソ ケ ッ ト は raw ソ ケ ッ ト の よ う に IP フ ラ グ メ ン ト を 再 構 成 し な い こ と に 注 意 。
datagram ソ ケ ッ ト に 対 す る す べ て の ICMP パ ケ ッ ト を 受 信 し た い 場 合 は 、 特 定 の ソ ケ ッ ト に 対 し て IP_RECVERR を 用 い る ほ う が 良 い 場 合 が 多 い 。 ip (7) を 見 よ 。
raw ソ ケ ッ ト は 、 Linux の す べ て の IP プ ロ ト コ ル を 受 信 す る こ と が で き る 。 ICMP や TCP の よ う に 、 カ ー ネ ル 内 部 に プ ロ ト コ ル モ ジ ュ ー ル を 持 つ よ う な も の も 可 能 で あ る 。 こ の 場 合 に は 、 パ ケ ッ ト は カ ー ネ ル モ ジ ュ ー ル と raw ソ ケ ッ ト の 両 方 に 渡 さ れ る (raw ソ ケ ッ ト が 複 数 あ れ ば そ れ ぞ れ に 渡 さ れ る )。 移 植 性 の 必 要 な プ ロ グ ラ ム で は こ の 機 能 に 依 存 す る べ き で は な い 。 他 の 多 く の BSD に お け る ソ ケ ッ ト の 実 装 で は こ の 点 に お い て 制 限 が あ る 。
Linux は ユ ー ザ ー か ら 渡 さ れ た ヘ ッ ダ ー を 決 し て 変 更 し な い (た だ し IP_HDRINCL の 説 明 に あ る よ う に 、 0 を い く つ か 埋 め る 場 合 を 除 く )。 こ れ は 他 の 多 く の raw ソ ケ ッ ト の 実 装 で は 異 な る 。
一 般 に raw ソ ケ ッ ト は 移 植 性 が な い こ と が 多 い の で 、 移 植 性 が 必 要 な プ ロ グ ラ ム で は 避 け る べ き で あ る 。
raw ソ ケ ッ ト へ の 送 信 で は 、 IP プ ロ ト コ ル を sin_port か ら 取 得 で き な け れ ば な ら な い 。 こ の 機 能 は Linux 2.2 で は 使 え な く な っ た 。 IP_HDRINCL を 用 い れ ば 同 様 の こ と が 実 現 で き る 。
バ グ
透 過 プ ロ ク シ (transparent proxy) 拡 張 に つ い て は 記 述 し て い な い 。
IP_HDRINCL オ プ シ ョ ン が セ ッ ト さ れ て い る と デ ー タ グ ラ ム は フ ラ グ メ ン ト 化 さ れ ず 、 イ ン タ ー フ ェ ー ス の MTU の 大 き さ に 制 限 さ れ る 。
送 信 用 の IP プ ロ ト コ ル の 設 定 を sin_port に し て お く 機 能 は Linux 2.2 か ら 使 え な く な っ た 。 ソ ケ ッ ト に バ イ ン ド さ れ て い る プ ロ ト コ ル か 、 最 初 の socket (2) コ ー ル に よ っ て 指 定 さ れ た プ ロ ト コ ル が 常 に 用 い ら れ る 。
関 連 項 目
recvmsg (2), sendmsg (2), capabilities (7), ip (7), socket (7)
Path MTU discovery に 関 し て は RFC 1191 を 参 照 。 IP プ ロ ト コ ル に 関 し て は RFC 791 と イ ン ク ル ー ド フ ァ イ ル <linux/ip.h> を 参 照 。
こ の 文 書 に つ い て
こ の man ペ ー ジ は Linux man-pages プ ロ ジ ェ ク ト の リ リ ー ス 5.10 の 一 部 で あ る 。 プ ロ ジ ェ ク ト の 説 明 と バ グ 報 告 に 関 す る 情 報 は https://www.kernel.org/doc/man-pages/ に 書 か れ て い る 。