diff options
author | Jeff Garzik <jgarzik@exmulti.com> | 2012-04-17 09:23:49 -0700 |
---|---|---|
committer | Jeff Garzik <jgarzik@exmulti.com> | 2012-04-17 09:23:49 -0700 |
commit | dd21ce5f1bb690e6104d8eba30cbd4b8749bf6b0 (patch) | |
tree | affadc04c40fbe547d7aeb6f3b2594f495c084aa | |
parent | ea9627979e172dd1d13e9f1a4b4185bb820fcfe8 (diff) | |
parent | 8deb9822e41602001b399944d8a182f48bc9d088 (diff) |
Merge pull request #1094 from jgarzik/already-have-locking
Locking fix for AlreadyHave()
-rw-r--r-- | src/main.cpp | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/src/main.cpp b/src/main.cpp index 11bcdc83fe..449f4bd372 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -2135,8 +2135,17 @@ bool static AlreadyHave(CTxDB& txdb, const CInv& inv) { switch (inv.type) { - case MSG_TX: return mapTransactions.count(inv.hash) || mapOrphanTransactions.count(inv.hash) || txdb.ContainsTx(inv.hash); - case MSG_BLOCK: return mapBlockIndex.count(inv.hash) || mapOrphanBlocks.count(inv.hash); + case MSG_TX: + { + LOCK(cs_mapTransactions); + return mapTransactions.count(inv.hash) || + mapOrphanTransactions.count(inv.hash) || + txdb.ContainsTx(inv.hash); + } + + case MSG_BLOCK: + return mapBlockIndex.count(inv.hash) || + mapOrphanBlocks.count(inv.hash); } // Don't know what it is, just say we already got one return true; |