summaryrefslogtreecommitdiffstats
path: root/scd
diff options
context:
space:
mode:
authorWerner Koch <wk@gnupg.org>2008-12-08 20:10:42 +0100
committerWerner Koch <wk@gnupg.org>2008-12-08 20:10:42 +0100
commit78ff45c49e7c78149b26df8c10250338a37cc1a9 (patch)
tree3b72156d71e230ce2dbee1694556c6a5d024f5e8 /scd
parentFix bug 901. (diff)
downloadgnupg2-78ff45c49e7c78149b26df8c10250338a37cc1a9.tar.xz
gnupg2-78ff45c49e7c78149b26df8c10250338a37cc1a9.zip
Align ticker to the full or half second.
Diffstat (limited to 'scd')
-rw-r--r--scd/ChangeLog6
-rw-r--r--scd/scdaemon.c26
2 files changed, 26 insertions, 6 deletions
diff --git a/scd/ChangeLog b/scd/ChangeLog
index 9ac21d66b..e582ae5b4 100644
--- a/scd/ChangeLog
+++ b/scd/ChangeLog
@@ -1,3 +1,9 @@
+2008-12-08 Werner Koch <wk@g10code.com>
+
+ * scdaemon.c (handle_connections): Sync ticker to the next full
+ interval.
+ (TIMERTICK_INTERVAL_USEC): Change to 500ms.
+
2008-12-05 Werner Koch <wk@g10code.com>
* app-openpgp.c (app_local_s): Add field ALGO_ATTR_CHANGE.
diff --git a/scd/scdaemon.c b/scd/scdaemon.c
index fc33be3a6..5f3078c19 100644
--- a/scd/scdaemon.c
+++ b/scd/scdaemon.c
@@ -156,7 +156,7 @@ static ARGPARSE_OPTS opts[] = {
#define DEFAULT_PCSC_DRIVER "libpcsclite.so"
#endif
-/* The timer tick used for housekeeping stuff. We poll every 250ms to
+/* The timer tick used for housekeeping stuff. We poll every 500ms to
let the user immediately know a status change.
This is not too good for power saving but given that there is no
@@ -167,7 +167,7 @@ static ARGPARSE_OPTS opts[] = {
mechanism. Given that a native thread could only be used under W32
we don't do that at all. */
#define TIMERTICK_INTERVAL_SEC (0)
-#define TIMERTICK_INTERVAL_USEC (250000)
+#define TIMERTICK_INTERVAL_USEC (500000)
/* Flag to indicate that a shutdown was requested. */
static int shutdown_pending;
@@ -1152,11 +1152,25 @@ handle_connections (int listen_fd)
listen_fd = -1;
}
- /* Create a timeout event if needed. */
+ /* Create a timeout event if needed. Round it up to the next
+ microsecond interval to help with power saving. */
if (!time_ev)
- time_ev = pth_event (PTH_EVENT_TIME,
- pth_timeout (TIMERTICK_INTERVAL_SEC,
- TIMERTICK_INTERVAL_USEC));
+ {
+ pth_time_t nexttick = pth_timeout (TIMERTICK_INTERVAL_SEC,
+ TIMERTICK_INTERVAL_USEC/2);
+ if ((nexttick.tv_usec % (TIMERTICK_INTERVAL_USEC/2)) > 10)
+ {
+ nexttick.tv_usec = ((nexttick.tv_usec
+ /(TIMERTICK_INTERVAL_USEC/2))
+ + 1) * (TIMERTICK_INTERVAL_USEC/2);
+ if (nexttick.tv_usec >= 1000000)
+ {
+ nexttick.tv_sec++;
+ nexttick.tv_usec = 0;
+ }
+ }
+ time_ev = pth_event (PTH_EVENT_TIME, nexttick);
+ }
/* POSIX says that fd_set should be implemented as a structure,
thus a simple assignment is fine to copy the entire set. */