From patchwork Fri Jun 16 14:03:52 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Benjamin Gaignard X-Patchwork-Id: 9791763 Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork.web.codeaurora.org (Postfix) with ESMTP id 7B2F96038F for ; Fri, 16 Jun 2017 14:05:37 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 80F112855D for ; Fri, 16 Jun 2017 14:05:37 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id 759C12863A; Fri, 16 Jun 2017 14:05:37 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on pdx-wl-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-1.9 required=2.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID autolearn=unavailable version=3.3.1 Received: from bombadil.infradead.org (bombadil.infradead.org [65.50.211.133]) (using TLSv1.2 with cipher AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.wl.linuxfoundation.org (Postfix) with ESMTPS id B896328572 for ; Fri, 16 Jun 2017 14:05:36 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20170209; h=Sender: Content-Transfer-Encoding:Content-Type:MIME-Version:Cc:List-Subscribe: List-Help:List-Post:List-Archive:List-Unsubscribe:List-Id:References: In-Reply-To:Message-Id:Date:Subject:To:From:Reply-To:Content-ID: Content-Description:Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc :Resent-Message-ID:List-Owner; bh=iP4WS90m9XKt4u99NaHMbJZUpZadEDiAqkt0PNQ9fWY=; b=i1gmpYmi9zwN758vJmqyAW4msY Kuz5N/lQcv4p8H8jcGY8W/5+SDwD6Iq80fIXLIkhOb45F/tZVwvTUw2fiBFJVhqQTs4k5TgjQAvwn vguWPtrcvtj4rUT6v392XKNuK1nJPbwjztxwTN4OXUdP535pPA5bF4dWUYB+R8szj3O6Qj4QH/ZrW JdN//gfEoiiXIL5EX9oDJtuzAouHegOIBH2DXIfSZKiS1687lDZpjTuvtH4tN20NrjVx5z9Z81p8S Ynt9+1ViNBAk9fOLI+jc6CSyxN5u4HJULNbAzC3TJrQcixcG7Cwb04C4pqCbPzMFeg5+qx1FtSNOT pTKBSpsg==; Received: from localhost ([127.0.0.1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.87 #1 (Red Hat Linux)) id 1dLrsV-00058p-D7; Fri, 16 Jun 2017 14:05:35 +0000 Received: from mail-wr0-x22b.google.com ([2a00:1450:400c:c0c::22b]) by bombadil.infradead.org with esmtps (Exim 4.87 #1 (Red Hat Linux)) id 1dLrsA-0003Jj-Rq for linux-arm-kernel@lists.infradead.org; Fri, 16 Jun 2017 14:05:21 +0000 Received: by mail-wr0-x22b.google.com with SMTP id 77so39089741wrb.1 for ; Fri, 16 Jun 2017 07:04:54 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=+ObfvECF1k7XByKeVBvD2P7FgdaZ9VPCnw0TWa/BRZ8=; b=Ndz5l6gKHqlYo8kehEGzHK67fXKbbl9uI8gJ2FihrG7wbA8iBPRAVM4jnOaIXR4yJ7 bjzpIuC5JmoNDxJHYPa8w6jTRSFLX51Id3k00mg+rRsrIK3FzFS+x07SHv2g/oYCIDqR FEDiiY/0yz2EOnPIrEdNO0UtomyHIzJyJTd7E= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=+ObfvECF1k7XByKeVBvD2P7FgdaZ9VPCnw0TWa/BRZ8=; b=bj+fUZTbCUgRgxF21SOY7KEf4eG7u0Ici3f8oQEXrxaufxzkzwS2zUBWTP4nRbaN7Z 6jzqC3/1RhnkDc+e2xvLlt6d1+SdYVxGCYIGvdlae7s4nWRiLjUMc2F6lt7H8h42/hc8 uDTvTSHq+EoNO+ppa690aI2w2ukcrZ9ti/g1HQuG69aKEd9f8bCWY0eX3Tl11R4lhUsz vdQUNM5sWq8f/cGjXBgyOtDvaah7us5SmIsOgB8+txzKHA7V2zv4CgN4FYVz8qlUeeNg I2l53AZM5YBAclIIg0fGp9BVxx5RqNcg7tCIpXWvaZWoQ51pziZGHYEHdQ1d+H2oaRh8 kV1A== X-Gm-Message-State: AKS2vOyu1OFvpqgk0gfJ1iQiSox04wBvZO6eq/z9iHJ5kWeJvYNCUKBJ w32Qcv03WhrBnMUX X-Received: by 10.223.142.202 with SMTP id q68mr7063392wrb.25.1497621893061; Fri, 16 Jun 2017 07:04:53 -0700 (PDT) Received: from lmenx321.st.com. ([80.214.78.131]) by smtp.gmail.com with ESMTPSA id h12sm1883277wrc.43.2017.06.16.07.04.51 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Fri, 16 Jun 2017 07:04:52 -0700 (PDT) From: Benjamin Gaignard To: john.stultz@linaro.org, tglx@linutronix.de, sboyd@codeaurora.org, shuah@kernel.org, linux-kernel@vger.kernel.org, linux-kselftest@vger.kernel.org, patrice.chotard@st.com, a.zummo@towertech.it, alexandre.belloni@free-electrons.com, linux-arm-kernel@lists.infradead.org, rtc-linux@googlegroups.com Subject: [PATCH 2/3] tools: timer: add test to check y2038/2106 bug Date: Fri, 16 Jun 2017 16:03:52 +0200 Message-Id: <1497621833-9942-3-git-send-email-benjamin.gaignard@linaro.org> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1497621833-9942-1-git-send-email-benjamin.gaignard@linaro.org> References: <1497621833-9942-1-git-send-email-benjamin.gaignard@linaro.org> X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20170616_070515_288859_C9C9D14D X-CRM114-Status: GOOD ( 17.76 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: linaro-kernel@lists.linaro.org, Benjamin Gaignard MIME-Version: 1.0 Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+patchwork-linux-arm=patchwork.kernel.org@lists.infradead.org X-Virus-Scanned: ClamAV using ClamSMTP The goal of this test is to check if a RTC device correctly support dates after years 2038 or 2106. It set a date (1-1-2200) on RTC and read it back to be sure that the driver is working well. The same thing is done on alarm. Signed-off-by: Benjamin Gaignard --- tools/testing/selftests/timers/Makefile | 4 +- tools/testing/selftests/timers/rtctest-2038.c | 135 ++++++++++++++++++++++++++ 2 files changed, 138 insertions(+), 1 deletion(-) create mode 100644 tools/testing/selftests/timers/rtctest-2038.c diff --git a/tools/testing/selftests/timers/Makefile b/tools/testing/selftests/timers/Makefile index 54481f1..7791f79 100644 --- a/tools/testing/selftests/timers/Makefile +++ b/tools/testing/selftests/timers/Makefile @@ -9,7 +9,8 @@ TEST_GEN_PROGS = posix_timers nanosleep nsleep-lat set-timer-lat mqueue-lat \ TEST_GEN_PROGS_EXTENDED = alarmtimer-suspend valid-adjtimex adjtick change_skew \ skew_consistency clocksource-switch leap-a-day \ - leapcrash set-tai set-2038 set-tz rtctest_setdate + leapcrash set-tai set-2038 set-tz rtctest_setdate \ + rtctest-2038 include ../lib.mk @@ -29,4 +30,5 @@ run_destructive_tests: run_tests ./set-tz ./set-tai ./set-2038 + ./rtctest-2038 diff --git a/tools/testing/selftests/timers/rtctest-2038.c b/tools/testing/selftests/timers/rtctest-2038.c new file mode 100644 index 0000000..213b7ee --- /dev/null +++ b/tools/testing/selftests/timers/rtctest-2038.c @@ -0,0 +1,135 @@ +/* Real Time Clock Driver Test + * by: Benjamin Gaignard (benjamin.gaignard@linaro.org) + * + * To build + * gcc rtctest-2038.c -o rtctest-2038 + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +static const char default_rtc[] = "/dev/rtc0"; + +int main(int argc, char **argv) +{ + int fd, retval; + struct rtc_time new, current; + const char *rtc = default_rtc; + + switch (argc) { + case 2: + rtc = argv[1]; + /* FALLTHROUGH */ + case 1: + break; + default: + fprintf(stderr, "usage: rtctest-2038 [rtcdev]\n"); + return 1; + } + + fprintf(stderr, "\nTest if RTC is robust for date after y2038/2106\n\n"); + + fd = open(rtc, O_RDONLY); + if (fd == -1) { + perror(rtc); + exit(errno); + } + + new.tm_year = 300; /* 2200 - 1900 */ + new.tm_mon = 0; + new.tm_mday = 1; + new.tm_hour = 0; + new.tm_min = 0; + new.tm_sec = 0; + + fprintf(stderr, "Test will set RTC date/time to %d-%d-%d, %02d:%02d:%02d.\n", + new.tm_mday, new.tm_mon + 1, new.tm_year + 1900, + new.tm_hour, new.tm_min, new.tm_sec); + + /* Write the new date in RTC */ + retval = ioctl(fd, RTC_SET_TIME, &new); + if (retval == -1) { + perror("RTC_SET_TIME ioctl"); + close(fd); + exit(errno); + } + + /* Read back */ + retval = ioctl(fd, RTC_RD_TIME, ¤t); + if (retval == -1) { + perror("RTC_RD_TIME ioctl"); + exit(errno); + } + + fprintf(stderr, "RTC date/time is %d-%d-%d, %02d:%02d:%02d.\n", + current.tm_mday, current.tm_mon + 1, current.tm_year + 1900, + current.tm_hour, current.tm_min, current.tm_sec); + + if (new.tm_year != current.tm_year || + new.tm_mon != current.tm_mon || + new.tm_mday != current.tm_mday || + new.tm_hour != current.tm_hour || + new.tm_min != current.tm_min || + new.tm_sec != current.tm_sec) { + fprintf(stderr, "\n\nSet Time test failed\n"); + close(fd); + return 1; + } + + new.tm_sec += 5; + + fprintf(stderr, "\nTest will set RTC alarm to %d-%d-%d, %02d:%02d:%02d.\n", + new.tm_mday, new.tm_mon + 1, new.tm_year + 1900, + new.tm_hour, new.tm_min, new.tm_sec); + + /* Write the new alarm in RTC */ + retval = ioctl(fd, RTC_ALM_SET, &new); + if (retval == -1) { + perror("RTC_ALM_SET ioctl"); + close(fd); + exit(errno); + } + + /* Read back */ + retval = ioctl(fd, RTC_ALM_READ, ¤t); + if (retval == -1) { + perror("RTC_ALM_READ ioctl"); + exit(errno); + } + + fprintf(stderr, "RTC alarm is %d-%d-%d, %02d:%02d:%02d.\n", + current.tm_mday, current.tm_mon + 1, current.tm_year + 1900, + current.tm_hour, current.tm_min, current.tm_sec); + + if (new.tm_year != current.tm_year || + new.tm_mon != current.tm_mon || + new.tm_mday != current.tm_mday || + new.tm_hour != current.tm_hour || + new.tm_min != current.tm_min || + new.tm_sec != current.tm_sec) { + fprintf(stderr, "\n\nSet alarm test failed\n"); + close(fd); + return 1; + } + + fprintf(stderr, "\nTest complete\n"); + close(fd); + return 0; +}