Message ID | 20170719194511.28899-1-salyzyn@android.com (mailing list archive) |
---|---|
State | Not Applicable, archived |
Headers | show |
Hi, On 19/07/2017 at 12:44:41 -0700, Mark Salyzyn wrote: > Primary purpose of rtc_show_time is to provide a marker used for > post-mortem Battery and Power analysis. These markers occur at > major discontinuities of time, and thus optionally add a timestamp > to aid the analysis. This function is to be called at a higher > level, and were added because of a lack of current kernel logging > data. > I really think you should drop rtc from the config, function and file names because this doesn't have any relationship with any RTC stuff. I can just see that you are (ab)using rtc_time64_to_tm because there is no struct tm or gmtime() in the kernel. > The persistent clock that is used to report Suspended for message > is not present on all platforms, and is currently standardized for > millisecond precision. > > An added value to the time report is the ability in post-mortem > triage analysis to synchronize kernel activities in MONOTONIC > time with user space activities in REALTIME. > > Feature activated by CONFIG_RTC_SHOW_TIME_<TYPE>, where <TYPE> is > None (default, disabled), realtime, boottime or monotonic. > > Since this is for post mortem field analysis, there is no debugfs > or trace facility that can generally be leveraged. analyze_suspend.py > for example requires a debug configured kernel, on the other hand > these prints can remain in a field product. The purpose for > rtc_show_time is not for development debugging. > > Data collected may be recorded by klogd with a longer logspan > than the built-in dmesg buffer, or land in pstore console driver > to be collected after a reboot. > > Signed-off-by: Mark Salyzyn <salyzyn@android.com> > > v2: > - move implementation to kernel timekeeping from rtc_lib files > - use rtc_time64_to_tm() instead of rtc_time_to_tm() > - use inline in include/linux/rtc.h for !CONFIG_RTC_SHOW_TIME > v3: > - _correctly_ use rtc_time64_to_tm > v4: > - introduce CONFIG_RTC_SHOW_TIME_<TYPE> and split off rtc time > format printing to a separate patch. > > --- > include/linux/rtc.h | 5 +++ > kernel/time/Kconfig | 77 +++++++++++++++++++++++++++++++++++++++++++++ > kernel/time/Makefile | 1 + > kernel/time/rtc_show_time.c | 29 +++++++++++++++++ > 4 files changed, 112 insertions(+) > create mode 100644 kernel/time/rtc_show_time.c > > diff --git a/include/linux/rtc.h b/include/linux/rtc.h > index 0a0f0d14a5fb..779401c937d5 100644 > --- a/include/linux/rtc.h > +++ b/include/linux/rtc.h > @@ -22,6 +22,11 @@ extern int rtc_year_days(unsigned int day, unsigned int month, unsigned int year > extern int rtc_valid_tm(struct rtc_time *tm); > extern time64_t rtc_tm_to_time64(struct rtc_time *tm); > extern void rtc_time64_to_tm(time64_t time, struct rtc_time *tm); > +#ifdef CONFIG_RTC_SHOW_TIME > +extern void rtc_show_time(const char *prefix_msg); > +#else > +static inline void rtc_show_time(const char *prefix_msg) { } > +#endif > ktime_t rtc_tm_to_ktime(struct rtc_time tm); > struct rtc_time rtc_ktime_to_tm(ktime_t kt); > > diff --git a/kernel/time/Kconfig b/kernel/time/Kconfig > index ac09bc29eb08..2dc891056635 100644 > --- a/kernel/time/Kconfig > +++ b/kernel/time/Kconfig > @@ -145,3 +145,80 @@ config HIGH_RES_TIMERS > > endmenu > endif > + > +config RTC_SHOW_TIME > + bool > + help > + Activate optional rtc_show_time(const char *msg) wall clock > + time instrumentation. > + > + The primary use of the instrumentation is to aid field > + analysis of Battery and Power usage. The instrumentation > + may also help triage and synchronize kernel logs and user > + space activity logs at key displacements. For instance > + CLOCK_MONOTONIC stops while suspended, while CLOCK_REALTIME > + continues, and the timestamps help re-orient post-analysis. > + > + Select the appropriate RTC_SHOW_TIME_<type> > + > +choice > + prompt "choose a clock for rtc_show_time" > + config RTC_SHOW_TIME_NONE > + bool "not activated" > + help > + Turn off all printing associated with rtc_show_time > + > + The primary use of the instrumentation is to aid field > + analysis of Battery and Power usage. The instrumentation > + may also help triage and synchronize kernel logs and user > + space activity logs at key displacements. For instance > + CLOCK_MONOTONIC stops while suspended, while CLOCK_REALTIME > + continues, and the timestamps help re-orient post-analysis. > + > + This is the default behavior. > + config RTC_SHOW_TIME_REALTIME > + bool "realtime" > + select RTC_SHOW_TIME > + help > + Activate optional rtc_show_time(const char *msg) wall clock > + time instrumentation. > + > + The primary use of the instrumentation is to aid field > + analysis of Battery and Power usage. The instrumentation > + may also help triage and synchronize kernel logs and user > + space activity logs at key displacements. For instance > + CLOCK_MONOTONIC stops while suspended, while CLOCK_REALTIME > + continues, and the timestamps help re-orient post-analysis. > + > + Print realtime <epoch>.<ns> timestamp in rtc_show_time > + config RTC_SHOW_TIME_MONOTONIC > + bool "monotonic" > + select RTC_SHOW_TIME > + help > + Activate optional rtc_show_time(const char *msg) wall clock > + time instrumentation. > + > + The primary use of the instrumentation is to aid field > + analysis of Battery and Power usage. The instrumentation > + may also help triage and synchronize kernel logs and user > + space activity logs at key displacements. For instance > + CLOCK_MONOTONIC stops while suspended, while CLOCK_REALTIME > + continues, and the timestamps help re-orient post-analysis. > + > + Print only the supplied message in rtc_show_time > + config RTC_SHOW_TIME_BOOTTIME > + bool "boottime" > + select RTC_SHOW_TIME > + help > + Activate optional rtc_show_time(const char *msg) wall clock > + time instrumentation. > + > + The primary use of the instrumentation is to aid field > + analysis of Battery and Power usage. The instrumentation > + may also help triage and synchronize kernel logs and user > + space activity logs at key displacements. For instance > + CLOCK_MONOTONIC stops while suspended, while CLOCK_REALTIME > + continues, and the timestamps help re-orient post-analysis. > + > + Print boottime <s>.<ns> timestamp in rtc_show_time > +endchoice > diff --git a/kernel/time/Makefile b/kernel/time/Makefile > index 938dbf33ef49..66f17e641052 100644 > --- a/kernel/time/Makefile > +++ b/kernel/time/Makefile > @@ -17,3 +17,4 @@ obj-$(CONFIG_GENERIC_SCHED_CLOCK) += sched_clock.o > obj-$(CONFIG_TICK_ONESHOT) += tick-oneshot.o tick-sched.o > obj-$(CONFIG_DEBUG_FS) += timekeeping_debug.o > obj-$(CONFIG_TEST_UDELAY) += test_udelay.o > +obj-$(CONFIG_RTC_SHOW_TIME) += rtc_show_time.o > diff --git a/kernel/time/rtc_show_time.c b/kernel/time/rtc_show_time.c > new file mode 100644 > index 000000000000..19a8a0cc94f0 > --- /dev/null > +++ b/kernel/time/rtc_show_time.c > @@ -0,0 +1,29 @@ > +/* > + * rtc time printing utility functions > + * > + * This program is free software; you can redistribute it and/or modify > + * it under the terms of the GNU General Public License version 2 as > + * published by the Free Software Foundation. > + */ > + > +#include <linux/rtc.h> > + > +void rtc_show_time(const char *prefix_msg) > +{ > +#if defined(CONFIG_RTC_SHOW_TIME_MONOTONIC) /* dmesg is in monotonic */ > + pr_info("%s\n", prefix_msg ? prefix_msg : "Time:"); > +#elif defined(CONFIG_RTC_SHOW_TIME_BOOTTIME) > + struct timespec64 ts; > + > + getboottime64(&ts); > + pr_info("%s %lu.%09lu B\n", > + prefix_msg ? prefix_msg : "Time:", ts.tv_sec, ts.tv_nsec); > +#else /* realtime */ > + struct timespec64 ts; > + > + getnstimeofday64(&ts); > + pr_info("%s %lu.%09lu UTC\n", > + prefix_msg ? prefix_msg : "Time:", ts.tv_sec, ts.tv_nsec); > +#endif > +} > +EXPORT_SYMBOL(rtc_show_time); > -- > 2.14.0.rc0.284.gd933b75aa4-goog >
On 07/19/2017 02:22 PM, Alexandre Belloni wrote: > Hi, > > On 19/07/2017 at 12:44:41 -0700, Mark Salyzyn wrote: >> Primary purpose of rtc_show_time is to provide a marker used for >> post-mortem Battery and Power analysis. These markers occur at >> major discontinuities of time, and thus optionally add a timestamp >> to aid the analysis. This function is to be called at a higher >> level, and were added because of a lack of current kernel logging >> data. >> > I really think you should drop rtc from the config, function and file > names because this doesn't have any relationship with any RTC stuff. Agreed and Thanks. In another response, this function has more in common with a pr_info_show_time() than I previously have accepted. Most of the rtc part goes away if I follow that thread/idea Leaving the following: > I can just see that you are (ab)using rtc_time64_to_tm because there is > no struct tm or gmtime() in the kernel. Yes, since we put that part into a separate patch, that can be punted/accepted on its own, using rtc-lib is a simple concept. The commit message for that patch should have had your line of sentiment in it! (even (ab)using message :-) ) -- Mark
diff --git a/include/linux/rtc.h b/include/linux/rtc.h index 0a0f0d14a5fb..779401c937d5 100644 --- a/include/linux/rtc.h +++ b/include/linux/rtc.h @@ -22,6 +22,11 @@ extern int rtc_year_days(unsigned int day, unsigned int month, unsigned int year extern int rtc_valid_tm(struct rtc_time *tm); extern time64_t rtc_tm_to_time64(struct rtc_time *tm); extern void rtc_time64_to_tm(time64_t time, struct rtc_time *tm); +#ifdef CONFIG_RTC_SHOW_TIME +extern void rtc_show_time(const char *prefix_msg); +#else +static inline void rtc_show_time(const char *prefix_msg) { } +#endif ktime_t rtc_tm_to_ktime(struct rtc_time tm); struct rtc_time rtc_ktime_to_tm(ktime_t kt); diff --git a/kernel/time/Kconfig b/kernel/time/Kconfig index ac09bc29eb08..2dc891056635 100644 --- a/kernel/time/Kconfig +++ b/kernel/time/Kconfig @@ -145,3 +145,80 @@ config HIGH_RES_TIMERS endmenu endif + +config RTC_SHOW_TIME + bool + help + Activate optional rtc_show_time(const char *msg) wall clock + time instrumentation. + + The primary use of the instrumentation is to aid field + analysis of Battery and Power usage. The instrumentation + may also help triage and synchronize kernel logs and user + space activity logs at key displacements. For instance + CLOCK_MONOTONIC stops while suspended, while CLOCK_REALTIME + continues, and the timestamps help re-orient post-analysis. + + Select the appropriate RTC_SHOW_TIME_<type> + +choice + prompt "choose a clock for rtc_show_time" + config RTC_SHOW_TIME_NONE + bool "not activated" + help + Turn off all printing associated with rtc_show_time + + The primary use of the instrumentation is to aid field + analysis of Battery and Power usage. The instrumentation + may also help triage and synchronize kernel logs and user + space activity logs at key displacements. For instance + CLOCK_MONOTONIC stops while suspended, while CLOCK_REALTIME + continues, and the timestamps help re-orient post-analysis. + + This is the default behavior. + config RTC_SHOW_TIME_REALTIME + bool "realtime" + select RTC_SHOW_TIME + help + Activate optional rtc_show_time(const char *msg) wall clock + time instrumentation. + + The primary use of the instrumentation is to aid field + analysis of Battery and Power usage. The instrumentation + may also help triage and synchronize kernel logs and user + space activity logs at key displacements. For instance + CLOCK_MONOTONIC stops while suspended, while CLOCK_REALTIME + continues, and the timestamps help re-orient post-analysis. + + Print realtime <epoch>.<ns> timestamp in rtc_show_time + config RTC_SHOW_TIME_MONOTONIC + bool "monotonic" + select RTC_SHOW_TIME + help + Activate optional rtc_show_time(const char *msg) wall clock + time instrumentation. + + The primary use of the instrumentation is to aid field + analysis of Battery and Power usage. The instrumentation + may also help triage and synchronize kernel logs and user + space activity logs at key displacements. For instance + CLOCK_MONOTONIC stops while suspended, while CLOCK_REALTIME + continues, and the timestamps help re-orient post-analysis. + + Print only the supplied message in rtc_show_time + config RTC_SHOW_TIME_BOOTTIME + bool "boottime" + select RTC_SHOW_TIME + help + Activate optional rtc_show_time(const char *msg) wall clock + time instrumentation. + + The primary use of the instrumentation is to aid field + analysis of Battery and Power usage. The instrumentation + may also help triage and synchronize kernel logs and user + space activity logs at key displacements. For instance + CLOCK_MONOTONIC stops while suspended, while CLOCK_REALTIME + continues, and the timestamps help re-orient post-analysis. + + Print boottime <s>.<ns> timestamp in rtc_show_time +endchoice diff --git a/kernel/time/Makefile b/kernel/time/Makefile index 938dbf33ef49..66f17e641052 100644 --- a/kernel/time/Makefile +++ b/kernel/time/Makefile @@ -17,3 +17,4 @@ obj-$(CONFIG_GENERIC_SCHED_CLOCK) += sched_clock.o obj-$(CONFIG_TICK_ONESHOT) += tick-oneshot.o tick-sched.o obj-$(CONFIG_DEBUG_FS) += timekeeping_debug.o obj-$(CONFIG_TEST_UDELAY) += test_udelay.o +obj-$(CONFIG_RTC_SHOW_TIME) += rtc_show_time.o diff --git a/kernel/time/rtc_show_time.c b/kernel/time/rtc_show_time.c new file mode 100644 index 000000000000..19a8a0cc94f0 --- /dev/null +++ b/kernel/time/rtc_show_time.c @@ -0,0 +1,29 @@ +/* + * rtc time printing utility functions + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + */ + +#include <linux/rtc.h> + +void rtc_show_time(const char *prefix_msg) +{ +#if defined(CONFIG_RTC_SHOW_TIME_MONOTONIC) /* dmesg is in monotonic */ + pr_info("%s\n", prefix_msg ? prefix_msg : "Time:"); +#elif defined(CONFIG_RTC_SHOW_TIME_BOOTTIME) + struct timespec64 ts; + + getboottime64(&ts); + pr_info("%s %lu.%09lu B\n", + prefix_msg ? prefix_msg : "Time:", ts.tv_sec, ts.tv_nsec); +#else /* realtime */ + struct timespec64 ts; + + getnstimeofday64(&ts); + pr_info("%s %lu.%09lu UTC\n", + prefix_msg ? prefix_msg : "Time:", ts.tv_sec, ts.tv_nsec); +#endif +} +EXPORT_SYMBOL(rtc_show_time);
Primary purpose of rtc_show_time is to provide a marker used for post-mortem Battery and Power analysis. These markers occur at major discontinuities of time, and thus optionally add a timestamp to aid the analysis. This function is to be called at a higher level, and were added because of a lack of current kernel logging data. The persistent clock that is used to report Suspended for message is not present on all platforms, and is currently standardized for millisecond precision. An added value to the time report is the ability in post-mortem triage analysis to synchronize kernel activities in MONOTONIC time with user space activities in REALTIME. Feature activated by CONFIG_RTC_SHOW_TIME_<TYPE>, where <TYPE> is None (default, disabled), realtime, boottime or monotonic. Since this is for post mortem field analysis, there is no debugfs or trace facility that can generally be leveraged. analyze_suspend.py for example requires a debug configured kernel, on the other hand these prints can remain in a field product. The purpose for rtc_show_time is not for development debugging. Data collected may be recorded by klogd with a longer logspan than the built-in dmesg buffer, or land in pstore console driver to be collected after a reboot. Signed-off-by: Mark Salyzyn <salyzyn@android.com> v2: - move implementation to kernel timekeeping from rtc_lib files - use rtc_time64_to_tm() instead of rtc_time_to_tm() - use inline in include/linux/rtc.h for !CONFIG_RTC_SHOW_TIME v3: - _correctly_ use rtc_time64_to_tm v4: - introduce CONFIG_RTC_SHOW_TIME_<TYPE> and split off rtc time format printing to a separate patch. --- include/linux/rtc.h | 5 +++ kernel/time/Kconfig | 77 +++++++++++++++++++++++++++++++++++++++++++++ kernel/time/Makefile | 1 + kernel/time/rtc_show_time.c | 29 +++++++++++++++++ 4 files changed, 112 insertions(+) create mode 100644 kernel/time/rtc_show_time.c