From patchwork Tue Jul 24 21:36:23 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Arnd Bergmann X-Patchwork-Id: 142830 Delivered-To: patch@linaro.org Received: by 2002:a2e:9754:0:0:0:0:0 with SMTP id f20-v6csp65180ljj; Tue, 24 Jul 2018 14:36:55 -0700 (PDT) X-Google-Smtp-Source: AAOMgpczDU5VZiDRUmz/ROVVCL04e3/j+chLHDOJ97gMzEWj/ehNXjEKDY+ZLg+Jj8gHYpVt3dAZ X-Received: by 2002:a62:e106:: with SMTP id q6-v6mr19542255pfh.75.1532468215411; Tue, 24 Jul 2018 14:36:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1532468215; cv=none; d=google.com; s=arc-20160816; b=hpkBHsFsXY3LV7gacEmow/E5Pgz64JVXw4CP5ShMtI/p/j/i1UzvgUznMTQwVVFEgr 3ClpoSVBjcsB0wGmV2oIhzpYWiNingx4YeGKB+xyYtNVVkCixdSPQiF9c4NUaPZu45BZ qgvjGiov2HhUtrjov4iyuQFLNcAxw0J9X5kAjBCyGSQOav7VcefD07D5ZpH6RQLzkLnl WHi9lvs5XkewC+NQGmn+26fvxebmv7VDkMojc0ugY034AJWhzxdgJt55lzi75/gPo0Ld x6dBMx91M24ZN0s36KqE7NaxdrltA1YbpswpJv+fdeKPynui16vijOXsHUw01xfPJ9JH nHdg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:arc-authentication-results; bh=zqvHEMytYhUEIaB0p8C+ZVDsQEV8RXY9eqvEpnkC3bE=; b=CDy5bUXXEKwWqdncPsH4z+biY265+2oNgapmWFsiBph9lKAdmZj9FDZrtjJRyhYYUf 1wAJKidF3zcvcFgsWiULiQnRdHIyNQBmkecXi7FfBj7gW+fVF2s1gSmAAQznXr8KHIdd iWNVYYDU/yIFPjdiO2JjIcoz0iUDODamuHhLBcgbzxbHaQjQpjRMOQYjnwGo3MdHolyV AZQaJjvhrr2oifJ2HvbKaZIAOhrXf57cT32183S7D3/RbZP4qotbRM93gg1hFITvUArd cqlQ2gFlbs4PqQYudqEr/V2ShMonoE4RmgfVtLIiFspLKJxu2FKReyg1X/MMSQiMBbSu F6JA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p65-v6si12654050pga.401.2018.07.24.14.36.55; Tue, 24 Jul 2018 14:36:55 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388721AbeGXWpR (ORCPT + 31 others); Tue, 24 Jul 2018 18:45:17 -0400 Received: from mout.kundenserver.de ([212.227.126.131]:36132 "EHLO mout.kundenserver.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727453AbeGXWpR (ORCPT ); Tue, 24 Jul 2018 18:45:17 -0400 Received: from wuerfel.lan ([109.193.40.16]) by mrelayeu.kundenserver.de (mreue006 [212.227.15.129]) with ESMTPA (Nemesis) id 0MgDvl-1fKlD52hBF-00NVMy; Tue, 24 Jul 2018 23:36:34 +0200 From: Arnd Bergmann To: dalias@libc.org Cc: ysato@users.sourceforge.jp, baolin.wang@linaro.org, y2038@lists.linaro.org, linux-sh@vger.kernel.org, linux-kernel@vger.kernel.org, Arnd Bergmann Subject: [PATCH v2 3/4] sh: remove unused rtc_sh_get/set_time infrastructure Date: Tue, 24 Jul 2018 23:36:23 +0200 Message-Id: <20180724213624.3899336-3-arnd@arndb.de> X-Mailer: git-send-email 2.18.0 In-Reply-To: <20180724213624.3899336-1-arnd@arndb.de> References: <20180724213624.3899336-1-arnd@arndb.de> X-Provags-ID: V03:K1:U1Qrjj1bkxg0qF4o5IC8qmsI3joJaEm+yz4arZrc83Qq402sChO TuyW69VJb102RT0/BB13urqwiQkhI1cD4cM7GC9IxZaUEYO9PQ41tivMFlbfALICIELImAy 3dj5lSRuG9CJsO0T8qzSHrB1maMFUCHcbEFGpJCEVw3V/cbnjZADRq5xq6KKgCE6eWBsl9m dzklb5DVhoFBRJPwR5+Zw== X-UI-Out-Filterresults: notjunk:1; V01:K0:LmUWx6R57Z8=:E8k7JeGgQCLaJB5o8Etzif 3WGRy5abn8W1tu4EqaAFXrwmIvnkDWKmz4T0h+AeMNzblegzflllLxVxfnhdb0jh0qJFXVKr9 QuRukRMbBsvlYHzze9hmm+XvBQDz3p7mJ5h6IHk4651BBzATqoZvXnI5aXlzvJa7oO8vvsojt yQ/8S7+HgnEKGJ2f032gU3nfBExTnSBYB/P3DOBTsWdWdIl7tvJX1HAwywrVLfi9Xfrn4AxQO LN8Ahi5H9zQ8XvbZb0c9FCmIvV4+V9nDh3nzMN1xaNXNwielmm1vIMcZn/SH/r/ZkAI6Rt4pb T7ku/lAwcTJ9f8qm/ujee0yrXzSSQj6p1dwuOlNca64HOdgdYGpbqi6e/Ol7OCQBDKesEGEbM L0hh04kcDg59BcnlANw/mu64IMXqV9BvoYeMLvwl/8mny4d4tAfxEwPtGAJNG+Vo1DgkcANAm XNmbkgrAG8+qQvR2nPZQH0YP8J718Zn10Z1Ht/vFRx0wd4n1eR+pw4kJr0Abam5lFJ/B9il78 N09uZ/NL4YH40pU3haBDyuoEPLfuOaydjcxYap18jhLemhZl7YD2t0IUxPmscMYLvYWBKjeQ3 VCNyhS1iJeA7nZysWYffLFHPYZ6hyINwTCnKBufKeDwYuQVKIOf1tbzrO9SctWlcNRhnaJkpC qsToOxZ9Wn5NQ9CaK36rxBJWQhKSDLngsQCqACB5cDy9+aBiXHJbNAuDUfki4if+CsHo= Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org All platforms are now converted to RTC drivers, so this has become obsolete. The board_time_init() callback still has one caller, but could otherwise also get killed. This removes one more usage of the deprecated timespec structure, which overflows in y2038. Signed-off-by: Arnd Bergmann --- arch/sh/include/asm/rtc.h | 2 -- arch/sh/kernel/time.c | 69 --------------------------------------- 2 files changed, 71 deletions(-) -- 2.18.0 diff --git a/arch/sh/include/asm/rtc.h b/arch/sh/include/asm/rtc.h index c63555ee1255..fe55fbb181aa 100644 --- a/arch/sh/include/asm/rtc.h +++ b/arch/sh/include/asm/rtc.h @@ -4,8 +4,6 @@ void time_init(void); extern void (*board_time_init)(void); -extern void (*rtc_sh_get_time)(struct timespec *); -extern int (*rtc_sh_set_time)(const time_t); #define RTC_CAP_4_DIGIT_YEAR (1 << 0) diff --git a/arch/sh/kernel/time.c b/arch/sh/kernel/time.c index fcd5e41977d1..eb0a91270499 100644 --- a/arch/sh/kernel/time.c +++ b/arch/sh/kernel/time.c @@ -22,75 +22,6 @@ #include #include -/* Dummy RTC ops */ -static void null_rtc_get_time(struct timespec *tv) -{ - tv->tv_sec = mktime(2000, 1, 1, 0, 0, 0); - tv->tv_nsec = 0; -} - -static int null_rtc_set_time(const time_t secs) -{ - return 0; -} - -void (*rtc_sh_get_time)(struct timespec *) = null_rtc_get_time; -int (*rtc_sh_set_time)(const time_t) = null_rtc_set_time; - -void read_persistent_clock(struct timespec *ts) -{ - rtc_sh_get_time(ts); -} - -#ifdef CONFIG_GENERIC_CMOS_UPDATE -int update_persistent_clock(struct timespec now) -{ - return rtc_sh_set_time(now.tv_sec); -} -#endif - -static int rtc_generic_get_time(struct device *dev, struct rtc_time *tm) -{ - struct timespec tv; - - rtc_sh_get_time(&tv); - rtc_time_to_tm(tv.tv_sec, tm); - return 0; -} - -static int rtc_generic_set_time(struct device *dev, struct rtc_time *tm) -{ - unsigned long secs; - - rtc_tm_to_time(tm, &secs); - if ((rtc_sh_set_time == null_rtc_set_time) || - (rtc_sh_set_time(secs) < 0)) - return -EOPNOTSUPP; - - return 0; -} - -static const struct rtc_class_ops rtc_generic_ops = { - .read_time = rtc_generic_get_time, - .set_time = rtc_generic_set_time, -}; - -static int __init rtc_generic_init(void) -{ - struct platform_device *pdev; - - if (rtc_sh_get_time == null_rtc_get_time) - return -ENODEV; - - pdev = platform_device_register_data(NULL, "rtc-generic", -1, - &rtc_generic_ops, - sizeof(rtc_generic_ops)); - - - return PTR_ERR_OR_ZERO(pdev); -} -device_initcall(rtc_generic_init); - void (*board_time_init)(void); static void __init sh_late_time_init(void)