mirror of
https://github.com/refraction-networking/utls.git
synced 2025-04-03 20:17:36 +03:00
crypto/tls: don't hold lock when closing underlying net.Conn.
There's no need to hold the handshake lock across this call and it can lead to deadlocks if the net.Conn calls back into the tls.Conn. Fixes #18426. Change-Id: Ib1b2813cce385949d970f8ad2e52cfbd1390e624 Reviewed-on: https://go-review.googlesource.com/36561 Run-TryBot: Adam Langley <agl@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
This commit is contained in:
parent
14c17c5cf0
commit
0fc02e2b6f
2 changed files with 32 additions and 1 deletions
31
conn_test.go
31
conn_test.go
|
@ -241,3 +241,34 @@ func TestDynamicRecordSizingWithAEAD(t *testing.T) {
|
|||
config.CipherSuites = []uint16{TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256}
|
||||
runDynamicRecordSizingTest(t, config)
|
||||
}
|
||||
|
||||
// hairpinConn is a net.Conn that makes a “hairpin” call when closed, back into
|
||||
// the tls.Conn which is calling it.
|
||||
type hairpinConn struct {
|
||||
net.Conn
|
||||
tlsConn *Conn
|
||||
}
|
||||
|
||||
func (conn *hairpinConn) Close() error {
|
||||
conn.tlsConn.ConnectionState()
|
||||
return nil
|
||||
}
|
||||
|
||||
func TestHairpinInClose(t *testing.T) {
|
||||
// This tests that the underlying net.Conn can call back into the
|
||||
// tls.Conn when being closed without deadlocking.
|
||||
client, server := net.Pipe()
|
||||
defer server.Close()
|
||||
defer client.Close()
|
||||
|
||||
conn := &hairpinConn{client, nil}
|
||||
tlsConn := Server(conn, &Config{
|
||||
GetCertificate: func(*ClientHelloInfo) (*Certificate, error) {
|
||||
panic("unreachable")
|
||||
},
|
||||
})
|
||||
conn.tlsConn = tlsConn
|
||||
|
||||
// This call should not deadlock.
|
||||
tlsConn.Close()
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue