Commit Graph

659 Commits

Author SHA1 Message Date
jl777
395f10cf91 Test 2018-04-24 21:09:51 +03:00
jl777
43ef3068d1 10 second window for notary mining 2018-04-23 23:47:48 +03:00
jl777
37091e704e 30 seconds margin for notary mining 2018-04-23 21:33:18 +03:00
jl777
161f617de4 komodo_requestedhash request 2018-04-23 19:58:16 +03:00
jl777
64b45b7192 Test 2018-04-21 15:16:44 +03:00
jl777
a36c1a705a +print 2018-04-21 14:53:16 +03:00
jl777
0d8e3988e9 Immediate submit block from miner 2018-04-20 22:44:01 +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
563d507c61 Test 2018-04-20 13:30:54 +03:00
jl777
cfb55edbbc Test 2018-04-20 13:25:22 +03:00
jl777
7b025a4790 Test 2018-04-20 13:24:48 +03:00
jl777
dd66e3af3a Test 2018-04-20 13:20:26 +03:00
jl777
e16d22ee0f Test 2018-04-20 13:13:18 +03:00
jl777
9464ac21bc Test 2018-04-20 13:03:27 +03:00
jl777
66dd02d288 Test 2018-04-20 12:32:39 +03:00
jl777
7377cedcf6 Test 2018-04-20 00:40:03 +03:00
jl777
65b4e8809d Test 2018-04-20 00:39:38 +03:00
jl777
d07308d221 Test 2018-04-19 20:59:03 +03:00
jl777
d9935f2b61 Test 2018-04-19 20:54:47 +03:00
jl777
b509fdae14 Test 2018-04-19 16:27:54 +03:00
jl777
7bb789bb66 Test 2018-04-19 16:03:51 +03:00
jl777
af0c41ee3d Test 2018-04-19 15:55:17 +03:00
jl777
bf30e02d79 Test 2018-04-19 15:53:28 +03:00
jl777
997ddd92c7 Test 2018-04-19 15:44:56 +03:00
jl777
eff2c3a35a Test 2018-04-19 15:43:39 +03:00
jl777
286d95b1df Test 2018-04-19 15:38:34 +03:00
jl777
c21c630657 Test 2018-04-19 15:33:36 +03:00
jl777
2ae7e0b5fa Test 2018-04-19 15:19:58 +03:00
jl777
18dd6a3b58 Test 2018-04-19 15:12:19 +03:00
jl777
bb3ab99ac0 Test 2018-04-19 14:50:22 +03:00
jl777
8fbee9292d Test 2018-04-19 14:17:47 +03:00
jl777
f8f740a966 Test 2018-04-19 14:10:25 +03:00
jl777
18443f692d Cleanup assetchains mining options 2018-04-19 13:59:36 +03:00
jl777
02c30aac1e Test 2018-04-18 22:39:53 +03:00
jl777
44b34dfba5 Test 2018-04-18 22:37:07 +03:00
jl777
98a5a298ed Test 2018-04-18 22:35:24 +03:00
jl777
3fdbd5bf82 Test 2018-04-18 22:23:10 +03:00
jl777
23fc88bbda Test 2018-04-18 22:18:40 +03:00
jl777
aea2d1aadd Test 2018-04-18 22:12:00 +03:00
jl777
a9550b923b Test 2018-04-18 22:07:22 +03:00
jl777
f8ef6ca931 Test 2018-04-18 22:03:29 +03:00
jl777
178273cf24 Test 2018-04-18 22:02:25 +03:00
jl777
3a443f3378 -print 2018-04-18 14:45:08 +03:00
jl777
7213e636c1 Merge branch 'dev' into jl777 2018-04-17 23:28:32 +03:00
jl777
32b915c93d test 2018-04-17 10:24:56 +03:00
jl777
eec7c7822b Test 2018-04-16 23:36:08 +03:00
jl777
5afd0f5da3 Test 2018-04-16 23:26:51 +03:00
jl777
091240c1c2 Test 2018-04-16 23:20:46 +03:00
jl777
79d6d16cfc Test 2018-04-16 23:06:03 +03:00