Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
G
Geth-Modification
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
张蕾
Geth-Modification
Commits
b99fe27f
Commit
b99fe27f
authored
Sep 29, 2015
by
Péter Szilágyi
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
core: fix block canonical mark / content write race
parent
f186b390
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
11 additions
and
20 deletions
+11
-20
blockchain.go
core/blockchain.go
+11
-20
No files found.
core/blockchain.go
View file @
b99fe27f
...
@@ -601,7 +601,7 @@ func (self *BlockChain) writeHeader(header *types.Header) error {
...
@@ -601,7 +601,7 @@ func (self *BlockChain) writeHeader(header *types.Header) error {
}
}
// InsertHeaderChain will attempt to insert the given header chain in to the
// InsertHeaderChain will attempt to insert the given header chain in to the
// local chain, possibly creating a
d
ork. If an error is returned, it will
// local chain, possibly creating a
f
ork. If an error is returned, it will
// return the index number of the failing header as well an error describing
// return the index number of the failing header as well an error describing
// what went wrong.
// what went wrong.
//
//
...
@@ -686,37 +686,31 @@ func (self *BlockChain) WriteBlock(block *types.Block) (status writeStatus, err
...
@@ -686,37 +686,31 @@ func (self *BlockChain) WriteBlock(block *types.Block) (status writeStatus, err
}
}
td
:=
new
(
big
.
Int
)
.
Add
(
block
.
Difficulty
(),
ptd
)
td
:=
new
(
big
.
Int
)
.
Add
(
block
.
Difficulty
(),
ptd
)
self
.
mu
.
RLock
()
// Make sure no inconsistent state is leaked during insertion
cblock
:=
self
.
currentBlock
self
.
mu
.
Lock
()
self
.
mu
.
R
Unlock
()
defer
self
.
mu
.
Unlock
()
// Compare the TD of the last known block in the canonical chain to make sure it's greater.
// If the total difficulty is higher than our known, add it to the canonical chain
// At this point it's possible that a different chain (fork) becomes the new canonical chain.
if
td
.
Cmp
(
self
.
GetTd
(
self
.
currentBlock
.
Hash
()))
>
0
{
if
td
.
Cmp
(
self
.
GetTd
(
self
.
currentBlock
.
Hash
()))
>
0
{
// chain fork
// Reorganize the chain if the parent is not the head block
if
block
.
ParentHash
()
!=
cblock
.
Hash
()
{
if
block
.
ParentHash
()
!=
self
.
currentBlock
.
Hash
()
{
// during split we merge two different chains and create the new canonical chain
if
err
:=
self
.
reorg
(
self
.
currentBlock
,
block
);
err
!=
nil
{
err
:=
self
.
reorg
(
cblock
,
block
)
if
err
!=
nil
{
return
NonStatTy
,
err
return
NonStatTy
,
err
}
}
}
}
status
=
CanonStatTy
// Insert the block as the new head of the chain
self
.
mu
.
Lock
()
self
.
insert
(
block
)
self
.
insert
(
block
)
s
elf
.
mu
.
Unlock
()
s
tatus
=
CanonStatTy
}
else
{
}
else
{
status
=
SideStatTy
status
=
SideStatTy
}
}
// Irrelevant of the canonical status, write the block itself to the database
if
err
:=
WriteTd
(
self
.
chainDb
,
block
.
Hash
(),
td
);
err
!=
nil
{
if
err
:=
WriteTd
(
self
.
chainDb
,
block
.
Hash
(),
td
);
err
!=
nil
{
glog
.
Fatalf
(
"failed to write block total difficulty: %v"
,
err
)
glog
.
Fatalf
(
"failed to write block total difficulty: %v"
,
err
)
}
}
if
err
:=
WriteBlock
(
self
.
chainDb
,
block
);
err
!=
nil
{
if
err
:=
WriteBlock
(
self
.
chainDb
,
block
);
err
!=
nil
{
glog
.
Fatalf
(
"filed to write block contents: %v"
,
err
)
glog
.
Fatalf
(
"filed to write block contents: %v"
,
err
)
}
}
// Delete from future blocks
self
.
futureBlocks
.
Remove
(
block
.
Hash
())
self
.
futureBlocks
.
Remove
(
block
.
Hash
())
return
return
...
@@ -860,9 +854,6 @@ func (self *BlockChain) InsertChain(chain types.Blocks) (int, error) {
...
@@ -860,9 +854,6 @@ func (self *BlockChain) InsertChain(chain types.Blocks) (int, error) {
// to be part of the new canonical chain and accumulates potential missing transactions and post an
// to be part of the new canonical chain and accumulates potential missing transactions and post an
// event about them
// event about them
func
(
self
*
BlockChain
)
reorg
(
oldBlock
,
newBlock
*
types
.
Block
)
error
{
func
(
self
*
BlockChain
)
reorg
(
oldBlock
,
newBlock
*
types
.
Block
)
error
{
self
.
mu
.
Lock
()
defer
self
.
mu
.
Unlock
()
var
(
var
(
newChain
types
.
Blocks
newChain
types
.
Blocks
commonBlock
*
types
.
Block
commonBlock
*
types
.
Block
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment