From 9e9734dac9cd98dbef3adb4e1d879e86868bf076 Mon Sep 17 00:00:00 2001 From: Uladzimir Pylinski Date: Fri, 27 Mar 2015 13:18:08 +0000 Subject: RTC. Improved function rtcConvertDateTimeToStructTm(). Now it can return milliseconds by optional pointer argument. git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@7819 35acf78f-673a-0410-8e92-d51de3d6d3f4 --- os/hal/src/rtc.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) (limited to 'os/hal/src/rtc.c') diff --git a/os/hal/src/rtc.c b/os/hal/src/rtc.c index a60ddd6a0..5459b3b85 100644 --- a/os/hal/src/rtc.c +++ b/os/hal/src/rtc.c @@ -213,11 +213,13 @@ void rtcSetCallback(RTCDriver *rtcp, rtccb_t callback) { * * @param[in] timespec pointer to a @p RTCDateTime structure * @param[out] timp pointer to a broken-down time structure + * @param[out] tv_msec pointer to milliseconds value or @p NULL * * @api */ void rtcConvertDateTimeToStructTm(const RTCDateTime *timespec, - struct tm *timp) { + struct tm *timp, + uint32_t *tv_msec) { int tmp; timp->tm_year = (int)timespec->year + (1980 - 1900); @@ -231,6 +233,10 @@ void rtcConvertDateTimeToStructTm(const RTCDateTime *timespec, timp->tm_min = (tmp % 3600) / 60; tmp -= timp->tm_min * 60; timp->tm_hour = tmp / 3600; + + if (NULL != tv_msec) { + *tv_msec = (uint32_t)timespec->millisecond % 1000; + } } /** -- cgit v1.2.3