nanosleep перестал работать???
обнаружил, что один перловый скрипт начал "есть" процессор, стал
копаться - usleep не обеспечивает задержку.
сделал тестовый пример на си с вызовом usleep(1000) - транслируется в
nanosleep и выполняется мнгновенно.
в чем может быть дело?
$ time strace ./a.out
execve("./a.out", ["./a.out"], [/* 19 vars */]) = 0
brk(0) = 0x804a000
access("/etc/ld.so.nohwcap", F_OK) = -1 ENOENT (No such file or
directory)
mmap2(NULL, 8192, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1,
0) = 0xb77c3000
access("/etc/ld.so.preload", R_OK) = -1 ENOENT (No such file or
directory)
open("/etc/ld.so.cache", O_RDONLY) = 3
fstat64(3, {st_mode=S_IFREG|0644, st_size=24208, ...}) = 0
mmap2(NULL, 24208, PROT_READ, MAP_PRIVATE, 3, 0) = 0xb77bd000
close(3) = 0
access("/etc/ld.so.nohwcap", F_OK) = -1 ENOENT (No such file or
directory)
open("/lib/i686/cmov/libc.so.6", O_RDONLY) = 3
read(3,
"\177ELF\1\1\1\0\0\0\0\0\0\0\0\0\3\0\3\0\1\0\0\0\320m\1\0004\0\0\0\374"...,
512) = 512
fstat64(3, {st_mode=S_IFREG|0755, st_size=1323460, ...}) = 0
mmap2(NULL, 1333608, PROT_READ|PROT_EXEC, MAP_PRIVATE|MAP_DENYWRITE, 3,
0) = 0xb7677000
mmap2(0xb77b7000, 12288, PROT_READ|PROT_WRITE,
MAP_PRIVATE|MAP_FIXED|MAP_DENYWRITE, 3, 0x13f) = 0xb77b7000
mmap2(0xb77ba000, 10600, PROT_READ|PROT_WRITE,
MAP_PRIVATE|MAP_FIXED|MAP_ANONYMOUS, -1, 0) = 0xb77ba000
close(3) = 0
mmap2(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1,
0) = 0xb7676000
set_thread_area({entry_number:-1 -> 6, base_addr:0xb76766c0,
limit:1048575, seg_32bit:1, contents:0, read_exec_only:0,
limit_in_pages:1, seg_not_present:0, useable:1}) = 0
mprotect(0xb77b7000, 8192, PROT_READ) = 0
mprotect(0xb77e1000, 4096, PROT_READ) = 0
munmap(0xb77bd000, 24208) = 0
nanosleep({0, 1000000}, NULL) = 0
exit_group(0) = ?
real 0m0.005s
user 0m0.000s
sys 0m0.004s
Reply to: