]> Cypherpunks repositories - gostls13.git/commit
database/sql: prevent race in driver by locking dc in Next
authorDaniel Theophanes <kardianos@gmail.com>
Sat, 23 Sep 2017 22:30:46 +0000 (15:30 -0700)
committerDaniel Theophanes <kardianos@gmail.com>
Fri, 13 Oct 2017 18:11:41 +0000 (18:11 +0000)
commit897080d5cbb1793f8ad3ef5fb7c6fafba2e97d42
tree72ae4bc21424894d2b6cada8be141d7e48856972
parent350b74bc4b9f37ba29ef02c2f89d687ae8563a05
database/sql: prevent race in driver by locking dc in Next

Database drivers should be called from a single goroutine to ease
driver's design. If a driver chooses to handle context
cancels internally it may do so.

The sql package violated this agreement when calling Next or
NextResultSet. It was possible for a concurrent rollback
triggered from a context cancel to call a Tx.Rollback (which
takes a driver connection lock) while a Rows.Next is in progress
(which does not tack the driver connection lock).

The current internal design of the sql package is each call takes
roughly two locks: a closemu lock which prevents an disposing of
internal resources (assigning nil or removing from lists)
and a driver connection lock that prevents calling driver code from
multiple goroutines.

Fixes #21117

Change-Id: Ie340dc752a503089c27f57ffd43e191534829360
Reviewed-on: https://go-review.googlesource.com/65731
Reviewed-by: Ian Lance Taylor <iant@golang.org>
src/database/sql/fakedb_test.go
src/database/sql/sql.go
src/database/sql/sql_test.go