mirror of
https://github.com/bitcoin/bitcoin.git
synced 2026-01-20 07:09:15 +01:00
Merge bitcoin/bitcoin#32466: threading: drop CSemaphore in favor of c++20 std::counting_semaphore
6f7052a7b9threading: semaphore: move CountingSemaphoreGrant to its own header (Cory Fields)fd15469892threading: semaphore: remove temporary convenience types (Cory Fields)1f89e2a49ascripted-diff: threading: semaphore: use direct types rather than the temporary convenience ones (Cory Fields)f21365c4fcthreading: replace CountingSemaphore with std::counting_semaphore (Cory Fields)1acacfbad7threading: make CountingSemaphore/CountingSemaphoreGrant template types (Cory Fields)e6ce5f9e78scripted-diff: rename CSemaphore and CSemaphoreGrant (Cory Fields)793166d381wallet: change the write semaphore to a BinarySemaphore (Cory Fields)6790ad27f1scripted-diff: rename CSemaphoreGrant and CSemaphore for net (Cory Fields)d870bc9451threading: add temporary semaphore aliases (Cory Fields)7b816c4e00threading: rename CSemaphore methods to match std::semaphore (Cory Fields) Pull request description: This is relatively simple, but done in a bunch of commits to enable scripted diffs. I wanted to add a semaphore in a branch I've been working on, but it was unclear if I should use `std::counting_semaphore` or stick with our old `CSemaphore`. I couldn't decide, so I just decided to remove all doubt and get rid of ours :) This replaces our old `CSemaphore` with `std::counting_semaphore` everywhere we used it. `CSemaphoreGrant` is still there as an RAII wrapper, but is now called `CountingSemaphoreGrant` and `BinarySemaphoreGrant` to match. Those have been moved out of `sync.h` to their own file. ACKs for top commit: purpleKarrot: ACK6f7052a7b9achow101: ACK6f7052a7b9TheCharlatan: ACK6f7052a7b9hebasto: ACK6f7052a7b9, I have reviewed the code and it looks OK. Tree-SHA512: 5975d13aa21739174e3a22c544620ae3f36345f172b51612346d3b7baf0a07c39ef6fd54f647c87878c21a67951b347a5d4a5f90e897f3f6c0db360a3779d0df
This commit is contained in:
20
src/net.cpp
20
src/net.cpp
@@ -1886,7 +1886,7 @@ bool CConnman::AddConnection(const std::string& address, ConnectionType conn_typ
|
||||
if (max_connections != std::nullopt && existing_connections >= max_connections) return false;
|
||||
|
||||
// Max total outbound connections already exist
|
||||
CSemaphoreGrant grant(*semOutbound, true);
|
||||
CountingSemaphoreGrant<> grant(*semOutbound, true);
|
||||
if (!grant) return false;
|
||||
|
||||
OpenNetworkConnection(CAddress(), false, std::move(grant), address.c_str(), conn_type, /*use_v2transport=*/use_v2transport);
|
||||
@@ -2402,7 +2402,7 @@ void CConnman::ProcessAddrFetch()
|
||||
// peer doesn't support it or immediately disconnects us for another reason.
|
||||
const bool use_v2transport(GetLocalServices() & NODE_P2P_V2);
|
||||
CAddress addr;
|
||||
CSemaphoreGrant grant(*semOutbound, /*fTry=*/true);
|
||||
CountingSemaphoreGrant<> grant(*semOutbound, /*fTry=*/true);
|
||||
if (grant) {
|
||||
OpenNetworkConnection(addr, false, std::move(grant), strDest.c_str(), ConnectionType::ADDR_FETCH, use_v2transport);
|
||||
}
|
||||
@@ -2576,7 +2576,7 @@ void CConnman::ThreadOpenConnections(const std::vector<std::string> connect, std
|
||||
|
||||
PerformReconnections();
|
||||
|
||||
CSemaphoreGrant grant(*semOutbound);
|
||||
CountingSemaphoreGrant<> grant(*semOutbound);
|
||||
if (interruptNet)
|
||||
return;
|
||||
|
||||
@@ -2954,7 +2954,7 @@ void CConnman::ThreadOpenAddedConnections()
|
||||
AssertLockNotHeld(m_reconnections_mutex);
|
||||
while (true)
|
||||
{
|
||||
CSemaphoreGrant grant(*semAddnode);
|
||||
CountingSemaphoreGrant<> grant(*semAddnode);
|
||||
std::vector<AddedNodeInfo> vInfo = GetAddedNodeInfo(/*include_connected=*/false);
|
||||
bool tried = false;
|
||||
for (const AddedNodeInfo& info : vInfo) {
|
||||
@@ -2967,7 +2967,7 @@ void CConnman::ThreadOpenAddedConnections()
|
||||
CAddress addr(CService(), NODE_NONE);
|
||||
OpenNetworkConnection(addr, false, std::move(grant), info.m_params.m_added_node.c_str(), ConnectionType::MANUAL, info.m_params.m_use_v2transport);
|
||||
if (!interruptNet.sleep_for(std::chrono::milliseconds(500))) return;
|
||||
grant = CSemaphoreGrant(*semAddnode, /*fTry=*/true);
|
||||
grant = CountingSemaphoreGrant<>(*semAddnode, /*fTry=*/true);
|
||||
}
|
||||
// See if any reconnections are desired.
|
||||
PerformReconnections();
|
||||
@@ -2978,7 +2978,7 @@ void CConnman::ThreadOpenAddedConnections()
|
||||
}
|
||||
|
||||
// if successful, this moves the passed grant to the constructed node
|
||||
void CConnman::OpenNetworkConnection(const CAddress& addrConnect, bool fCountFailure, CSemaphoreGrant&& grant_outbound, const char *pszDest, ConnectionType conn_type, bool use_v2transport)
|
||||
void CConnman::OpenNetworkConnection(const CAddress& addrConnect, bool fCountFailure, CountingSemaphoreGrant<>&& grant_outbound, const char *pszDest, ConnectionType conn_type, bool use_v2transport)
|
||||
{
|
||||
AssertLockNotHeld(m_unused_i2p_sessions_mutex);
|
||||
assert(conn_type != ConnectionType::INBOUND);
|
||||
@@ -3329,11 +3329,11 @@ bool CConnman::Start(CScheduler& scheduler, const Options& connOptions)
|
||||
|
||||
if (semOutbound == nullptr) {
|
||||
// initialize semaphore
|
||||
semOutbound = std::make_unique<CSemaphore>(std::min(m_max_automatic_outbound, m_max_automatic_connections));
|
||||
semOutbound = std::make_unique<std::counting_semaphore<>>(std::min(m_max_automatic_outbound, m_max_automatic_connections));
|
||||
}
|
||||
if (semAddnode == nullptr) {
|
||||
// initialize semaphore
|
||||
semAddnode = std::make_unique<CSemaphore>(m_max_addnode);
|
||||
semAddnode = std::make_unique<std::counting_semaphore<>>(m_max_addnode);
|
||||
}
|
||||
|
||||
//
|
||||
@@ -3421,13 +3421,13 @@ void CConnman::Interrupt()
|
||||
|
||||
if (semOutbound) {
|
||||
for (int i=0; i<m_max_automatic_outbound; i++) {
|
||||
semOutbound->post();
|
||||
semOutbound->release();
|
||||
}
|
||||
}
|
||||
|
||||
if (semAddnode) {
|
||||
for (int i=0; i<m_max_addnode; i++) {
|
||||
semAddnode->post();
|
||||
semAddnode->release();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user