FBSD 5.5 and software timers
Michael Scheidell
scheidell at secnap.net
Tue Jul 25 19:27:55 UTC 2006
Found it! library libc_r
Given POC:
int main( int argc, char **argv )
{
char execs1[256] = "/bin/date +A%Y%m%d%H%M.%S";
char execs2[256] = "/bin/date +B%Y%m%d%H%M.%S";
int a;
while ( 1) {
system( execs1 );
usleep( 500*1000);
system( execs2 );
}
return 0;
} /* main */
compile with:
cc -g -c nanotest.c
cc -g -o nanotest nanotest.o
everything works as expected.
time forward, back, doesn't matter (date prints out wallclock,
nanosleep() sleeps 500*1000*1000us (.5 seconds)
this breaks it:
cc -g -c nanotest.c
cc -g -o nanotest nanotest.o -lc_r
setting clock back 'hangs' during usleep (500*1000)
didn't hang on 5.4.
I will be writing up a bug report shortly.
--
Michael Scheidell, CTO
SECNAP Network Security / www.secnap.com
scheidell at secnap.net / 1+561-999-5000, x 1131
More information about the freebsd-hackers
mailing list