diff options
author | Harald Welte <laforge@gnumonks.org> | 2012-04-08 16:59:24 +0200 |
---|---|---|
committer | Harald Welte <laforge@gnumonks.org> | 2012-04-08 16:59:24 +0200 |
commit | 9c3dc90d16a40789081c84e46620f4d66689fec1 (patch) | |
tree | 69fba13dafd13f1429b8539cba097ea18d2beb10 /openbsc/src/libmsc | |
parent | a334c296e02852880148abf92abf12c63ed49b3b (diff) |
introduce HAVE_TM_GMTOFF_IN_TM
Not all architectures have the tm.tm_gmtoff member. This fixes cygwin
builds.
Diffstat (limited to 'openbsc/src/libmsc')
-rw-r--r-- | openbsc/src/libmsc/gsm_04_08.c | 7 | ||||
-rw-r--r-- | openbsc/src/libmsc/gsm_04_11.c | 9 |
2 files changed, 16 insertions, 0 deletions
diff --git a/openbsc/src/libmsc/gsm_04_08.c b/openbsc/src/libmsc/gsm_04_08.c index 20a2cc502..e596b210d 100644 --- a/openbsc/src/libmsc/gsm_04_08.c +++ b/openbsc/src/libmsc/gsm_04_08.c @@ -29,6 +29,8 @@ #include <time.h> #include <netinet/in.h> +#include "bscconfig.h" + #include <openbsc/auth.h> #include <openbsc/db.h> #include <openbsc/debug.h> @@ -734,7 +736,12 @@ int gsm48_tx_mm_info(struct gsm_subscriber_connection *conn) /* Need to get GSM offset and convert into 15 min units */ /* This probably breaks if gmtoff returns a value not evenly divisible by 15? */ local_time = localtime(&cur_t); +#ifdef HAVE_TM_GMTOFF_IN_TM tzunits = (local_time->tm_gmtoff/60)/15; +#else +#warning find a portable way to obtain the timezone offset + tzunits = 0; +#endif if (tzunits < 0) { tzunits = tzunits/-1; ptr8[7] = bcdify(tzunits); diff --git a/openbsc/src/libmsc/gsm_04_11.c b/openbsc/src/libmsc/gsm_04_11.c index ee7f5772c..76c37208b 100644 --- a/openbsc/src/libmsc/gsm_04_11.c +++ b/openbsc/src/libmsc/gsm_04_11.c @@ -32,6 +32,8 @@ #include <time.h> #include <netinet/in.h> +#include "bscconfig.h" + #include <osmocom/core/msgb.h> #include <osmocom/gsm/tlv.h> #include <openbsc/debug.h> @@ -279,7 +281,12 @@ static void gsm340_gen_scts(uint8_t *scts, time_t time) *scts++ = bcdify(tm->tm_hour); *scts++ = bcdify(tm->tm_min); *scts++ = bcdify(tm->tm_sec); +#ifdef HAVE_TM_GMTOFF_IN_TM *scts++ = bcdify(tm->tm_gmtoff/(60*15)); +#else +#warning find a portable way to obtain timezone offset + *scts++ = 0; +#endif } /* Decode 03.40 TP-SCTS (into utc/gmt timestamp) */ @@ -300,7 +307,9 @@ static time_t gsm340_scts(uint8_t *scts) tm.tm_sec = unbcdify(*scts++); /* according to gsm 03.40 time zone is "expressed in quarters of an hour" */ +#ifdef HAVE_TM_GMTOFF_IN_TM tm.tm_gmtoff = unbcdify(*scts++) * 15*60; +#endif return mktime(&tm); } |