summaryrefslogtreecommitdiffstats
path: root/lib/libssl/ssl_versions.c
diff options
context:
space:
mode:
authorjsing <jsing@openbsd.org>2017-05-06 20:37:24 +0000
committerjsing <jsing@openbsd.org>2017-05-06 20:37:24 +0000
commit43a30d3dc540bddabcfa9b4f1a82156efd0c91e4 (patch)
tree51583cc8f5f26a68679923819d55a05432540628 /lib/libssl/ssl_versions.c
parentConvert explicit_bzero() + free() to freezero(). (diff)
downloadwireguard-openbsd-43a30d3dc540bddabcfa9b4f1a82156efd0c91e4.tar.xz
wireguard-openbsd-43a30d3dc540bddabcfa9b4f1a82156efd0c91e4.zip
Provide SSL{,_CTX}_set_{min,max}_proto_version() functions.
Rides minor bump. ok beck@
Diffstat (limited to 'lib/libssl/ssl_versions.c')
-rw-r--r--lib/libssl/ssl_versions.c48
1 files changed, 47 insertions, 1 deletions
diff --git a/lib/libssl/ssl_versions.c b/lib/libssl/ssl_versions.c
index 6e17cdac6c6..240a2498aa8 100644
--- a/lib/libssl/ssl_versions.c
+++ b/lib/libssl/ssl_versions.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ssl_versions.c,v 1.2 2017/05/06 16:18:36 jsing Exp $ */
+/* $OpenBSD: ssl_versions.c,v 1.3 2017/05/06 20:37:25 jsing Exp $ */
/*
* Copyright (c) 2016, 2017 Joel Sing <jsing@openbsd.org>
*
@@ -35,6 +35,52 @@ ssl_clamp_version_range(uint16_t *min_ver, uint16_t *max_ver,
}
int
+ssl_version_set_min(const SSL_METHOD *meth, uint16_t ver, uint16_t max_ver,
+ uint16_t *out_ver)
+{
+ uint16_t min_version, max_version;
+
+ if (ver == 0) {
+ *out_ver = meth->internal->min_version;
+ return 1;
+ }
+
+ min_version = ver;
+ max_version = max_ver;
+
+ if (!ssl_clamp_version_range(&min_version, &max_version,
+ meth->internal->min_version, meth->internal->max_version))
+ return 0;
+
+ *out_ver = min_version;
+
+ return 1;
+}
+
+int
+ssl_version_set_max(const SSL_METHOD *meth, uint16_t ver, uint16_t min_ver,
+ uint16_t *out_ver)
+{
+ uint16_t min_version, max_version;
+
+ if (ver == 0) {
+ *out_ver = meth->internal->max_version;
+ return 1;
+ }
+
+ min_version = min_ver;
+ max_version = ver;
+
+ if (!ssl_clamp_version_range(&min_version, &max_version,
+ meth->internal->min_version, meth->internal->max_version))
+ return 0;
+
+ *out_ver = max_version;
+
+ return 1;
+}
+
+int
ssl_enabled_version_range(SSL *s, uint16_t *min_ver, uint16_t *max_ver)
{
uint16_t min_version, max_version;