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>2018-12-19 20:54:27 +0800
commit601a0810c5372785797f7384fda057a9d1861138 (patch)
tree5d0707599b2b1c1deb1ecb238043a4e889c8422c /core
parentd745eca535276a5553837afe937fae1a2fff60eb (diff)
downloaddexon-601a0810c5372785797f7384fda057a9d1861138.tar
dexon-601a0810c5372785797f7384fda057a9d1861138.tar.gz
dexon-601a0810c5372785797f7384fda057a9d1861138.tar.bz2
dexon-601a0810c5372785797f7384fda057a9d1861138.tar.lz
dexon-601a0810c5372785797f7384fda057a9d1861138.tar.xz
dexon-601a0810c5372785797f7384fda057a9d1861138.tar.zst
dexon-601a0810c5372785797f7384fda057a9d1861138.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 149808ff0..afb9dfc2e 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)