Commit 2b283ce
database/sql: fix race when canceling queries immediately
Previously the following could happen, though in practice it would
be rare.
Goroutine 1:
(*Tx).QueryContext begins a query, passing in userContext
Goroutine 2:
(*Tx).awaitDone starts to wait on the context derived from the passed in context
Goroutine 1:
(*Tx).grabConn returns a valid (*driverConn)
The (*driverConn) passes to (*DB).queryConn
Goroutine 3:
userContext is canceled
Goroutine 2:
(*Tx).awaitDone unblocks and calls (*Tx).rollback
(*driverConn).finalClose obtains dc.Mutex
(*driverConn).finalClose sets dc.ci = nil
Goroutine 1:
(*DB).queryConn obtains dc.Mutex in withLock
ctxDriverPrepare accepts dc.ci which is now nil
ctxCriverPrepare panics on the nil ci
The fix for this is to guard the Tx methods with a RWLock
holding it exclusivly when closing the Tx and holding a read lock
when executing a query.
Fixes #18719
Change-Id: I37aa02c37083c9793dabd28f7f934a1c5cbc05ea
Reviewed-on: https://go-review.googlesource.com/35550
Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>1 parent 1cf0818 commit 2b283ce
2 files changed
+147
-35
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1357 | 1357 | | |
1358 | 1358 | | |
1359 | 1359 | | |
1360 | | - | |
1361 | | - | |
1362 | | - | |
1363 | | - | |
1364 | | - | |
1365 | | - | |
1366 | | - | |
1367 | | - | |
1368 | | - | |
1369 | | - | |
| 1360 | + | |
1370 | 1361 | | |
1371 | 1362 | | |
1372 | 1363 | | |
| |||
1388 | 1379 | | |
1389 | 1380 | | |
1390 | 1381 | | |
| 1382 | + | |
| 1383 | + | |
| 1384 | + | |
| 1385 | + | |
| 1386 | + | |
1391 | 1387 | | |
1392 | 1388 | | |
1393 | 1389 | | |
| |||
1413 | 1409 | | |
1414 | 1410 | | |
1415 | 1411 | | |
| 1412 | + | |
| 1413 | + | |
| 1414 | + | |
| 1415 | + | |
| 1416 | + | |
| 1417 | + | |
| 1418 | + | |
| 1419 | + | |
| 1420 | + | |
| 1421 | + | |
| 1422 | + | |
| 1423 | + | |
| 1424 | + | |
| 1425 | + | |
1416 | 1426 | | |
1417 | 1427 | | |
1418 | 1428 | | |
| |||
1424 | 1434 | | |
1425 | 1435 | | |
1426 | 1436 | | |
| 1437 | + | |
| 1438 | + | |
| 1439 | + | |
1427 | 1440 | | |
1428 | 1441 | | |
1429 | 1442 | | |
1430 | 1443 | | |
1431 | 1444 | | |
1432 | 1445 | | |
| 1446 | + | |
| 1447 | + | |
| 1448 | + | |
| 1449 | + | |
1433 | 1450 | | |
| 1451 | + | |
| 1452 | + | |
| 1453 | + | |
| 1454 | + | |
| 1455 | + | |
1434 | 1456 | | |
1435 | 1457 | | |
1436 | 1458 | | |
| 1459 | + | |
| 1460 | + | |
| 1461 | + | |
1437 | 1462 | | |
1438 | 1463 | | |
1439 | 1464 | | |
| |||
1503 | 1528 | | |
1504 | 1529 | | |
1505 | 1530 | | |
| 1531 | + | |
| 1532 | + | |
| 1533 | + | |
1506 | 1534 | | |
1507 | 1535 | | |
1508 | 1536 | | |
| |||
1567 | 1595 | | |
1568 | 1596 | | |
1569 | 1597 | | |
| 1598 | + | |
| 1599 | + | |
| 1600 | + | |
1570 | 1601 | | |
1571 | 1602 | | |
1572 | 1603 | | |
| |||
1618 | 1649 | | |
1619 | 1650 | | |
1620 | 1651 | | |
| 1652 | + | |
| 1653 | + | |
| 1654 | + | |
1621 | 1655 | | |
1622 | 1656 | | |
1623 | 1657 | | |
| |||
1661 | 1695 | | |
1662 | 1696 | | |
1663 | 1697 | | |
| 1698 | + | |
| 1699 | + | |
| 1700 | + | |
1664 | 1701 | | |
1665 | 1702 | | |
1666 | 1703 | | |
| |||
2038 | 2075 | | |
2039 | 2076 | | |
2040 | 2077 | | |
2041 | | - | |
| 2078 | + | |
2042 | 2079 | | |
2043 | 2080 | | |
2044 | 2081 | | |
2045 | 2082 | | |
2046 | 2083 | | |
2047 | 2084 | | |
2048 | | - | |
2049 | | - | |
2050 | | - | |
| 2085 | + | |
| 2086 | + | |
| 2087 | + | |
2051 | 2088 | | |
2052 | | - | |
2053 | | - | |
2054 | | - | |
2055 | | - | |
2056 | | - | |
2057 | | - | |
2058 | | - | |
2059 | | - | |
| 2089 | + | |
| 2090 | + | |
| 2091 | + | |
| 2092 | + | |
2060 | 2093 | | |
2061 | 2094 | | |
2062 | 2095 | | |
| |||
2314 | 2347 | | |
2315 | 2348 | | |
2316 | 2349 | | |
2317 | | - | |
| 2350 | + | |
| 2351 | + | |
| 2352 | + | |
2318 | 2353 | | |
2319 | 2354 | | |
2320 | 2355 | | |
| |||
2328 | 2363 | | |
2329 | 2364 | | |
2330 | 2365 | | |
2331 | | - | |
2332 | | - | |
2333 | | - | |
| 2366 | + | |
2334 | 2367 | | |
2335 | | - | |
| 2368 | + | |
2336 | 2369 | | |
2337 | 2370 | | |
| 2371 | + | |
| 2372 | + | |
| 2373 | + | |
| 2374 | + | |
2338 | 2375 | | |
2339 | 2376 | | |
2340 | 2377 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
14 | 14 | | |
15 | 15 | | |
16 | 16 | | |
| 17 | + | |
17 | 18 | | |
18 | 19 | | |
19 | 20 | | |
| |||
1135 | 1136 | | |
1136 | 1137 | | |
1137 | 1138 | | |
| 1139 | + | |
| 1140 | + | |
| 1141 | + | |
| 1142 | + | |
| 1143 | + | |
| 1144 | + | |
| 1145 | + | |
| 1146 | + | |
| 1147 | + | |
| 1148 | + | |
| 1149 | + | |
| 1150 | + | |
| 1151 | + | |
| 1152 | + | |
| 1153 | + | |
| 1154 | + | |
| 1155 | + | |
| 1156 | + | |
1138 | 1157 | | |
1139 | 1158 | | |
1140 | 1159 | | |
| |||
1147 | 1166 | | |
1148 | 1167 | | |
1149 | 1168 | | |
| 1169 | + | |
1150 | 1170 | | |
1151 | 1171 | | |
1152 | 1172 | | |
1153 | 1173 | | |
1154 | 1174 | | |
1155 | 1175 | | |
1156 | 1176 | | |
1157 | | - | |
| 1177 | + | |
1158 | 1178 | | |
1159 | | - | |
1160 | | - | |
| 1179 | + | |
| 1180 | + | |
1161 | 1181 | | |
1162 | 1182 | | |
1163 | 1183 | | |
| |||
1830 | 1850 | | |
1831 | 1851 | | |
1832 | 1852 | | |
1833 | | - | |
| 1853 | + | |
| 1854 | + | |
| 1855 | + | |
1834 | 1856 | | |
1835 | 1857 | | |
1836 | 1858 | | |
| |||
2576 | 2598 | | |
2577 | 2599 | | |
2578 | 2600 | | |
2579 | | - | |
| 2601 | + | |
2580 | 2602 | | |
2581 | | - | |
2582 | | - | |
| 2603 | + | |
| 2604 | + | |
2583 | 2605 | | |
2584 | 2606 | | |
2585 | 2607 | | |
| |||
2642 | 2664 | | |
2643 | 2665 | | |
2644 | 2666 | | |
2645 | | - | |
| 2667 | + | |
| 2668 | + | |
| 2669 | + | |
| 2670 | + | |
2646 | 2671 | | |
2647 | 2672 | | |
2648 | 2673 | | |
| |||
2655 | 2680 | | |
2656 | 2681 | | |
2657 | 2682 | | |
| 2683 | + | |
| 2684 | + | |
| 2685 | + | |
| 2686 | + | |
| 2687 | + | |
| 2688 | + | |
| 2689 | + | |
| 2690 | + | |
| 2691 | + | |
| 2692 | + | |
| 2693 | + | |
| 2694 | + | |
| 2695 | + | |
| 2696 | + | |
| 2697 | + | |
| 2698 | + | |
| 2699 | + | |
| 2700 | + | |
| 2701 | + | |
| 2702 | + | |
| 2703 | + | |
| 2704 | + | |
| 2705 | + | |
| 2706 | + | |
| 2707 | + | |
| 2708 | + | |
| 2709 | + | |
| 2710 | + | |
| 2711 | + | |
| 2712 | + | |
| 2713 | + | |
| 2714 | + | |
| 2715 | + | |
| 2716 | + | |
| 2717 | + | |
| 2718 | + | |
| 2719 | + | |
| 2720 | + | |
| 2721 | + | |
| 2722 | + | |
| 2723 | + | |
| 2724 | + | |
| 2725 | + | |
| 2726 | + | |
| 2727 | + | |
| 2728 | + | |
| 2729 | + | |
| 2730 | + | |
| 2731 | + | |
| 2732 | + | |
2658 | 2733 | | |
2659 | 2734 | | |
2660 | 2735 | | |
| |||
0 commit comments