Skip to content

Commit 3956b11

Browse files
committed
delete commitment tx fee info cached
1 parent 20eee80 commit 3956b11

File tree

1 file changed

+5
-119
lines changed

1 file changed

+5
-119
lines changed

lightning/src/ln/channel.rs

Lines changed: 5 additions & 119 deletions
Original file line numberDiff line numberDiff line change
@@ -1976,14 +1976,9 @@ pub(super) struct FundingScope {
19761976
/// Max to_local and to_remote outputs in a remote-generated commitment transaction
19771977
counterparty_max_commitment_tx_output: Mutex<(u64, u64)>,
19781978

1979-
// We save these values so we can make sure `next_local_commit_tx_fee_msat` and
1980-
// `next_remote_commit_tx_fee_msat` properly predict what the next commitment transaction fee will
1981-
// be, by comparing the cached values to the fee of the transaction generated by
1982-
// `build_commitment_transaction`.
1983-
#[cfg(any(test, fuzzing))]
1984-
next_local_commitment_tx_fee_info_cached: Mutex<Option<CommitmentTxInfoCached>>,
1985-
#[cfg(any(test, fuzzing))]
1986-
next_remote_commitment_tx_fee_info_cached: Mutex<Option<CommitmentTxInfoCached>>,
1979+
// We save these values so we can make sure validation of channel updates properly predicts
1980+
// what the next commitment transaction fee will be, by comparing the cached values to the
1981+
// fee of the transaction generated by `build_commitment_transaction`.
19871982
#[cfg(any(test, fuzzing))]
19881983
next_local_fee: Mutex<PredictedNextFee>,
19891984
#[cfg(any(test, fuzzing))]
@@ -2061,10 +2056,6 @@ impl Readable for FundingScope {
20612056
short_channel_id,
20622057
minimum_depth_override,
20632058
#[cfg(any(test, fuzzing))]
2064-
next_local_commitment_tx_fee_info_cached: Mutex::new(None),
2065-
#[cfg(any(test, fuzzing))]
2066-
next_remote_commitment_tx_fee_info_cached: Mutex::new(None),
2067-
#[cfg(any(test, fuzzing))]
20682059
next_local_fee: Mutex::new(PredictedNextFee::default()),
20692060
#[cfg(any(test, fuzzing))]
20702061
next_remote_fee: Mutex::new(PredictedNextFee::default()),
@@ -3210,10 +3201,6 @@ where
32103201
#[cfg(debug_assertions)]
32113202
counterparty_max_commitment_tx_output: Mutex::new((value_to_self_msat, (channel_value_satoshis * 1000 - msg_push_msat).saturating_sub(value_to_self_msat))),
32123203

3213-
#[cfg(any(test, fuzzing))]
3214-
next_local_commitment_tx_fee_info_cached: Mutex::new(None),
3215-
#[cfg(any(test, fuzzing))]
3216-
next_remote_commitment_tx_fee_info_cached: Mutex::new(None),
32173204
#[cfg(any(test, fuzzing))]
32183205
next_local_fee: Mutex::new(PredictedNextFee::default()),
32193206
#[cfg(any(test, fuzzing))]
@@ -3457,10 +3444,6 @@ where
34573444
#[cfg(debug_assertions)]
34583445
counterparty_max_commitment_tx_output: Mutex::new((channel_value_satoshis * 1000 - push_msat, push_msat)),
34593446

3460-
#[cfg(any(test, fuzzing))]
3461-
next_local_commitment_tx_fee_info_cached: Mutex::new(None),
3462-
#[cfg(any(test, fuzzing))]
3463-
next_remote_commitment_tx_fee_info_cached: Mutex::new(None),
34643447
#[cfg(any(test, fuzzing))]
34653448
next_local_fee: Mutex::new(PredictedNextFee::default()),
34663449
#[cfg(any(test, fuzzing))]
@@ -4451,20 +4434,6 @@ where
44514434
}
44524435
#[cfg(any(test, fuzzing))]
44534436
{
4454-
if funding.is_outbound() {
4455-
let projected_commit_tx_info = funding.next_local_commitment_tx_fee_info_cached.lock().unwrap().take();
4456-
*funding.next_remote_commitment_tx_fee_info_cached.lock().unwrap() = None;
4457-
if let Some(info) = projected_commit_tx_info {
4458-
let total_pending_htlcs = self.pending_inbound_htlcs.len() + self.pending_outbound_htlcs.len()
4459-
+ self.holding_cell_htlc_updates.len();
4460-
if info.total_pending_htlcs == total_pending_htlcs
4461-
&& info.next_holder_htlc_id == self.next_holder_htlc_id
4462-
&& info.next_counterparty_htlc_id == self.next_counterparty_htlc_id
4463-
&& info.feerate == self.feerate_per_kw {
4464-
assert_eq!(commitment_data.stats.commit_tx_fee_sat, info.fee / 1000);
4465-
}
4466-
}
4467-
}
44684437
let PredictedNextFee { predicted_feerate, predicted_htlcs, predicted_fee_sat } = funding.next_local_fee.lock().unwrap().clone();
44694438
let mut actual_nondust_htlcs: Vec<_> = commitment_data.tx.nondust_htlcs().iter().map(|&HTLCOutputInCommitment { offered, amount_msat, .. } | HTLCAmountDirection { outbound: offered, amount_msat }).collect();
44704439
actual_nondust_htlcs.sort_unstable();
@@ -5349,31 +5318,7 @@ where
53495318
}
53505319

53515320
let num_htlcs = included_htlcs + addl_htlcs;
5352-
let commit_tx_fee_msat = SpecTxBuilder {}.commit_tx_fee_sat(context.feerate_per_kw, num_htlcs, funding.get_channel_type()) * 1000;
5353-
#[cfg(any(test, fuzzing))]
5354-
{
5355-
let mut fee = commit_tx_fee_msat;
5356-
if fee_spike_buffer_htlc.is_some() {
5357-
fee = SpecTxBuilder {}.commit_tx_fee_sat(context.feerate_per_kw, num_htlcs - 1, funding.get_channel_type()) * 1000;
5358-
}
5359-
let total_pending_htlcs = context.pending_inbound_htlcs.len() + context.pending_outbound_htlcs.len()
5360-
+ context.holding_cell_htlc_updates.len();
5361-
let commitment_tx_info = CommitmentTxInfoCached {
5362-
fee,
5363-
total_pending_htlcs,
5364-
next_holder_htlc_id: match htlc.origin {
5365-
HTLCInitiator::LocalOffered => context.next_holder_htlc_id + 1,
5366-
HTLCInitiator::RemoteOffered => context.next_holder_htlc_id,
5367-
},
5368-
next_counterparty_htlc_id: match htlc.origin {
5369-
HTLCInitiator::LocalOffered => context.next_counterparty_htlc_id,
5370-
HTLCInitiator::RemoteOffered => context.next_counterparty_htlc_id + 1,
5371-
},
5372-
feerate: context.feerate_per_kw,
5373-
};
5374-
*funding.next_local_commitment_tx_fee_info_cached.lock().unwrap() = Some(commitment_tx_info);
5375-
}
5376-
commit_tx_fee_msat
5321+
SpecTxBuilder {}.commit_tx_fee_sat(context.feerate_per_kw, num_htlcs, funding.get_channel_type()) * 1000
53775322
}
53785323

53795324
/// Get the commitment tx fee for the remote's next commitment transaction based on the number of
@@ -5450,30 +5395,7 @@ where
54505395
}
54515396

54525397
let num_htlcs = included_htlcs + addl_htlcs;
5453-
let commit_tx_fee_msat = SpecTxBuilder {}.commit_tx_fee_sat(context.feerate_per_kw, num_htlcs, funding.get_channel_type()) * 1000;
5454-
#[cfg(any(test, fuzzing))]
5455-
if let Some(htlc) = &htlc {
5456-
let mut fee = commit_tx_fee_msat;
5457-
if fee_spike_buffer_htlc.is_some() {
5458-
fee = SpecTxBuilder {}.commit_tx_fee_sat(context.feerate_per_kw, num_htlcs - 1, funding.get_channel_type()) * 1000;
5459-
}
5460-
let total_pending_htlcs = context.pending_inbound_htlcs.len() + context.pending_outbound_htlcs.len();
5461-
let commitment_tx_info = CommitmentTxInfoCached {
5462-
fee,
5463-
total_pending_htlcs,
5464-
next_holder_htlc_id: match htlc.origin {
5465-
HTLCInitiator::LocalOffered => context.next_holder_htlc_id + 1,
5466-
HTLCInitiator::RemoteOffered => context.next_holder_htlc_id,
5467-
},
5468-
next_counterparty_htlc_id: match htlc.origin {
5469-
HTLCInitiator::LocalOffered => context.next_counterparty_htlc_id,
5470-
HTLCInitiator::RemoteOffered => context.next_counterparty_htlc_id + 1,
5471-
},
5472-
feerate: context.feerate_per_kw,
5473-
};
5474-
*funding.next_remote_commitment_tx_fee_info_cached.lock().unwrap() = Some(commitment_tx_info);
5475-
}
5476-
commit_tx_fee_msat
5398+
SpecTxBuilder {}.commit_tx_fee_sat(context.feerate_per_kw, num_htlcs, funding.get_channel_type()) * 1000
54775399
}
54785400

54795401
#[rustfmt::skip]
@@ -6128,15 +6050,6 @@ macro_rules! promote_splice_funding {
61286050
};
61296051
}
61306052

6131-
#[cfg(any(test, fuzzing))]
6132-
struct CommitmentTxInfoCached {
6133-
fee: u64,
6134-
total_pending_htlcs: usize,
6135-
next_holder_htlc_id: u64,
6136-
next_counterparty_htlc_id: u64,
6137-
feerate: u32,
6138-
}
6139-
61406053
#[cfg(any(test, fuzzing))]
61416054
#[derive(Clone, Default)]
61426055
struct PredictedNextFee {
@@ -7645,16 +7558,6 @@ where
76457558
return Err(ChannelError::close("Received an unexpected revoke_and_ack".to_owned()));
76467559
}
76477560

7648-
#[cfg(any(test, fuzzing))]
7649-
{
7650-
for funding in
7651-
core::iter::once(&mut self.funding).chain(self.pending_funding.iter_mut())
7652-
{
7653-
*funding.next_local_commitment_tx_fee_info_cached.lock().unwrap() = None;
7654-
*funding.next_remote_commitment_tx_fee_info_cached.lock().unwrap() = None;
7655-
}
7656-
}
7657-
76587561
match &self.context.holder_signer {
76597562
ChannelSignerType::Ecdsa(ecdsa) => {
76607563
ecdsa
@@ -11096,19 +10999,6 @@ where
1109610999

1109711000
#[cfg(any(test, fuzzing))]
1109811001
{
11099-
if !funding.is_outbound() {
11100-
let projected_commit_tx_info = funding.next_remote_commitment_tx_fee_info_cached.lock().unwrap().take();
11101-
*funding.next_local_commitment_tx_fee_info_cached.lock().unwrap() = None;
11102-
if let Some(info) = projected_commit_tx_info {
11103-
let total_pending_htlcs = self.context.pending_inbound_htlcs.len() + self.context.pending_outbound_htlcs.len();
11104-
if info.total_pending_htlcs == total_pending_htlcs
11105-
&& info.next_holder_htlc_id == self.context.next_holder_htlc_id
11106-
&& info.next_counterparty_htlc_id == self.context.next_counterparty_htlc_id
11107-
&& info.feerate == self.context.feerate_per_kw {
11108-
assert_eq!(commitment_data.stats.commit_tx_fee_sat, info.fee);
11109-
}
11110-
}
11111-
}
1111211002
let PredictedNextFee { predicted_feerate, predicted_htlcs, predicted_fee_sat } = funding.next_remote_fee.lock().unwrap().clone();
1111311003
let mut actual_nondust_htlcs: Vec<_> = counterparty_commitment_tx.nondust_htlcs().iter().map(|&HTLCOutputInCommitment { offered, amount_msat, .. }| HTLCAmountDirection { outbound: !offered, amount_msat }).collect();
1111411004
actual_nondust_htlcs.sort_unstable();
@@ -13736,10 +13626,6 @@ where
1373613626
#[cfg(debug_assertions)]
1373713627
counterparty_max_commitment_tx_output: Mutex::new((0, 0)),
1373813628

13739-
#[cfg(any(test, fuzzing))]
13740-
next_local_commitment_tx_fee_info_cached: Mutex::new(None),
13741-
#[cfg(any(test, fuzzing))]
13742-
next_remote_commitment_tx_fee_info_cached: Mutex::new(None),
1374313629
#[cfg(any(test, fuzzing))]
1374413630
next_local_fee: Mutex::new(PredictedNextFee::default()),
1374513631
#[cfg(any(test, fuzzing))]

0 commit comments

Comments
 (0)