strace -ttT date
을 실행하면 실행 파일의 실행 직후에 많은 syscalls를 놓친다. execve() 후에 date
ELF가 HDD에서 메모리로 복사되는 더 이상의 시스템 콜이 없다면 커널 내에서 발생합니까? 나는 각 바이트가 메모리에 blockwise 적재되는 HDD 컨트롤러에 많은 IOCTL을 보았을 것이라고 생각했다. 조금 단순화strace가 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>