Skip to content

Commit 937d1d8

Browse files
authored
Merge pull request #731 from TheBlueMatt/2020-10-fix-big-lock
Actually hold the total_consistency_lock instead of take-and-drop
2 parents 7d38c25 + ddebf36 commit 937d1d8

File tree

1 file changed

+34
-34
lines changed

1 file changed

+34
-34
lines changed

lightning/src/ln/channelmanager.rs

Lines changed: 34 additions & 34 deletions
Original file line numberDiff line numberDiff line change
@@ -775,7 +775,7 @@ impl<ChanSigner: ChannelKeys, M: Deref, T: Deref, K: Deref, F: Deref, L: Deref>
775775
let channel = Channel::new_outbound(&self.fee_estimator, &self.keys_manager, their_network_key, channel_value_satoshis, push_msat, user_id, config)?;
776776
let res = channel.get_open_channel(self.genesis_hash.clone());
777777

778-
let _ = self.total_consistency_lock.read().unwrap();
778+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
779779
let mut channel_state = self.channel_state.lock().unwrap();
780780
match channel_state.by_id.entry(channel.channel_id()) {
781781
hash_map::Entry::Occupied(_) => {
@@ -847,7 +847,7 @@ impl<ChanSigner: ChannelKeys, M: Deref, T: Deref, K: Deref, F: Deref, L: Deref>
847847
///
848848
/// May generate a SendShutdown message event on success, which should be relayed.
849849
pub fn close_channel(&self, channel_id: &[u8; 32]) -> Result<(), APIError> {
850-
let _ = self.total_consistency_lock.read().unwrap();
850+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
851851

852852
let (mut failed_htlcs, chan_option) = {
853853
let mut channel_state_lock = self.channel_state.lock().unwrap();
@@ -907,7 +907,7 @@ impl<ChanSigner: ChannelKeys, M: Deref, T: Deref, K: Deref, F: Deref, L: Deref>
907907
/// Force closes a channel, immediately broadcasting the latest local commitment transaction to
908908
/// the chain and rejecting new HTLCs on the given channel.
909909
pub fn force_close_channel(&self, channel_id: &[u8; 32]) {
910-
let _ = self.total_consistency_lock.read().unwrap();
910+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
911911

912912
let mut chan = {
913913
let mut channel_state_lock = self.channel_state.lock().unwrap();
@@ -1255,7 +1255,7 @@ impl<ChanSigner: ChannelKeys, M: Deref, T: Deref, K: Deref, F: Deref, L: Deref>
12551255
}
12561256
let onion_packet = onion_utils::construct_onion_packet(onion_payloads, onion_keys, prng_seed, payment_hash);
12571257

1258-
let _ = self.total_consistency_lock.read().unwrap();
1258+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
12591259

12601260
let err: Result<(), _> = loop {
12611261
let mut channel_lock = self.channel_state.lock().unwrap();
@@ -1423,7 +1423,7 @@ impl<ChanSigner: ChannelKeys, M: Deref, T: Deref, K: Deref, F: Deref, L: Deref>
14231423
/// May panic if the funding_txo is duplicative with some other channel (note that this should
14241424
/// be trivially prevented by using unique funding transaction keys per-channel).
14251425
pub fn funding_transaction_generated(&self, temporary_channel_id: &[u8; 32], funding_txo: OutPoint) {
1426-
let _ = self.total_consistency_lock.read().unwrap();
1426+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
14271427

14281428
let (chan, msg) = {
14291429
let (res, chan) = match self.channel_state.lock().unwrap().by_id.remove(temporary_channel_id) {
@@ -1506,7 +1506,7 @@ impl<ChanSigner: ChannelKeys, M: Deref, T: Deref, K: Deref, F: Deref, L: Deref>
15061506
///
15071507
/// Panics if addresses is absurdly large (more than 500).
15081508
pub fn broadcast_node_announcement(&self, rgb: [u8; 3], alias: [u8; 32], addresses: Vec<NetAddress>) {
1509-
let _ = self.total_consistency_lock.read().unwrap();
1509+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
15101510

15111511
if addresses.len() > 500 {
15121512
panic!("More than half the message size was taken up by public addresses!");
@@ -1536,7 +1536,7 @@ impl<ChanSigner: ChannelKeys, M: Deref, T: Deref, K: Deref, F: Deref, L: Deref>
15361536
/// Should only really ever be called in response to a PendingHTLCsForwardable event.
15371537
/// Will likely generate further events.
15381538
pub fn process_pending_htlc_forwards(&self) {
1539-
let _ = self.total_consistency_lock.read().unwrap();
1539+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
15401540

15411541
let mut new_events = Vec::new();
15421542
let mut failed_forwards = Vec::new();
@@ -1789,7 +1789,7 @@ impl<ChanSigner: ChannelKeys, M: Deref, T: Deref, K: Deref, F: Deref, L: Deref>
17891789
///
17901790
/// This method handles all the details, and must be called roughly once per minute.
17911791
pub fn timer_chan_freshness_every_min(&self) {
1792-
let _ = self.total_consistency_lock.read().unwrap();
1792+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
17931793
let mut channel_state_lock = self.channel_state.lock().unwrap();
17941794
let channel_state = &mut *channel_state_lock;
17951795
for (_, chan) in channel_state.by_id.iter_mut() {
@@ -1814,7 +1814,7 @@ impl<ChanSigner: ChannelKeys, M: Deref, T: Deref, K: Deref, F: Deref, L: Deref>
18141814
/// Returns false if no payment was found to fail backwards, true if the process of failing the
18151815
/// HTLC backwards has been started.
18161816
pub fn fail_htlc_backwards(&self, payment_hash: &PaymentHash, payment_secret: &Option<PaymentSecret>) -> bool {
1817-
let _ = self.total_consistency_lock.read().unwrap();
1817+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
18181818

18191819
let mut channel_state = Some(self.channel_state.lock().unwrap());
18201820
let removed_source = channel_state.as_mut().unwrap().claimable_htlcs.remove(&(*payment_hash, *payment_secret));
@@ -1993,7 +1993,7 @@ impl<ChanSigner: ChannelKeys, M: Deref, T: Deref, K: Deref, F: Deref, L: Deref>
19931993
pub fn claim_funds(&self, payment_preimage: PaymentPreimage, payment_secret: &Option<PaymentSecret>, expected_amount: u64) -> bool {
19941994
let payment_hash = PaymentHash(Sha256::hash(&payment_preimage.0).into_inner());
19951995

1996-
let _ = self.total_consistency_lock.read().unwrap();
1996+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
19971997

19981998
let mut channel_state = Some(self.channel_state.lock().unwrap());
19991999
let removed_source = channel_state.as_mut().unwrap().claimable_htlcs.remove(&(payment_hash, *payment_secret));
@@ -2178,7 +2178,7 @@ impl<ChanSigner: ChannelKeys, M: Deref, T: Deref, K: Deref, F: Deref, L: Deref>
21782178
/// 4) once all remote copies are updated, you call this function with the update_id that
21792179
/// completed, and once it is the latest the Channel will be re-enabled.
21802180
pub fn channel_monitor_updated(&self, funding_txo: &OutPoint, highest_applied_update_id: u64) {
2181-
let _ = self.total_consistency_lock.read().unwrap();
2181+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
21822182

21832183
let mut close_results = Vec::new();
21842184
let mut htlc_forwards = Vec::new();
@@ -2922,7 +2922,7 @@ impl<ChanSigner: ChannelKeys, M: Deref, T: Deref, K: Deref, F: Deref, L: Deref>
29222922
/// (C-not exported) Cause its doc(hidden) anyway
29232923
#[doc(hidden)]
29242924
pub fn update_fee(&self, channel_id: [u8;32], feerate_per_kw: u32) -> Result<(), APIError> {
2925-
let _ = self.total_consistency_lock.read().unwrap();
2925+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
29262926
let counterparty_node_id;
29272927
let err: Result<(), _> = loop {
29282928
let mut channel_state_lock = self.channel_state.lock().unwrap();
@@ -3062,7 +3062,7 @@ impl<ChanSigner: ChannelKeys, M: Deref, T: Deref, K: Deref, F: Deref, L: Deref>
30623062
pub fn block_connected(&self, header: &BlockHeader, txdata: &TransactionData, height: u32) {
30633063
let header_hash = header.block_hash();
30643064
log_trace!(self.logger, "Block {} at height {} connected", header_hash, height);
3065-
let _ = self.total_consistency_lock.read().unwrap();
3065+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
30663066
let mut failed_channels = Vec::new();
30673067
let mut timed_out_htlcs = Vec::new();
30683068
{
@@ -3175,7 +3175,7 @@ impl<ChanSigner: ChannelKeys, M: Deref, T: Deref, K: Deref, F: Deref, L: Deref>
31753175
/// If necessary, the channel may be force-closed without letting the counterparty participate
31763176
/// in the shutdown.
31773177
pub fn block_disconnected(&self, header: &BlockHeader) {
3178-
let _ = self.total_consistency_lock.read().unwrap();
3178+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
31793179
let mut failed_channels = Vec::new();
31803180
{
31813181
let mut channel_lock = self.channel_state.lock().unwrap();
@@ -3216,87 +3216,87 @@ impl<ChanSigner: ChannelKeys, M: Deref + Sync + Send, T: Deref + Sync + Send, K:
32163216
L::Target: Logger,
32173217
{
32183218
fn handle_open_channel(&self, counterparty_node_id: &PublicKey, their_features: InitFeatures, msg: &msgs::OpenChannel) {
3219-
let _ = self.total_consistency_lock.read().unwrap();
3219+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
32203220
let _ = handle_error!(self, self.internal_open_channel(counterparty_node_id, their_features, msg), *counterparty_node_id);
32213221
}
32223222

32233223
fn handle_accept_channel(&self, counterparty_node_id: &PublicKey, their_features: InitFeatures, msg: &msgs::AcceptChannel) {
3224-
let _ = self.total_consistency_lock.read().unwrap();
3224+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
32253225
let _ = handle_error!(self, self.internal_accept_channel(counterparty_node_id, their_features, msg), *counterparty_node_id);
32263226
}
32273227

32283228
fn handle_funding_created(&self, counterparty_node_id: &PublicKey, msg: &msgs::FundingCreated) {
3229-
let _ = self.total_consistency_lock.read().unwrap();
3229+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
32303230
let _ = handle_error!(self, self.internal_funding_created(counterparty_node_id, msg), *counterparty_node_id);
32313231
}
32323232

32333233
fn handle_funding_signed(&self, counterparty_node_id: &PublicKey, msg: &msgs::FundingSigned) {
3234-
let _ = self.total_consistency_lock.read().unwrap();
3234+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
32353235
let _ = handle_error!(self, self.internal_funding_signed(counterparty_node_id, msg), *counterparty_node_id);
32363236
}
32373237

32383238
fn handle_funding_locked(&self, counterparty_node_id: &PublicKey, msg: &msgs::FundingLocked) {
3239-
let _ = self.total_consistency_lock.read().unwrap();
3239+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
32403240
let _ = handle_error!(self, self.internal_funding_locked(counterparty_node_id, msg), *counterparty_node_id);
32413241
}
32423242

32433243
fn handle_shutdown(&self, counterparty_node_id: &PublicKey, msg: &msgs::Shutdown) {
3244-
let _ = self.total_consistency_lock.read().unwrap();
3244+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
32453245
let _ = handle_error!(self, self.internal_shutdown(counterparty_node_id, msg), *counterparty_node_id);
32463246
}
32473247

32483248
fn handle_closing_signed(&self, counterparty_node_id: &PublicKey, msg: &msgs::ClosingSigned) {
3249-
let _ = self.total_consistency_lock.read().unwrap();
3249+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
32503250
let _ = handle_error!(self, self.internal_closing_signed(counterparty_node_id, msg), *counterparty_node_id);
32513251
}
32523252

32533253
fn handle_update_add_htlc(&self, counterparty_node_id: &PublicKey, msg: &msgs::UpdateAddHTLC) {
3254-
let _ = self.total_consistency_lock.read().unwrap();
3254+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
32553255
let _ = handle_error!(self, self.internal_update_add_htlc(counterparty_node_id, msg), *counterparty_node_id);
32563256
}
32573257

32583258
fn handle_update_fulfill_htlc(&self, counterparty_node_id: &PublicKey, msg: &msgs::UpdateFulfillHTLC) {
3259-
let _ = self.total_consistency_lock.read().unwrap();
3259+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
32603260
let _ = handle_error!(self, self.internal_update_fulfill_htlc(counterparty_node_id, msg), *counterparty_node_id);
32613261
}
32623262

32633263
fn handle_update_fail_htlc(&self, counterparty_node_id: &PublicKey, msg: &msgs::UpdateFailHTLC) {
3264-
let _ = self.total_consistency_lock.read().unwrap();
3264+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
32653265
let _ = handle_error!(self, self.internal_update_fail_htlc(counterparty_node_id, msg), *counterparty_node_id);
32663266
}
32673267

32683268
fn handle_update_fail_malformed_htlc(&self, counterparty_node_id: &PublicKey, msg: &msgs::UpdateFailMalformedHTLC) {
3269-
let _ = self.total_consistency_lock.read().unwrap();
3269+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
32703270
let _ = handle_error!(self, self.internal_update_fail_malformed_htlc(counterparty_node_id, msg), *counterparty_node_id);
32713271
}
32723272

32733273
fn handle_commitment_signed(&self, counterparty_node_id: &PublicKey, msg: &msgs::CommitmentSigned) {
3274-
let _ = self.total_consistency_lock.read().unwrap();
3274+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
32753275
let _ = handle_error!(self, self.internal_commitment_signed(counterparty_node_id, msg), *counterparty_node_id);
32763276
}
32773277

32783278
fn handle_revoke_and_ack(&self, counterparty_node_id: &PublicKey, msg: &msgs::RevokeAndACK) {
3279-
let _ = self.total_consistency_lock.read().unwrap();
3279+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
32803280
let _ = handle_error!(self, self.internal_revoke_and_ack(counterparty_node_id, msg), *counterparty_node_id);
32813281
}
32823282

32833283
fn handle_update_fee(&self, counterparty_node_id: &PublicKey, msg: &msgs::UpdateFee) {
3284-
let _ = self.total_consistency_lock.read().unwrap();
3284+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
32853285
let _ = handle_error!(self, self.internal_update_fee(counterparty_node_id, msg), *counterparty_node_id);
32863286
}
32873287

32883288
fn handle_announcement_signatures(&self, counterparty_node_id: &PublicKey, msg: &msgs::AnnouncementSignatures) {
3289-
let _ = self.total_consistency_lock.read().unwrap();
3289+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
32903290
let _ = handle_error!(self, self.internal_announcement_signatures(counterparty_node_id, msg), *counterparty_node_id);
32913291
}
32923292

32933293
fn handle_channel_reestablish(&self, counterparty_node_id: &PublicKey, msg: &msgs::ChannelReestablish) {
3294-
let _ = self.total_consistency_lock.read().unwrap();
3294+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
32953295
let _ = handle_error!(self, self.internal_channel_reestablish(counterparty_node_id, msg), *counterparty_node_id);
32963296
}
32973297

32983298
fn peer_disconnected(&self, counterparty_node_id: &PublicKey, no_connection_possible: bool) {
3299-
let _ = self.total_consistency_lock.read().unwrap();
3299+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
33003300
let mut failed_channels = Vec::new();
33013301
let mut failed_payments = Vec::new();
33023302
let mut no_channels_remain = true;
@@ -3387,7 +3387,7 @@ impl<ChanSigner: ChannelKeys, M: Deref + Sync + Send, T: Deref + Sync + Send, K:
33873387
fn peer_connected(&self, counterparty_node_id: &PublicKey, init_msg: &msgs::Init) {
33883388
log_debug!(self.logger, "Generating channel_reestablish events for {}", log_pubkey!(counterparty_node_id));
33893389

3390-
let _ = self.total_consistency_lock.read().unwrap();
3390+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
33913391

33923392
{
33933393
let mut peer_state_lock = self.per_peer_state.write().unwrap();
@@ -3427,7 +3427,7 @@ impl<ChanSigner: ChannelKeys, M: Deref + Sync + Send, T: Deref + Sync + Send, K:
34273427
}
34283428

34293429
fn handle_error(&self, counterparty_node_id: &PublicKey, msg: &msgs::ErrorMessage) {
3430-
let _ = self.total_consistency_lock.read().unwrap();
3430+
let _consistency_lock = self.total_consistency_lock.read().unwrap();
34313431

34323432
if msg.channel_id == [0; 32] {
34333433
for chan in self.list_channels() {
@@ -3659,7 +3659,7 @@ impl<ChanSigner: ChannelKeys + Writeable, M: Deref, T: Deref, K: Deref, F: Deref
36593659
L::Target: Logger,
36603660
{
36613661
fn write<W: Writer>(&self, writer: &mut W) -> Result<(), ::std::io::Error> {
3662-
let _ = self.total_consistency_lock.write().unwrap();
3662+
let _consistency_lock = self.total_consistency_lock.write().unwrap();
36633663

36643664
writer.write_all(&[SERIALIZATION_VERSION; 1])?;
36653665
writer.write_all(&[MIN_SERIALIZATION_VERSION; 1])?;

0 commit comments

Comments
 (0)