summaryrefslogtreecommitdiffstats
path: root/hwclock
diff options
context:
space:
mode:
authorMatthias Koenig2007-09-20 11:11:18 +0200
committerKarel Zak2007-09-20 13:40:14 +0200
commit5d1f6bae3b298809ecd63b3e55f6ab30caaa4dbf (patch)
treed46cc323187dcbed3bf3bf2860a55b591f658e97 /hwclock
parentbuild-sys: remove hardcoded _GNU_SOURCE (diff)
downloadkernel-qcow2-util-linux-5d1f6bae3b298809ecd63b3e55f6ab30caaa4dbf.tar.gz
kernel-qcow2-util-linux-5d1f6bae3b298809ecd63b3e55f6ab30caaa4dbf.tar.xz
kernel-qcow2-util-linux-5d1f6bae3b298809ecd63b3e55f6ab30caaa4dbf.zip
hwclock: fix --rtc option
The --rtc option does not set the name of the device correctly. It still uses /dev/rtc even if the --rtc option is given. Testcase: $ mv /dev/rtc /dev/foo $ hwclock --show --debug --rtc=/dev/foo hwclock from util-linux-2.13-rc2 Using /dev interface to clock. Last drift adjustment done at 1190198135 seconds after 1969 Last calibration done at 1190198135 seconds after 1969 Hardware clock is on local time Assuming hardware clock is kept in local time. Waiting for clock tick... hwclock: open() of /dev/rtc failed, errno=2: No such file or directory. ...got clock tick Co-Author: Karel Zak <kzak@redhat.com> Signed-off-by: Matthias Koenig <mkoenig@suse.de> Signed-off-by: Karel Zak <kzak@redhat.com>
Diffstat (limited to 'hwclock')
-rw-r--r--hwclock/rtc.c33
1 files changed, 15 insertions, 18 deletions
diff --git a/hwclock/rtc.c b/hwclock/rtc.c
index f8e626eb8..724daf99e 100644
--- a/hwclock/rtc.c
+++ b/hwclock/rtc.c
@@ -104,24 +104,21 @@ open_rtc(void) {
"/dev/misc/rtc",
NULL
};
- char **p = fls;
- char *fname = rtc_dev_name ? : *p;
-
- do {
- int fd = open(fname, O_RDONLY);
-
- if (fd < 0 && errno == ENOENT) {
- if (fname == rtc_dev_name)
- break;
- fname = *++p;
- } else {
- rtc_dev_name = *p;
- return fd;
- }
- } while(fname);
-
- if (!rtc_dev_name)
- rtc_dev_name = *fls;
+ char **p;
+
+ /* --rtc option has been given */
+ if (rtc_dev_name)
+ return open(rtc_dev_name, O_RDONLY);
+
+ for (p=fls; *p; ++p) {
+ int fd = open(*p, O_RDONLY);
+
+ if (fd < 0 && errno == ENOENT)
+ continue;
+ rtc_dev_name = *p;
+ return fd;
+ }
+ rtc_dev_name = *fls; /* default */
return -1;
}