summaryrefslogtreecommitdiff
path: root/src/lib/libssl/tls12_lib.c
diff options
context:
space:
mode:
authortb <>2024-04-16 17:46:30 +0000
committertb <>2024-04-16 17:46:30 +0000
commit478a18f6e1ea66b9cf61074c2771d9c04f4d798f (patch)
treeec214c3193a7a2dde770fe26928836b23e1bb051 /src/lib/libssl/tls12_lib.c
parenta2d33edef120713fca38edea57eba33f8e3ba217 (diff)
downloadopenbsd-478a18f6e1ea66b9cf61074c2771d9c04f4d798f.tar.gz
openbsd-478a18f6e1ea66b9cf61074c2771d9c04f4d798f.tar.bz2
openbsd-478a18f6e1ea66b9cf61074c2771d9c04f4d798f.zip
Fix key share negotiation in HRR case
In the ClientHello retrying the handshake after a HelloRetryRequest, the client must send a single key share matching the group selected by the server in the HRR. This is not necessarily the mutually preferred group. Incorrect logic added in ssl_tlsect.c r1.134 would potentially reject such a key share because of that. Instead, add logic to ensure on the server side that there is a single share matching the group we selected in the HRR. Fixes a regress test in p5-IO-Socket-SSL where server is configured with P-521:P-384 and the client with P-256:P-384:P-521. Since the client sends an initial P-256 key share, a HRR is triggered which the faulty logic rejected because it was not the mutually preferred P-384 but rather matching the server-selected P-521. This will need some deduplication in subsequent commits. We may also want to consider honoring the mutual preference and request a key accordingly in the HRR. reported by bluhm, fix suggested by jsing ok beck jsing
Diffstat (limited to 'src/lib/libssl/tls12_lib.c')
0 files changed, 0 insertions, 0 deletions