3cbbde
diff --git a/parseconf.c b/parseconf.c
3cbbde
index a2c715b..33a1349 100644
3cbbde
--- a/parseconf.c
3cbbde
+++ b/parseconf.c
3cbbde
@@ -85,6 +85,8 @@ parseconf_bool_array[] =
3cbbde
   { "ssl_sslv2", &tunable_sslv2 },
3cbbde
   { "ssl_sslv3", &tunable_sslv3 },
3cbbde
   { "ssl_tlsv1", &tunable_tlsv1 },
3cbbde
+  { "ssl_tlsv1_1", &tunable_tlsv1_1 },
3cbbde
+  { "ssl_tlsv1_2", &tunable_tlsv1_2 },
3cbbde
   { "tilde_user_enable", &tunable_tilde_user_enable },
3cbbde
   { "force_anon_logins_ssl", &tunable_force_anon_logins_ssl },
3cbbde
   { "force_anon_data_ssl", &tunable_force_anon_data_ssl },
3cbbde
diff --git a/ssl.c b/ssl.c
3cbbde
index da23f87..94c2b6b 100644
3cbbde
--- a/ssl.c
3cbbde
+++ b/ssl.c
3cbbde
@@ -135,6 +135,14 @@ ssl_init(struct vsf_session* p_sess)
3cbbde
     {
3cbbde
       options |= SSL_OP_NO_TLSv1;
3cbbde
     }
3cbbde
+    if (!tunable_tlsv1_1)
3cbbde
+    {
3cbbde
+      options |= SSL_OP_NO_TLSv1_1;
3cbbde
+    }
3cbbde
+    if (!tunable_tlsv1_2)
3cbbde
+    {
3cbbde
+      options |= SSL_OP_NO_TLSv1_2;
3cbbde
+    }
3cbbde
     SSL_CTX_set_options(p_ctx, options);
3cbbde
     if (tunable_rsa_cert_file)
3cbbde
     {
3cbbde
diff --git a/tunables.c b/tunables.c
3cbbde
index 742284e..08d5490 100644
3cbbde
--- a/tunables.c
3cbbde
+++ b/tunables.c
3cbbde
@@ -66,6 +66,8 @@ int tunable_force_local_data_ssl;
3cbbde
 int tunable_sslv2;
3cbbde
 int tunable_sslv3;
3cbbde
 int tunable_tlsv1;
3cbbde
+int tunable_tlsv1_1;
3cbbde
+int tunable_tlsv1_2;
3cbbde
 int tunable_tilde_user_enable;
3cbbde
 int tunable_force_anon_logins_ssl;
3cbbde
 int tunable_force_anon_data_ssl;
3cbbde
@@ -209,7 +211,9 @@ tunables_load_defaults()
3cbbde
   tunable_force_local_data_ssl = 1;
3cbbde
   tunable_sslv2 = 0;
3cbbde
   tunable_sslv3 = 0;
3cbbde
-  tunable_tlsv1 = 1;
3cbbde
+  tunable_tlsv1 = 0;
3cbbde
+  tunable_tlsv1_1 = 0;
3cbbde
+  tunable_tlsv1_2 = 1;
3cbbde
   tunable_tilde_user_enable = 0;
3cbbde
   tunable_force_anon_logins_ssl = 0;
3cbbde
   tunable_force_anon_data_ssl = 0;
3cbbde
diff --git a/tunables.h b/tunables.h
3cbbde
index 3e2d40c..a466427 100644
3cbbde
--- a/tunables.h
3cbbde
+++ b/tunables.h
3cbbde
@@ -67,6 +67,8 @@ extern int tunable_force_local_data_ssl;      /* Require local data uses SSL */
3cbbde
 extern int tunable_sslv2;                     /* Allow SSLv2 */
3cbbde
 extern int tunable_sslv3;                     /* Allow SSLv3 */
3cbbde
 extern int tunable_tlsv1;                     /* Allow TLSv1 */
3cbbde
+extern int tunable_tlsv1_1;                   /* Allow TLSv1.1 */
3cbbde
+extern int tunable_tlsv1_2;                   /* Allow TLSv1.2 */
3cbbde
 extern int tunable_tilde_user_enable;         /* Support e.g. ~chris */
3cbbde
 extern int tunable_force_anon_logins_ssl;     /* Require anon logins use SSL */
3cbbde
 extern int tunable_force_anon_data_ssl;       /* Require anon data uses SSL */
3cbbde
diff --git a/vsftpd.conf.5 b/vsftpd.conf.5
3cbbde
index cf1ae34..6f36b1b 100644
3cbbde
--- a/vsftpd.conf.5
3cbbde
+++ b/vsftpd.conf.5
3cbbde
@@ -506,7 +506,7 @@ Default: YES
3cbbde
 Only applies if
3cbbde
 .BR ssl_enable
3cbbde
 is activated. If enabled, this option will permit SSL v2 protocol connections.
3cbbde
-TLS v1 connections are preferred.
3cbbde
+TLS v1.2 connections are preferred.
3cbbde
 
3cbbde
 Default: NO
3cbbde
 .TP
3cbbde
@@ -514,7 +514,7 @@ Default: NO
3cbbde
 Only applies if
3cbbde
 .BR ssl_enable
3cbbde
 is activated. If enabled, this option will permit SSL v3 protocol connections.
3cbbde
-TLS v1 connections are preferred.
3cbbde
+TLS v1.2 connections are preferred.
3cbbde
 
3cbbde
 Default: NO
3cbbde
 .TP
3cbbde
@@ -522,7 +522,23 @@ Default: NO
3cbbde
 Only applies if
3cbbde
 .BR ssl_enable
3cbbde
 is activated. If enabled, this option will permit TLS v1 protocol connections.
3cbbde
-TLS v1 connections are preferred.
3cbbde
+TLS v1.2 connections are preferred.
3cbbde
+
3cbbde
+Default: NO
3cbbde
+.TP
3cbbde
+.B ssl_tlsv1_1
3cbbde
+Only applies if
3cbbde
+.BR ssl_enable
3cbbde
+is activated. If enabled, this option will permit TLS v1.1 protocol connections.
3cbbde
+TLS v1.2 connections are preferred.
3cbbde
+
3cbbde
+Default: NO
3cbbde
+.TP
3cbbde
+.B ssl_tlsv1_2
3cbbde
+Only applies if
3cbbde
+.BR ssl_enable
3cbbde
+is activated. If enabled, this option will permit TLS v1.2 protocol connections.
3cbbde
+TLS v1.2 connections are preferred.
3cbbde
 
3cbbde
 Default: YES
3cbbde
 .TP