lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Date:	Thu, 17 Apr 2008 18:31:56 +0100
From:	"Jack Harvard" <jack.harvard@...glemail.com>
To:	linux-kernel@...r.kernel.org
Subject: gettimeofday() in 2.6.24

Hi, I was trying to figure out how gettimeofday() measures time in
2.6.24-arm2, in which a free-running timer is added to improve the
resolution of gettimeofday() from 10ms to us, I can trace down to
do_gettimeofday() as follows:

http://lxr.linux.no/linux+v2.6.24/arch/arm/kernel/time.c#L240
 239#ifndef CONFIG_GENERIC_TIME
 240void do_gettimeofday(struct timeval *tv)
 241{
 242        unsigned long flags;
 243        unsigned long seq;
 244        unsigned long usec, sec;
 245
 246        do {
 247                seq = read_seqbegin_irqsave(&xtime_lock, flags);
 248                usec = system_timer->offset();
 249                sec = xtime.tv_sec;
 250                usec += xtime.tv_nsec / 1000;
 251        } while (read_seqretry_irqrestore(&xtime_lock, seq, flags));
 252
 253        /* usec may have gone up a lot: be safe */
 254        while (usec >= 1000000) {
 255                usec -= 1000000;
 256                sec++;
 257        }
 258
 259        tv->tv_sec = sec;
 260        tv->tv_usec = usec;
 261}
 262
 263EXPORT_SYMBOL(do_gettimeofday);

but I haven't quite figured out how gettimeofday() actually gets time
from this added timer, also how xtime is updated?

Thanks, Jack
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ