1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/sys/timex/timex.c
Lucas Jenss 8e758d7463 sys: Misc errors that occur w/ ENABLE_DEBUG fixed
I enabled debug output in all files to poke around
and there were some errors (seemingly) due to code
changes that were not tested with debug enabled. This
commits tries to fix these issues.
2015-01-30 01:36:28 +01:00

110 lines
2.4 KiB
C

/**
* Timex implementation
*
* Copyright (C) 2009, 2010, 2013, 2014 Freie Universitaet Berlin (FUB).
* Copyright (C) 2013, 2014 INRIA.
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
/**
* @file
* @author Kaspar Schleiser <kaspar@schleiser.de>
* @author Oliver Hahm <oliver.hahm@inria.fr>
* @author Christian Mehlis <mehlis@inf.fu-berlin.de>
* @author Daniel Jentsch <d.jentsch@fu-berlin.de>
*
*/
#include <stdio.h>
#include <inttypes.h>
#define ENABLE_DEBUG (0)
#include "debug.h"
#include "timex.h"
timex_t timex_add(const timex_t a, const timex_t b)
{
#if ENABLE_DEBUG
if (!timex_isnormalized(&a) || !timex_isnormalized(&b)) {
puts("timex_add on denormalized value");
}
#endif
timex_t result;
result.seconds = a.seconds + b.seconds;
result.microseconds = a.microseconds + b.microseconds;
if (result.microseconds > SEC_IN_USEC) {
result.microseconds -= SEC_IN_USEC;
result.seconds++;
}
return result;
}
timex_t timex_set(uint32_t seconds, uint32_t microseconds)
{
timex_t result;
result.seconds = seconds;
result.microseconds = microseconds;
#if ENABLE_DEBUG
if (!timex_isnormalized(&result)) {
puts("timex_set on denormalized value");
}
#endif
return result;
}
timex_t timex_sub(const timex_t a, const timex_t b)
{
#if ENABLE_DEBUG
if (!timex_isnormalized(&a) || !timex_isnormalized(&b)) {
puts("timex_sub on denormalized value");
}
#endif
timex_t result;
if (a.microseconds >= b.microseconds) {
result.seconds = a.seconds - b.seconds;
result.microseconds = a.microseconds - b.microseconds;
}
else {
result.seconds = a.seconds - b.seconds - 1;
result.microseconds = a.microseconds + SEC_IN_USEC - b.microseconds;
}
return result;
}
int timex_cmp(const timex_t a, const timex_t b)
{
#if ENABLE_DEBUG
if (!timex_isnormalized(&a) || !timex_isnormalized(&b)) {
puts("timex_cmp on denormalized value");
}
#endif
if (a.seconds < b.seconds) {
return -1;
}
if (a.seconds == b.seconds) {
if (a.microseconds < b.microseconds) {
return -1;
}
if (a.microseconds == b.microseconds) {
return 0;
}
}
return 1;
}