Re: [Bitcoin-development] Hard fork via miner vote

2015-06-20 Thread Matt Whitlock
On Saturday, 20 June 2015, at 8:11 pm, Pieter Wuille wrote:
 you want full nodes that have not noticed the fork to fail rather than see a 
 slow but otherwise functional chain.

Isn't that what the Alert mechanism is for? If these nodes continue running 
despite an alert telling them they're outdated, then it must be intentional.

--
___
Bitcoin-development mailing list
Bitcoin-development@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/bitcoin-development


Re: [Bitcoin-development] Hard fork via miner vote

2015-06-20 Thread Pieter Wuille
On Sat, Jun 20, 2015 at 7:26 PM, David Vorick david.vor...@gmail.com
wrote:

 I see it as unreasonable to expect all nodes to upgrade during a hardfork.
 If you are intentionally waiting for that to happen, it's possible for an
 extreme minority of nodes to hold the rest of the network hostage by simply
 refusing to upgrade. However you want nodes to be able to protest until it
 is clear that they have lost the battle without being at risk of getting
 hardforked out of the network unexpectedly.


You can't observe the majority of nodes, only miners, and weighed by
hashrate. If you need a mechanism for protest, that should happen before
the hard fork change code is rolled out. I am assuming a completely
uncontroversial change, in order to not confuse this discussion with the
debate about what hard forks should be done.

So I am not talking about protest, just about deploying a change. And yes,
it is unreasonable to expect that every single node will upgrade. But there
is a difference between ignoring old unmaintained nodes that do not
influence anyone's behaviour, and ignoring the nodes that power miners
producing actual blocks. In addition, having no blocks on the old chain is
safer than producing a small number, as you want full nodes that have not
noticed the fork to fail rather than see a slow but otherwise functional
chain.

-- 
Pieter
--
___
Bitcoin-development mailing list
Bitcoin-development@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/bitcoin-development


Re: [Bitcoin-development] Hard fork via miner vote

2015-06-20 Thread Tier Nolan
I agree giving notice that the change is going to happen is critical for a
hard fork.  If miners vote in favor, they need to give people time to
upgrade (or to decide to reject the fork).

The BIP 100 proposal is that no change will happen until a timestamp is
reached.  It isn't clear exactly how it would work.

Testnet: Sep 1st 2015
Mainnet: Jan 11th 2016

It suggests 90% of 12000 blocks (~83 days).

This means that if 10800 of the last 12000 blocks are the updated version,
then the change is considered locked in.

I think having an earlier fail threshold would be a good idea too.  This
guarantees notice.

Assuming 3 is old rule and 4 is new rule

If the median of 11 timestamp is after 1st Sep 2015 and less than 10800 of
the last 12000 blocks are version 4+, then reject version 4 blocks
If the median of 11 timestamp is after 1st Nov 2015 and at least 10800 of
the last 12000 blocks are version 4+, then reject version 3 blocks
(lock-in)
If the median of 11 timestamp is after 1st Jan 2016 and at least 10800 of
the last 12000 blocks are version 4+, the allow new rule

This means that if the 90% threshold is lost at any time between 1st Sep
and 1st Nov, then the fork is rejected.  Otherwise, after the 1st Nov, it
is locked in, but the new rules don't activate until 1st Jan.

For block size, miners could still soft fork back to 1MB after 1st Nov, it
there is a user/merchant revolt (maybe that would be version 5 blocks).


On Sat, Jun 20, 2015 at 6:13 PM, Pieter Wuille pieter.wui...@gmail.com
wrote:

 Hello all,

 I've seen ideas around hard fork proposals that involve a block version
 vote (a la BIP34, BIP66, or my more recent versionbits BIP draft). I
 believe this is a bad idea, independent of what the hard fork itself is.

 Ultimately, the purpose of a hard fork is asking the whole community to
 change their full nodes to new code. The purpose of the trigger mechanism
 is to establish when that has happened.

 Using a 95% threshold, implies the fork can happen when at least 5% of
 miners have not upgraded, which implies some full nodes have not (as miners
 are nodes), and in addition, means the old chain can keep growing too,
 confusing old non-miner nodes as well.

 Ideally, the fork should be scheduled when one is certain nodes will have
 upgraded, and the risk for a fork will be gone. If everyone has upgraded,
 no vote is necessary, and if nodes have not, it remains risky to fork them
 off.

 I understand that, in order to keep humans in the loop, you want an
 observable trigger mechanism, and a hashrate vote is an easy way to do
 this. But at least, use a minimum timestamp you believe to be reasonable
 for upgrade, and a 100% threshold afterwards. Anything else guarantees that
 your forking change happens *knowingly* before the risk is gone.

 You may argue that miners would be asked to - and have it in their best
 interest - to not actually make blocks that violate the changed rule before
 they are reasonably sure that everyone has upgraded. That is possible, but
 it does not gain you anything over just using a 100% threshold, as how
 would they be reasonably sure everyone has upgraded, while blocks creater
 by non-upgraded miners are still being created?

 TL;DR: use a timestamp switchover for a hard fork, or add a block voting
 threshold as a means to keep humans in the loop, but if you do, use 100% as
 threshold.

 --
 Pieter


 --

 ___
 Bitcoin-development mailing list
 Bitcoin-development@lists.sourceforge.net
 https://lists.sourceforge.net/lists/listinfo/bitcoin-development


--
___
Bitcoin-development mailing list
Bitcoin-development@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/bitcoin-development