From 1a1094a3b32f221d41a1740277ffaf766c62c15c Mon Sep 17 00:00:00 2001 From: Paul Ramirez Date: Fri, 18 Oct 2024 00:58:02 +0000 Subject: Change format and units of logs in LegacyResampler Fixed the logging format of std::chrono::duration types because C++20 adds their stream operator, and units were duplicated. Likewise, changed from nanoseconds to milliseconds given that it is easier to reason the logging messages in millis. Bug: 297226446 Flag: EXEMPT refactor Test: TEST=libinput_tests; m $TEST && $ANDROID_HOST_OUT/nativetest64/$TEST/$TEST Change-Id: Idd06e4fbad4dd02a3bf28957004b4bdb00988325 --- libs/input/Resampler.cpp | 43 +++++++++++++++++++++++++++++++++---------- 1 file changed, 33 insertions(+), 10 deletions(-) (limited to 'libs/input/Resampler.cpp') diff --git a/libs/input/Resampler.cpp b/libs/input/Resampler.cpp index 884b66e482..056db093d1 100644 --- a/libs/input/Resampler.cpp +++ b/libs/input/Resampler.cpp @@ -18,6 +18,7 @@ #include #include +#include #include #include @@ -37,6 +38,11 @@ const bool IS_DEBUGGABLE_BUILD = true; #endif +/** + * Log debug messages about timestamp and coordinates of event resampling. + * Enable this via "adb shell setprop log.tag.LegacyResamplerResampling DEBUG" + * (requires restart) + */ bool debugResampling() { if (!IS_DEBUGGABLE_BUILD) { static const bool DEBUG_TRANSPORT_RESAMPLING = @@ -164,7 +170,9 @@ bool LegacyResampler::canInterpolate(const InputMessage& message) const { const nanoseconds delta = futureSample.eventTime - pastSample.eventTime; if (delta < RESAMPLE_MIN_DELTA) { - LOG_IF(INFO, debugResampling()) << "Not resampled. Delta is too small: " << delta << "ns."; + LOG_IF(INFO, debugResampling()) + << "Not resampled. Delta is too small: " << std::setprecision(3) + << std::chrono::duration{delta}.count() << "ms"; return false; } return true; @@ -183,7 +191,7 @@ std::optional LegacyResampler::attemptInterpolation( const nanoseconds delta = nanoseconds{futureSample.eventTime} - pastSample.eventTime; const float alpha = - std::chrono::duration(resampleTime - pastSample.eventTime) / delta; + std::chrono::duration(resampleTime - pastSample.eventTime) / delta; PointerMap resampledPointerMap; for (const Pointer& pointer : pastSample.pointerMap) { @@ -213,10 +221,14 @@ bool LegacyResampler::canExtrapolate() const { const nanoseconds delta = presentSample.eventTime - pastSample.eventTime; if (delta < RESAMPLE_MIN_DELTA) { - LOG_IF(INFO, debugResampling()) << "Not resampled. Delta is too small: " << delta << "ns."; + LOG_IF(INFO, debugResampling()) + << "Not resampled. Delta is too small: " << std::setprecision(3) + << std::chrono::duration{delta}.count() << "ms"; return false; } else if (delta > RESAMPLE_MAX_DELTA) { - LOG_IF(INFO, debugResampling()) << "Not resampled. Delta is too large: " << delta << "ns."; + LOG_IF(INFO, debugResampling()) + << "Not resampled. Delta is too large: " << std::setprecision(3) + << std::chrono::duration{delta}.count() << "ms"; return false; } return true; @@ -242,11 +254,16 @@ std::optional LegacyResampler::attemptExtrapolation( (resampleTime > farthestPrediction) ? (farthestPrediction) : (resampleTime); LOG_IF(INFO, debugResampling() && newResampleTime == farthestPrediction) << "Resample time is too far in the future. Adjusting prediction from " - << (resampleTime - presentSample.eventTime) << " to " - << (farthestPrediction - presentSample.eventTime) << "ns."; + << std::setprecision(3) + << std::chrono::duration{resampleTime - presentSample.eventTime} + .count() + << "ms to " + << std::chrono::duration{farthestPrediction - + presentSample.eventTime} + .count() + << "ms"; const float alpha = - std::chrono::duration(newResampleTime - pastSample.eventTime) / - delta; + std::chrono::duration(newResampleTime - pastSample.eventTime) / delta; PointerMap resampledPointerMap; for (const Pointer& pointer : presentSample.pointerMap) { @@ -321,8 +338,14 @@ void LegacyResampler::overwriteOldPointers(MotionEvent& motionEvent, size_t samp mPreviousPrediction->eventTime) { LOG_IF(INFO, debugResampling()) << "Motion event sample older than predicted sample. Overwriting event time from " - << motionEvent.getHistoricalEventTime(sampleIndex) << "ns to " - << mPreviousPrediction->eventTime.count() << "ns."; + << std::setprecision(3) + << std::chrono::duration{nanoseconds{motionEvent.getHistoricalEventTime( + sampleIndex)}} + .count() + << "ms to " + << std::chrono::duration{mPreviousPrediction->eventTime}.count() + << "ms"; for (size_t pointerIndex = 0; pointerIndex < motionEvent.getPointerCount(); ++pointerIndex) { const std::optional previousPointer = mPreviousPrediction->pointerMap.find( -- cgit v1.2.3-59-g8ed1b