diff options
Diffstat (limited to 'src/lib/libssl')
-rw-r--r-- | src/lib/libssl/ssl_tlsext.c | 3 | ||||
-rw-r--r-- | src/lib/libssl/tls13_server.c | 10 |
2 files changed, 4 insertions, 9 deletions
diff --git a/src/lib/libssl/ssl_tlsext.c b/src/lib/libssl/ssl_tlsext.c index 9209597601..12ede899e8 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.156 2025/06/07 10:23:21 tb Exp $ */ | 1 | /* $OpenBSD: ssl_tlsext.c,v 1.157 2025/10/16 14:42:21 jsing Exp $ */ |
2 | /* | 2 | /* |
3 | * Copyright (c) 2016, 2017, 2019 Joel Sing <jsing@openbsd.org> | 3 | * Copyright (c) 2016, 2017, 2019 Joel Sing <jsing@openbsd.org> |
4 | * Copyright (c) 2017 Doug Hogan <doug@openbsd.org> | 4 | * Copyright (c) 2017 Doug Hogan <doug@openbsd.org> |
@@ -1554,6 +1554,7 @@ tlsext_keyshare_server_process(SSL *s, uint16_t msg_type, CBS *cbs, int *alert) | |||
1554 | for (j = 0; j < server_groups_len; j++) { | 1554 | for (j = 0; j < server_groups_len; j++) { |
1555 | if (server_groups[j] == client_groups[i]) { | 1555 | if (server_groups[j] == client_groups[i]) { |
1556 | client_preferred_group = client_groups[i]; | 1556 | client_preferred_group = client_groups[i]; |
1557 | s->s3->hs.tls13.server_group = client_preferred_group; | ||
1557 | preferred_group_found = 1; | 1558 | preferred_group_found = 1; |
1558 | break; | 1559 | break; |
1559 | } | 1560 | } |
diff --git a/src/lib/libssl/tls13_server.c b/src/lib/libssl/tls13_server.c index 63b7d92093..f852e08a52 100644 --- a/src/lib/libssl/tls13_server.c +++ b/src/lib/libssl/tls13_server.c | |||
@@ -1,4 +1,4 @@ | |||
1 | /* $OpenBSD: tls13_server.c,v 1.109 2024/07/22 14:47:15 jsing Exp $ */ | 1 | /* $OpenBSD: tls13_server.c,v 1.110 2025/10/16 14:42:21 jsing Exp $ */ |
2 | /* | 2 | /* |
3 | * Copyright (c) 2019, 2020 Joel Sing <jsing@openbsd.org> | 3 | * Copyright (c) 2019, 2020 Joel Sing <jsing@openbsd.org> |
4 | * Copyright (c) 2020 Bob Beck <beck@openbsd.org> | 4 | * Copyright (c) 2020 Bob Beck <beck@openbsd.org> |
@@ -437,8 +437,6 @@ tls13_server_engage_record_protection(struct tls13_ctx *ctx) | |||
437 | int | 437 | int |
438 | tls13_server_hello_retry_request_send(struct tls13_ctx *ctx, CBB *cbb) | 438 | tls13_server_hello_retry_request_send(struct tls13_ctx *ctx, CBB *cbb) |
439 | { | 439 | { |
440 | int nid; | ||
441 | |||
442 | ctx->hs->tls13.hrr = 1; | 440 | ctx->hs->tls13.hrr = 1; |
443 | 441 | ||
444 | if (!tls13_synthetic_handshake_message(ctx)) | 442 | if (!tls13_synthetic_handshake_message(ctx)) |
@@ -446,9 +444,7 @@ tls13_server_hello_retry_request_send(struct tls13_ctx *ctx, CBB *cbb) | |||
446 | 444 | ||
447 | if (ctx->hs->key_share != NULL) | 445 | if (ctx->hs->key_share != NULL) |
448 | return 0; | 446 | return 0; |
449 | if (!tls1_get_supported_group(ctx->ssl, &nid)) | 447 | if (ctx->hs->tls13.server_group == 0) |
450 | return 0; | ||
451 | if (!tls1_ec_nid2group_id(nid, &ctx->hs->tls13.server_group)) | ||
452 | return 0; | 448 | return 0; |
453 | 449 | ||
454 | if (!tls13_server_hello_build(ctx, cbb, 1)) | 450 | if (!tls13_server_hello_build(ctx, cbb, 1)) |
@@ -511,8 +507,6 @@ tls13_server_hello_send(struct tls13_ctx *ctx, CBB *cbb) | |||
511 | if (!tls13_servername_process(ctx)) | 507 | if (!tls13_servername_process(ctx)) |
512 | return 0; | 508 | return 0; |
513 | 509 | ||
514 | ctx->hs->tls13.server_group = 0; | ||
515 | |||
516 | if (!tls13_server_hello_build(ctx, cbb, 0)) | 510 | if (!tls13_server_hello_build(ctx, cbb, 0)) |
517 | return 0; | 511 | return 0; |
518 | 512 | ||