Received: by 10.223.185.116 with SMTP id b49csp61083wrg; Tue, 20 Feb 2018 15:56:53 -0800 (PST) X-Google-Smtp-Source: AH8x226IbbxDUg6qoojgwZEgUtcE9Jm1cxLysj0BG5V5uec3JOAXHdTNQTQ63vcpNCWIIm5s8oyW X-Received: by 2002:a17:902:b707:: with SMTP id d7-v6mr1267321pls.119.1519171013269; Tue, 20 Feb 2018 15:56:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519171013; cv=none; d=google.com; s=arc-20160816; b=LmCSkMECYdZtgQ7rCcWehPoW8jhQnWh50VfZCSgeHq9I5wH2O96Td5Zk2KnjnPLoiN L/LPm5mpWMIg9klR00yDJqoK63U8QtpOo86vfDhlzlLH3pDuEvEjgDVHL2017P76LoN8 SwK4eyVAbZOK+Qqk7J0BSPsPxHsJ+KYRe7p146Qk14ALLa3KK5FRZGO35+7jZhPNVL41 JLTdo1yB5xqdbKv/AkBasu9G5y2Reipe8k8OoPr6EkpaGTNTbZvWoB9cOR+pN3pjFcSn edB7v6HVSkk8NgMQ+m3fHL4JuShKvJJL0ZfKHdx+Z2srI5UmpoQi0F6yIcJ8YTquTwjU 0YzA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:date:cc:to:from:subject:message-id :arc-authentication-results; bh=VPbTosYH9peAy7Cmn/otQ2LgYsDnMPmUowOSZfcH1AQ=; b=RlASjQZmP5S0s9btKtzVBhlBNAZEe+EYuXVu7UF+m/BUJKr1960kM57RWcmmi95iAL awflf1cRJPzshN9FosAkZ7NnRHSTHeVt0l/3+pVJFzqdyOu/Fw1vkpbVvmwc92M+Atm9 Fs61gFIiTnKaOBkrJ6qBw9UdcSoDa1shL2RAcyB+ViOCWdhOWlpVxh/B0f/xisibz4NJ 5JvgywUavssjo7Jg6NV3dGK7eCFeoQ7QWNl39LSOcqATsw+zWbDJFQXne2a7nE8uxgWV PReC8LTKGUIG5OLsq5rnm3+tSmSC0cHCvqgDLoyReuUBZ0J7Hu/3JhTZch5Wy8klQNVX RPJA== 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 a20-v6si591853plm.683.2018.02.20.15.56.36; Tue, 20 Feb 2018 15:56:53 -0800 (PST) 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 S1751407AbeBTXzR (ORCPT + 99 others); Tue, 20 Feb 2018 18:55:17 -0500 Received: from smtprelay0216.hostedemail.com ([216.40.44.216]:46487 "EHLO smtprelay.hostedemail.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1751053AbeBTXzQ (ORCPT ); Tue, 20 Feb 2018 18:55:16 -0500 Received: from filter.hostedemail.com (clb03-v110.bra.tucows.net [216.40.38.60]) by smtprelay08.hostedemail.com (Postfix) with ESMTP id 0CB4F182CED2A; Tue, 20 Feb 2018 23:55:15 +0000 (UTC) X-Session-Marker: 6A6F6540706572636865732E636F6D X-Spam-Summary: 2,0,0,,d41d8cd98f00b204,joe@perches.com,:::::::::::::::::::::::::::::::::::::::::,RULES_HIT:41:355:379:541:599:960:988:989:1260:1277:1311:1313:1314:1345:1359:1373:1437:1515:1516:1518:1534:1542:1593:1594:1711:1730:1747:1777:1792:1960:1963:2393:2559:2562:2828:3138:3139:3140:3141:3142:3355:3622:3865:3866:3867:3868:3870:3871:3872:3874:4321:5007:6742:7653:7903:10004:10400:10848:11026:11232:11473:11658:11914:12048:12050:12296:12438:12740:12760:12895:13255:13439:14096:14097:14659:14721:21080:21611:21627:30029:30034:30054:30091,0,RBL:85.4.153.126:@perches.com:.lbl8.mailshell.net-62.8.60.190 64.201.201.201,CacheIP:none,Bayesian:0.5,0.5,0.5,Netcheck:none,DomainCache:0,MSF:not bulk,SPF:fn,MSBL:0,DNSBL:neutral,Custom_rules:0:0:0,LFtime:19,LUA_SUMMARY:none X-HE-Tag: road95_846c1b1f7a311 X-Filterd-Recvd-Size: 4073 Received: from XPS-9350 (126.153.4.85.dynamic.wline.res.cust.swisscom.ch [85.4.153.126]) (Authenticated sender: joe@perches.com) by omf13.hostedemail.com (Postfix) with ESMTPA; Tue, 20 Feb 2018 23:55:09 +0000 (UTC) Message-ID: <1519170907.4326.17.camel@perches.com> Subject: Re: [PATCH v2 01/21] lib/vsprintf: Print time and date in human readable format via %pt From: Joe Perches To: Andy Shevchenko , Rasmus Villemoes , Greg Kroah-Hartman , Andrew Morton , linux-kernel@vger.kernel.org, Alessandro Zummo , Alexandre Belloni , linux-rtc@vger.kernel.org, Arnd Bergmann , Mark Salyzyn Cc: Bartlomiej Zolnierkiewicz , Dmitry Torokhov , Geert Uytterhoeven , Guan Xuetao , Ingo Molnar , Jason Wessel , Jonathan Corbet , Jonathan Hunter , Krzysztof Kozlowski , "Rafael J. Wysocki" , Thierry Reding Date: Tue, 20 Feb 2018 15:55:07 -0800 In-Reply-To: <20180220214400.66749-2-andriy.shevchenko@linux.intel.com> References: <20180220214400.66749-1-andriy.shevchenko@linux.intel.com> <20180220214400.66749-2-andriy.shevchenko@linux.intel.com> Content-Type: text/plain; charset="ISO-8859-1" X-Mailer: Evolution 3.26.1-1 Mime-Version: 1.0 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, 2018-02-20 at 23:43 +0200, Andy Shevchenko wrote: > There are users which print time and date represented by content of > struct rtc_time in human readable format. > > Instead of open coding that each time introduce %ptR[dt][rv] specifier. > > Note, users have to select PRINTK_PEXT_TIMEDATE option in a Kconfig. Not sure this is a great option. Not just the name, the need to select it. > diff --git a/lib/vsprintf.c b/lib/vsprintf.c [] > +static noinline_for_stack > +char *date_str(char *buf, char *end, const struct rtc_time *tm, bool v, bool r) > +{ > + int year = tm->tm_year + (r ? 0 : 1900); > + int mon = tm->tm_mon + (r ? 0 : 1); What happens with negative values? Perhaps these temporaries should be unsigned int. > + > + if (unlikely(v && (unsigned int)tm->tm_year > 200)) > + buf = string(buf, end, "****", default_str_spec); > + else > + buf = number(buf, end, year, default_dec04_spec); > + > + if (buf < end) > + *buf = '-'; > + buf++; > + > + if (unlikely(v && (unsigned int)tm->tm_mon > 11)) > + buf = string(buf, end, "**", default_str_spec); > + else > + buf = number(buf, end, mon, default_dec02_spec); > + > + if (buf < end) > + *buf = '-'; > + buf++; > + > + if (unlikely(v && (unsigned int)tm->tm_mday > 31)) > + buf = string(buf, end, "**", default_str_spec); > + else > + buf = number(buf, end, tm->tm_mday, default_dec02_spec); > + > + return buf; > +} > + > +static noinline_for_stack > +char *time_str(char *buf, char *end, const struct rtc_time *tm, bool v, bool r) > +{ Maybe use unsigned int temporaries here too for hour, min, sec > + if (unlikely(v && (unsigned int)tm->tm_hour > 24)) > + buf = string(buf, end, "**", default_str_spec); > + else > + buf = number(buf, end, tm->tm_hour, default_dec02_spec); > + > + if (buf < end) > + *buf = ':'; > + buf++; > + > + if (unlikely(v && (unsigned int)tm->tm_min > 59)) leap seconds are allowed in the struct > + buf = string(buf, end, "**", default_str_spec); > + else > + buf = number(buf, end, tm->tm_min, default_dec02_spec); > + > + if (buf < end) > + *buf = ':'; > + buf++; > + > + if (unlikely(v && (unsigned int)tm->tm_sec > 59)) > + buf = string(buf, end, "**", default_str_spec); > + else > + buf = number(buf, end, tm->tm_sec, default_dec02_spec); > + > + return buf; > +} >