Commit Graph

1939 Commits

Author SHA1 Message Date
jl777
71f2c6969c Revert 2018-04-23 11:23:05 +03:00
jl777
3099c9ca23 Tweak sync constants 2018-04-23 11:17:36 +03:00
jl777
7cae836aa8 Fix 2018-04-23 10:42:14 +03:00
jl777
1e57ae08ca Fix 2018-04-23 10:40:06 +03:00
jl777
882c4cfeef Syntax 2018-04-23 10:38:44 +03:00
jl777
f8a07170af Revert half of windows headers filter 2018-04-23 10:28:16 +03:00
jl777
f307157143 Reduce prev block not found to return false from state.DoS error 2018-04-22 11:07:39 +03:00
jl777
d6eb511b21 -print 2018-04-22 00:08:08 +03:00
jl777
8999ab66f1 Test 2018-04-21 23:18:52 +03:00
jl777
e6c99a7ab9 Split out no previndex from invalid prevblock 2018-04-21 23:06:56 +03:00
jl777
d859438b65 Merge 2018-04-21 19:52:27 +03:00
jl777
e3e263b59d -print 2018-04-21 19:17:16 +03:00
jl777
b0bf5d0282 -print 2018-04-21 15:55:59 +03:00
jl777
64b45b7192 Test 2018-04-21 15:16:44 +03:00
jl777
41427baa04 Test 2018-04-21 11:36:15 +03:00
jl777
a36fcdf53d Test 2018-04-21 11:28:37 +03:00
jl777
e3b04fea0c Return error if prevblock != best block 2018-04-21 10:43:41 +03:00
jl777
c685d69264 Test 2018-04-20 22:27:11 +03:00
jl777
350d40c747 Test 2018-04-20 22:19:56 +03:00
jl777
ebb59e6038 Test 2018-04-20 22:10:25 +03:00
jl777
42a7467aa6 Revert network size check to ASSETCHAINS_STAKED 2018-04-20 21:59:48 +03:00
jl777
f4b367397a Fix polarity of compare 2018-04-20 17:42:58 +03:00
jl777
2ac071da47 KOMODO_LIMITED_NETWORKSIZE
Prior commits relate to supporting a limited size network.

It looks like there is an edge case where it is possible for a hash to
be in the mapIndex, without a pindex. If a block with such a hash is
tried to be Accepted, the AcceptBlockHeader returns true but with a
null pindex, and AcceptBlock fails.

The code says that this indicates that the hash was added from a
blockheader without a block, but I didn’t see that happening. In any
case, it happens a lot on a 2 node network. So much so that if one node
is just mining, before too long the other node will not accept the
block and once that happens, no subsequent block would work as the
prior block is missing.

Of course, with more nodes, these blocks will be around a lot more and
likely it won’t be such an issue, but not so sure that it doesn’t
require restarting the node to get it back on track again.

These prior commits implement a KOMODO_LIMITED_NETWORKSIZE logic where
if it sees that a block has come in which is in the mapIndex but has no
pindex, it automatically addtoblockindex.

There is one edge case still left where both the current block being
processed and its previous block are in this limbo state. Since the
pindex is not mapped to the block, it is problematic to retrieve the
CBlock for the pprev and without the valid pprev the pindex will have a
null pprev and no nHeight set. It is possible that all the other code
will properly deal with such a case and automatically fix it, but
rather than rely on that, in such a case the automatic addtoblockindex
is not done.

A node in such a state would need to exit and restart or somehow fill
in the data from other nodes.

From what I can tell, the above is the main reason why the PoS/PoW
networks were having problems staying in sync. Since even with one
mining node, it was just a matter of time before the other node got
stuck, with more than one mining node we end up with independent forks
that won’t reconcile until the node is restarted.
2018-04-20 17:16:06 +03:00
jl777
a772476349 Test 2018-04-20 16:55:34 +03:00
jl777
3128a24af6 Test 2018-04-20 13:35:16 +03:00
jl777
9464ac21bc Test 2018-04-20 13:03:27 +03:00
jl777
820600d13f Test 2018-04-20 12:43:08 +03:00
jl777
b85130925b Test 2018-04-20 12:42:27 +03:00
jl777
66dd02d288 Test 2018-04-20 12:32:39 +03:00
jl777
b1d85b23e6 Test 2018-04-20 12:21:01 +03:00
jl777
519578c9c9 Test 2018-04-20 12:17:02 +03:00
jl777
0f102ea7e3 Test 2018-04-20 12:14:11 +03:00
jl777
5295318ec4 Test 2018-04-20 12:08:51 +03:00
jl777
8dcf7f3fab Test 2018-04-20 12:07:57 +03:00
jl777
b5d0fe2e24 Test 2018-04-20 11:55:06 +03:00
jl777
b92dfb1eb5 Test 2018-04-20 11:53:02 +03:00
jl777
7732dbc26b Test 2018-04-20 11:34:37 +03:00
jl777
9850dffd80 Test 2018-04-20 11:30:27 +03:00
jl777
fd835d9406 Test 2018-04-20 11:29:12 +03:00
jl777
592f6fa210 Test 2018-04-20 11:24:41 +03:00
jl777
bc2bcf8551 Test 2018-04-20 11:24:01 +03:00
jl777
4aad3872a9 Test 2018-04-20 11:20:57 +03:00
jl777
bee39cbbbb Test 2018-04-20 11:20:11 +03:00
jl777
17522a5557 Test 2018-04-20 11:19:35 +03:00
jl777
415f5097cf Test 2018-04-20 10:59:21 +03:00
jl777
e14073653c Test 2018-04-20 10:55:12 +03:00
jl777
6d3df1e66c Test 2018-04-20 10:47:27 +03:00
jl777
4f48647cdc Test 2018-04-20 10:30:40 +03:00
jl777
74d30ec279 Merge branch 'dev' into jl777 2018-04-20 09:32:24 +03:00
jl777
02290a3fd8 Test 2018-04-20 01:15:21 +03:00