Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp808872ybz; Wed, 15 Apr 2020 19:36:59 -0700 (PDT) X-Google-Smtp-Source: APiQypLy7UbkBnvzWd+zPH6JkjOqvbwOQMTbxa1iBZraVqYLW/9vonZ2MRsifRM/FxtOQd4xSvPr X-Received: by 2002:aa7:cdce:: with SMTP id h14mr20086069edw.51.1587004619085; Wed, 15 Apr 2020 19:36:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587004619; cv=none; d=google.com; s=arc-20160816; b=Yq6+gGEvDp5K/nUDK69SkPZ4FnbEI5XSy9VDgDlp0iQXtGuSxrA01An6ue4MFUN5Ss ICv2bhPyD5fi50NbZeuFAGzAUASkgG9rPBWjGE1qYD4hLyhIAzt0NgHwQw/EKnxxzeek L8xFq/7NhGcs+9KrH556jnXJ/jFZZEC79rSa2VGPV5BdI12EKeqPIA+LOys8TMQtZZxj aOb1E6TcsdRJ2sU7WKRMv3Ye0PvWe8ajJWIWprePqpVGglpVlvN+k89u5pxizUS6NtqJ UrDIfObnDkHhojFxj4smCV+xXPBikRbVBhM5yTBSVdbQzZAeCISiE3/deDes1BVQRkXu UYLA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:date:from :dkim-signature; bh=TqEg5Op8tvCWqEi639RgXT0ywOBk8iUyJxWjz6oTWuk=; b=SlpdtAd7rw4Wu2IohNOMgGwiDNaVWG8qD31Mj6m4obyJ8+nueVYtfHwIh/wojV+fWy 3A7AL3uvLCzy1EglSoQt3KWbmQJ73ZSV57o7uTfqJdAkpb0XRBaQjXKmHOG+OBufjOvX N0es89mdG0S+BkVgN2DaTKj+WDSk+UdpSESn3cpwqR+/mdQ7S4PM5gRXZBA/vPlr9rdv nEM/PcsGWl4FR9lBHTcQobxzV4cdjPyLmjknGnW5s+ma99RxcxUetM4ISP/mP7sv0BL/ KAvhEO5y7YRLoXLmXWYbybocrOOlwdKDAcBls+xrnAL/ZvOUPM561IbFCM3uqTXnfhAA LPSQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=qicloPiy; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y24si10979659ejr.132.2020.04.15.19.36.36; Wed, 15 Apr 2020 19:36:59 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=qicloPiy; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388214AbgDPCc3 (ORCPT + 99 others); Wed, 15 Apr 2020 22:32:29 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38318 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1733009AbgDPCcZ (ORCPT ); Wed, 15 Apr 2020 22:32:25 -0400 Received: from mail-pg1-x544.google.com (mail-pg1-x544.google.com [IPv6:2607:f8b0:4864:20::544]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2B18FC061A0C for ; Wed, 15 Apr 2020 19:32:24 -0700 (PDT) Received: by mail-pg1-x544.google.com with SMTP id i3so947970pgk.1 for ; Wed, 15 Apr 2020 19:32:24 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:date:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to; bh=TqEg5Op8tvCWqEi639RgXT0ywOBk8iUyJxWjz6oTWuk=; b=qicloPiyu1Mxkeo/8xV5Zt+B740ERXtlKv1GKL3ZEYU+baSzY7tQAx0HLDvG5bDm22 wTkX2CuuX5I5UflUGCC5Y1MTcgMCxTP2gjJedTpbAU8p8cA8ckIOzXJ3PzSwRTM9JmT+ cPhMd1pbXfYHSXpKSCdl/lUXrmW4mPov4ouLSyDabRtuqWKIo/Nn7FwIrfXpynPVeg5q IdsnymYllTysXu8RfoxNbS01e5eL7Xo4zEXy63aSBLttfbnHyPMbq/RYZIWNJIG2SB6I m7IDaAhTubeoBgFy0C0RmC4YFIZ7Y8p9IzgLDmsyrd1mVcCH+qIBDCu/BSiVsIBgZdeS Yufw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:date:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to; bh=TqEg5Op8tvCWqEi639RgXT0ywOBk8iUyJxWjz6oTWuk=; b=Gtv9y/N0B24vEFADjHoWTfNbd6RPKfTGPgWZPWHCrfZyAO0muNAEP5Md5gT7GTF6zo y3SiOTxL1WG3jIIATcth9ez6eNBVzxKZUdkA6Fn6wZ04Ggm6DnHEZq+AtsK4pAkwONVb Mrnj3dinLymteCjM7qVxgAFdmuYmRokphHPfz4T4BgrCu0jmt0SiP6z139AqR8qmDGHd GnVR3NCBklgYgC4CWu4ylaAWCht/pQXXBSHWvmUda2ZTEOgTEa3GZ/dUV8Ilz3b+Pkfr 3wIGfm8UBTg7hm/GIDhfY8EBfA7YjkeeaEEv9/xH1B3ozbBBaGfXfaclAWlyLg8D4Un0 7aBQ== X-Gm-Message-State: AGi0PuaQklygRkUf7T+Vtj7f8jUMWPNu2OpTvzRXLF8nlEkzMOZxEXu8 GjIgKW+dTd8dT/r6cmW1qrk= X-Received: by 2002:a63:4b16:: with SMTP id y22mr28163012pga.251.1587004343436; Wed, 15 Apr 2020 19:32:23 -0700 (PDT) Received: from localhost (181.56.30.125.dy.iij4u.or.jp. [125.30.56.181]) by smtp.gmail.com with ESMTPSA id u24sm11928468pgo.65.2020.04.15.19.32.21 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 15 Apr 2020 19:32:22 -0700 (PDT) From: Sergey Senozhatsky X-Google-Original-From: Sergey Senozhatsky Date: Thu, 16 Apr 2020 11:32:19 +0900 To: Andy Shevchenko Cc: Petr Mladek , Steven Rostedt , Sergey Senozhatsky , linux-kernel@vger.kernel.org, Rasmus Villemoes , Andrew Morton , Hans Verkuil , Jonathan Corbet , Alexandre Belloni Subject: Re: [PATCH v3 1/3] lib/vsprintf: Print time64_t in human readable format Message-ID: <20200416023219.GA30641@jagdpanzerIV.localdomain> References: <20200415170046.33374-1-andriy.shevchenko@linux.intel.com> <20200415170046.33374-2-andriy.shevchenko@linux.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200415170046.33374-2-andriy.shevchenko@linux.intel.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On (20/04/15 20:00), Andy Shevchenko wrote: [..] > #include > #include > @@ -1819,6 +1820,29 @@ char *rtc_str(char *buf, char *end, const struct rtc_time *tm, > return buf; > } > > +static noinline_for_stack > +char *time64_str(char *buf, char *end, const time64_t time, > + struct printf_spec spec, const char *fmt) > +{ > + struct rtc_time rtc_time; > + struct tm tm; > + > + time64_to_tm(time, 0, &tm); > + > + rtc_time.tm_sec = tm.tm_sec; > + rtc_time.tm_min = tm.tm_min; > + rtc_time.tm_hour = tm.tm_hour; > + rtc_time.tm_mday = tm.tm_mday; > + rtc_time.tm_mon = tm.tm_mon; > + rtc_time.tm_year = tm.tm_year; > + rtc_time.tm_wday = tm.tm_wday; > + rtc_time.tm_yday = tm.tm_yday; > + > + rtc_time.tm_isdst = 0; Here you convert time64_t (signed, we also have unsigned version - timeu64_t) to tm first and then convert tm to rtc_time. Will rtc_time64_to_tm() do the trick? -ss