diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/lib/libssl/ssl_tlsext.c | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/src/lib/libssl/ssl_tlsext.c b/src/lib/libssl/ssl_tlsext.c index 835c413478..d43ebc6775 100644 --- a/src/lib/libssl/ssl_tlsext.c +++ b/src/lib/libssl/ssl_tlsext.c | |||
| @@ -1,4 +1,4 @@ | |||
| 1 | /* $OpenBSD: ssl_tlsext.c,v 1.17 2017/09/25 18:02:27 jsing Exp $ */ | 1 | /* $OpenBSD: ssl_tlsext.c,v 1.18 2017/11/28 16:46:14 jsing Exp $ */ |
| 2 | /* | 2 | /* |
| 3 | * Copyright (c) 2016, 2017 Joel Sing <jsing@openbsd.org> | 3 | * Copyright (c) 2016, 2017 Joel Sing <jsing@openbsd.org> |
| 4 | * Copyright (c) 2017 Doug Hogan <doug@openbsd.org> | 4 | * Copyright (c) 2017 Doug Hogan <doug@openbsd.org> |
| @@ -1296,6 +1296,7 @@ tlsext_clienthello_build(SSL *s, CBB *cbb) | |||
| 1296 | { | 1296 | { |
| 1297 | CBB extensions, extension_data; | 1297 | CBB extensions, extension_data; |
| 1298 | struct tls_extension *tlsext; | 1298 | struct tls_extension *tlsext; |
| 1299 | int extensions_present = 0; | ||
| 1299 | size_t i; | 1300 | size_t i; |
| 1300 | 1301 | ||
| 1301 | if (!CBB_add_u16_length_prefixed(cbb, &extensions)) | 1302 | if (!CBB_add_u16_length_prefixed(cbb, &extensions)) |
| @@ -1313,8 +1314,13 @@ tlsext_clienthello_build(SSL *s, CBB *cbb) | |||
| 1313 | return 0; | 1314 | return 0; |
| 1314 | if (!tls_extensions[i].clienthello_build(s, &extension_data)) | 1315 | if (!tls_extensions[i].clienthello_build(s, &extension_data)) |
| 1315 | return 0; | 1316 | return 0; |
| 1317 | |||
| 1318 | extensions_present = 1; | ||
| 1316 | } | 1319 | } |
| 1317 | 1320 | ||
| 1321 | if (!extensions_present) | ||
| 1322 | CBB_discard_child(cbb); | ||
| 1323 | |||
| 1318 | if (!CBB_flush(cbb)) | 1324 | if (!CBB_flush(cbb)) |
| 1319 | return 0; | 1325 | return 0; |
| 1320 | 1326 | ||
| @@ -1351,6 +1357,7 @@ tlsext_serverhello_build(SSL *s, CBB *cbb) | |||
| 1351 | { | 1357 | { |
| 1352 | CBB extensions, extension_data; | 1358 | CBB extensions, extension_data; |
| 1353 | struct tls_extension *tlsext; | 1359 | struct tls_extension *tlsext; |
| 1360 | int extensions_present = 0; | ||
| 1354 | size_t i; | 1361 | size_t i; |
| 1355 | 1362 | ||
| 1356 | if (!CBB_add_u16_length_prefixed(cbb, &extensions)) | 1363 | if (!CBB_add_u16_length_prefixed(cbb, &extensions)) |
| @@ -1368,8 +1375,13 @@ tlsext_serverhello_build(SSL *s, CBB *cbb) | |||
| 1368 | return 0; | 1375 | return 0; |
| 1369 | if (!tlsext->serverhello_build(s, &extension_data)) | 1376 | if (!tlsext->serverhello_build(s, &extension_data)) |
| 1370 | return 0; | 1377 | return 0; |
| 1378 | |||
| 1379 | extensions_present = 1; | ||
| 1371 | } | 1380 | } |
| 1372 | 1381 | ||
| 1382 | if (!extensions_present) | ||
| 1383 | CBB_discard_child(cbb); | ||
| 1384 | |||
| 1373 | if (!CBB_flush(cbb)) | 1385 | if (!CBB_flush(cbb)) |
| 1374 | return 0; | 1386 | return 0; |
| 1375 | 1387 | ||
