Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

dual-fund: no feestep #4648

Merged
merged 2 commits into from
Jul 19, 2021
Merged

Conversation

niftynei
Copy link
Contributor

The fee_step portion of the spec was cute but not really servicable, especially given that there's no guarantee that bumping the fee by 25% will put you over the required min_relay fee bump.

Instead, we just let the opener specify a new feerate, and require that it's at least 1/64th more than the last "successful" one (that means we've swapped tx_sigs for it successfully, it might still fail to broadcast).

Includes a fix for estimating the additional fee that a change output adds to the tx; we weren't considering the total weight which means it was possible to get off-by-one errors on the rounding.

This is a breaking change with prior dual-funding implementations.

@niftynei niftynei added this to the v0.10.1 milestone Jul 12, 2021
@niftynei niftynei requested a review from cdecker as a code owner July 12, 2021 18:45
Copy link
Contributor

@rustyrussell rustyrussell left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ack 2263a7c

@niftynei
Copy link
Contributor Author

blocked on merge of rustyrussell/lnprototest#16 (updates to rbf tests in protocol tests)

Copy link
Contributor

@vincenzopalazzo vincenzopalazzo left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ack 2263a7c

vincenzopalazzo added a commit to vincenzopalazzo/lightning that referenced this pull request Jul 14, 2021
Depending on ElementsProject#4648

Signed-off-by: Vincenzo Palazzo <vincenzopalazzodev@gmail.com>
@vincenzopalazzo
Copy link
Contributor

@niftynei this PR #4652 can help to easily fix the GitHub actions :)

@niftynei niftynei force-pushed the nifty/no_fee_step branch from 2263a7c to a82baae Compare July 14, 2021 19:47
We were getting off-by-one for the total amount that the change is for,
since it rounds the fee *down*, independent of the total weight of the
entire tx.

We fix this by using the diff btw the fee of the total weight (w/ and
w/o the change output)
@niftynei niftynei force-pushed the nifty/no_fee_step branch from a82baae to 8084926 Compare July 16, 2021 16:16
Copy link
Contributor

@vincenzopalazzo vincenzopalazzo left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ack 8084926

ERROR tests/test_db.py::test_backfill_scriptpubkeys - OSError: [Errno 39] Dir...

The github action look a like a unluck run

Using a 'feestep' is more restrictive than you'd want, instead we
enforce that the next feerate must be at least 1/64th more than the
last, but put no upper limit on it

Includes update to lnprototest changes

Contributed-By: Vincenzo Palazzo <vincenzopalazzodev@gmail.com>
Changelog-EXPERIMENTAL: Protocol: Replaces init_rbf's `fee_step` for RBF of v2 opens with `funding_feerate_perkw`, breaking change
@niftynei niftynei force-pushed the nifty/no_fee_step branch from 8084926 to 26f9692 Compare July 19, 2021 18:30
@niftynei
Copy link
Contributor Author

ACK 26f9692

@niftynei niftynei merged commit 376e6f8 into ElementsProject:master Jul 19, 2021
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants