aboutsummaryrefslogtreecommitdiffstats
path: root/core
diff options
context:
space:
mode:
authorJimmy Hu <jimmy.hu@dexon.org>2018-12-04 14:54:28 +0800
committerWei-Ning Huang <w@dexon.org>2019-04-09 13:49:58 +0800
commit85a4531d7398e0b1bee70ca8c2e0651483f9fc14 (patch)
tree6bdd32044e6e7f28535547300aeb859147abe58f /core
parent80ceaf38a584e4275b6ae163bfdce47f6df59d64 (diff)
downloaddexon-85a4531d7398e0b1bee70ca8c2e0651483f9fc14.tar
dexon-85a4531d7398e0b1bee70ca8c2e0651483f9fc14.tar.gz
dexon-85a4531d7398e0b1bee70ca8c2e0651483f9fc14.tar.bz2
dexon-85a4531d7398e0b1bee70ca8c2e0651483f9fc14.tar.lz
dexon-85a4531d7398e0b1bee70ca8c2e0651483f9fc14.tar.xz
dexon-85a4531d7398e0b1bee70ca8c2e0651483f9fc14.tar.zst
dexon-85a4531d7398e0b1bee70ca8c2e0651483f9fc14.zip
core, dex: Timeout for prepare payload (#72)
* Timeout on prepare payload * Leave 2 CPU for others * Add hardLimit and softLimit to PreparePayload
Diffstat (limited to 'core')
-rw-r--r--core/blockchain.go16
-rw-r--r--core/types/transaction_signing.go5
2 files changed, 13 insertions, 8 deletions
diff --git a/core/blockchain.go b/core/blockchain.go
index 470f7ae28..1b3b22e5e 100644
--- a/core/blockchain.go
+++ b/core/blockchain.go
@@ -270,13 +270,15 @@ func (bc *BlockChain) AddConfirmedBlock(block *coreTypes.Block) error {
bc.confirmedBlockInitMu.Unlock()
var transactions types.Transactions
- err := rlp.Decode(bytes.NewReader(block.Payload), &transactions)
- if err != nil {
- return err
- }
- _, err = types.GlobalSigCache.Add(types.NewEIP155Signer(bc.Config().ChainID), transactions)
- if err != nil {
- return err
+ if len(block.Payload) != 0 {
+ err := rlp.Decode(bytes.NewReader(block.Payload), &transactions)
+ if err != nil {
+ return err
+ }
+ _, err = types.GlobalSigCache.Add(types.NewEIP155Signer(bc.Config().ChainID), transactions)
+ if err != nil {
+ return err
+ }
}
addressMap := map[common.Address]struct{}{}
diff --git a/core/types/transaction_signing.go b/core/types/transaction_signing.go
index 99e0c7896..1a13e3e3d 100644
--- a/core/types/transaction_signing.go
+++ b/core/types/transaction_signing.go
@@ -60,7 +60,10 @@ type resultEntry struct {
// Add adds a list of transactions into sig cache.
func (c *globalSigCache) Add(signer Signer, txs Transactions) (errorTx *Transaction, err error) {
- num := runtime.NumCPU()
+ num := runtime.NumCPU() - 2
+ if num < 1 {
+ num = 1
+ }
batchSize := len(txs) / num
wg := sync.WaitGroup{}
wg.Add(num)