summaryrefslogtreecommitdiffstats
path: root/crypto/asn1
diff options
context:
space:
mode:
authorJohn Baldwin <jhb@FreeBSD.org>2022-02-23 17:18:22 -0800
committerMatt Caswell <matt@openssl.org>2022-03-03 13:33:12 +0000
commit0176fc78d090210cd7e231a7c2c4564464509506 (patch)
tree85360e6ebe63834bdc2bef7511ae4385118aed88 /crypto/asn1
parent065442165a3d339a7de469b4cd18a3f902c73443 (diff)
asn1_string_to_time_t: Use timegm on FreeBSD.
FreeBSD does not provide a global timezone variable containing the offset to UTC. Instead, FreeBSD's libc includes a legacy timezone function dating back to Version 7 AT&T UNIX. As a result, asn1_string_to_time_t currently fails to compile on FreeBSD as it subtracts a function from a time_t value: ../crypto/asn1/a_time.c:625:37: error: invalid operands to binary expression ('time_t' (aka 'long') and 'char *(int, int)') timestamp_utc = timestamp_local - timezone; ~~~~~~~~~~~~~~~ ^ ~~~~~~~~ 1 error generated. However, FreeBSD's libc does include a non-standard (but widely available) timegm function which converts a struct tm directly to a UTC time_t value. Use this on FreeBSD instead of mktime. Reviewed-by: Paul Dale <pauli@openssl.org> Reviewed-by: Matt Caswell <matt@openssl.org> (Merged from https://github.com/openssl/openssl/pull/17765)
Diffstat (limited to 'crypto/asn1')
-rw-r--r--crypto/asn1/a_time.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/crypto/asn1/a_time.c b/crypto/asn1/a_time.c
index e9df23af92..4b9a0641fb 100644
--- a/crypto/asn1/a_time.c
+++ b/crypto/asn1/a_time.c
@@ -597,11 +597,17 @@ int ASN1_TIME_compare(const ASN1_TIME *a, const ASN1_TIME *b)
# define timezone _timezone
#endif
+#ifdef __FreeBSD__
+# define USE_TIMEGM
+#endif
+
time_t asn1_string_to_time_t(const char *asn1_string)
{
ASN1_TIME *timestamp_asn1 = NULL;
struct tm *timestamp_tm = NULL;
+#ifndef USE_TIMEGM
time_t timestamp_local;
+#endif
time_t timestamp_utc;
timestamp_asn1 = ASN1_TIME_new();
@@ -619,10 +625,15 @@ time_t asn1_string_to_time_t(const char *asn1_string)
return -1;
}
+#ifdef USE_TIMEGM
+ timestamp_utc = timegm(timestamp_tm);
+ OPENSSL_free(timestamp_tm);
+#else
timestamp_local = mktime(timestamp_tm);
OPENSSL_free(timestamp_tm);
timestamp_utc = timestamp_local - timezone;
+#endif
ASN1_TIME_free(timestamp_asn1);
return timestamp_utc;