を実行strace -ttT date
すると、実行可能ファイルの起動直後に多くのシステムコールが見逃されます。execve() の後、date
ELF が HDD からメモリにコピーされるシステムコールはありません。これはカーネル内で発生しますか? 各バイトがブロック単位でメモリにロードされる HDD コントローラへの IOCTL が多数表示されると思いましたか?
16:00:00.505197 execve("/bin/date", ["date"], [/* 30 vars */]) = 0 <0.038088>
16:00:00.543671 brk(0) = 0x11b9000 <0.000074>
16:00:00.543915 access("/etc/ld.so.nohwcap", F_OK) = -1 ENOENT (No such file or directory) <0.000077>
16:00:00.544187 mmap(NULL, 8192, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7f0f4083a000 <0.000076>
16:00:00.544416 access("/etc/ld.so.preload", R_OK) = -1 ENOENT (No such file or directory) <0.000018>
16:00:00.544543 open("/etc/ld.so.cache", O_RDONLY) = 3 <0.000059>