Skip to content

Conversation

@furszy
Copy link

@furszy furszy commented Jul 1, 2020

Work done on top of #1717 .

Essentially an improvement over SyncWithWallets & SyncTransaction flow to run without locking cs_main.
(made as less modifications as possible over the zpiv wallet/chain files, no real need to improve that code.. most of it will disappear soon)

It's an adapted version of bitcoin#7946.

@furszy furszy self-assigned this Jul 1, 2020
@furszy furszy force-pushed the 2020_05_wallet_reduce_locks branch from 089c5a9 to 2be4426 Compare July 1, 2020 07:55
@furszy furszy changed the title [WIP] Reduce cs_main locks during ConnectTip/SyncWithWallets Reduce cs_main locks during ConnectTip/SyncWithWallets Jul 1, 2020
@furszy furszy force-pushed the 2020_05_wallet_reduce_locks branch from 46dd507 to 610c7f7 Compare July 12, 2020 00:28
@furszy furszy changed the title Reduce cs_main locks during ConnectTip/SyncWithWallets [Validation] Reduce cs_main locks during ConnectTip/SyncWithWallets Jul 26, 2020
@random-zebra random-zebra added this to the 5.0.0 milestone Jul 29, 2020
@furszy furszy requested a review from random-zebra July 31, 2020 01:30
Copy link

@random-zebra random-zebra left a comment

Choose a reason for hiding this comment

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

Seems we are introducing back the unused return value of SetMerkleBranch (and relative chainActive part, bringing back the need for AssertLockHeld(cs_main)).

Someone had removed those already in #1520 :)

furszy and others added 5 commits August 1, 2020 12:52
Coming from btc@867f842f1e5a385aeb2093f802d6f37a84d0fe5d
Coming from btc@5723bb44ce2c6bb14114aa7f211160702a47ac91
Adapted work coming from btc@b3b3c2a5623d5c942d2b3565cc2d833c65105555
Remove the unused variable "blockTmp" in CMerkleTx::SetMerkleBranch.  It
was previously used to read the block from disk if not provided as
argument, but is no longer needed.
coming from btc@ec81881b86b9680fcdcc42fd3ba31f04b8d09714
@furszy furszy force-pushed the 2020_05_wallet_reduce_locks branch from 610c7f7 to 3b2807f Compare August 1, 2020 17:34
@furszy
Copy link
Author

furszy commented Aug 1, 2020

Update per feedback. One more section without cs_main locked :) .

@furszy
Copy link
Author

furszy commented Aug 2, 2020

This will need more work.
Further on upstream, bitcoin#9583 reverts part of the changes made in f1eb073.
But.. to get to that point, need to continue moving forward with plenty other back ports.

random-zebra
random-zebra previously approved these changes Aug 2, 2020
Copy link

@random-zebra random-zebra left a comment

Choose a reason for hiding this comment

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

tested ACK 4b4858b
(didn't test the zerocoin changes though)

adaptation of btc@989989354b68d3954fe2742b96c53eeb2e8a7670
Copy link

@random-zebra random-zebra left a comment

Choose a reason for hiding this comment

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

utACK 9d1beb3

Copy link
Collaborator

@Fuzzbawls Fuzzbawls left a comment

Choose a reason for hiding this comment

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

ACK 9d1beb3

@random-zebra random-zebra merged commit 8e19562 into PIVX-Project:master Aug 5, 2020
@random-zebra random-zebra modified the milestones: 5.0.0, 4.3.0 Sep 10, 2020
@furszy furszy deleted the 2020_05_wallet_reduce_locks branch November 29, 2022 14:08
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

5 participants