From: J William Piggott Date: Mon, 24 Jul 2017 00:16:03 +0000 (-0400) Subject: hwclock: fix unimplemented ioctl test X-Git-Tag: v2.31-rc1~161 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=1d5cffa16a0183175684809cf215294ec20b8fd9;p=thirdparty%2Futil-linux.git hwclock: fix unimplemented ioctl test The rtc driver has not returned EINVAL for unimplemented ioctls since v2.5.8 in 2002. However, it does return it for other errors; making the current test potentially problematic. Since 9f3d0fc util-linux assumes kernel >= 2.6.0 so remove EINVAL as an ioctl test. Signed-off-by: J William Piggott --- diff --git a/sys-utils/hwclock-rtc.c b/sys-utils/hwclock-rtc.c index 36ce397614..ea8357daf9 100644 --- a/sys-utils/hwclock-rtc.c +++ b/sys-utils/hwclock-rtc.c @@ -257,7 +257,7 @@ static int synchronize_to_clock_tick_rtc(const struct hwclock_control *ctl) * they should. */ rc = -1; - errno = EINVAL; + errno = ENOTTY; #else rc = ioctl(rtc_fd, RTC_UIE_ON, 0); #endif @@ -293,7 +293,7 @@ static int synchronize_to_clock_tick_rtc(const struct hwclock_control *ctl) if (rc == -1) warn(_("ioctl() to %s to turn off update interrupts failed"), rtc_dev_name); - } else if (errno == ENOTTY || errno == EINVAL) { + } else if (errno == ENOTTY) { /* * This rtc device doesn't have interrupt functions. * This is typical on an Alpha, where the Hardware