diff options
author | Martin Holst Swende <martin@swende.se> | 2017-09-08 18:47:44 +0800 |
---|---|---|
committer | Martin Holst Swende <martin@swende.se> | 2017-09-08 18:47:44 +0800 |
commit | d6681ed36037c48bc95c7940e9914b9369e35170 (patch) | |
tree | 40af9cfdf8dcfc18a257ea7311d28ca5e1a9524b | |
parent | 54b1de67e2cbe700a4086d33b10501578dbeaaaf (diff) | |
download | dexon-d6681ed36037c48bc95c7940e9914b9369e35170.tar dexon-d6681ed36037c48bc95c7940e9914b9369e35170.tar.gz dexon-d6681ed36037c48bc95c7940e9914b9369e35170.tar.bz2 dexon-d6681ed36037c48bc95c7940e9914b9369e35170.tar.lz dexon-d6681ed36037c48bc95c7940e9914b9369e35170.tar.xz dexon-d6681ed36037c48bc95c7940e9914b9369e35170.tar.zst dexon-d6681ed36037c48bc95c7940e9914b9369e35170.zip |
core/vm: Rename + updated doc on jumpdest analysis
-rw-r--r-- | core/vm/analysis.go | 8 | ||||
-rw-r--r-- | core/vm/analysis_test.go | 2 |
2 files changed, 5 insertions, 5 deletions
diff --git a/core/vm/analysis.go b/core/vm/analysis.go index 08415fc1e..e6a2df7b0 100644 --- a/core/vm/analysis.go +++ b/core/vm/analysis.go @@ -38,7 +38,7 @@ func (d destinations) has(codehash common.Hash, code []byte, dest *big.Int) bool m, analysed := d[codehash] if !analysed { - m = jumpdests(code) + m = codeBitmap(code) d[codehash] = m } return OpCode(code[udest]) == JUMPDEST && m.codeSegment(udest) @@ -61,9 +61,9 @@ func (bits *bitvec) codeSegment(pos uint64) bool { return ((*bits)[pos/8] & (0x80 >> (pos % 8))) == 0 } -// jumpdests creates a map that contains an entry for each -// PC location that is a JUMPDEST instruction. -func jumpdests(code []byte) []byte { +// jumpdests creates a bitmap of the code, where 1 represents a DATA-segment, +// and 0 represents code-segment +func codeBitmap(code []byte) []byte { //The map is 4 bytes longer than necessary, in case the code // ends with a PUSH32, the algorithm will push zeroes onto the // bitvector outside the bounds of the actual code. diff --git a/core/vm/analysis_test.go b/core/vm/analysis_test.go index 17c578e95..3d4e709db 100644 --- a/core/vm/analysis_test.go +++ b/core/vm/analysis_test.go @@ -28,7 +28,7 @@ func TestJumpDestAnalysis(t *testing.T) { {[]byte{byte(PUSH32)}, 0xFF, 2}, } for _, test := range tests { - ret := jumpdests(test.code) + ret := codeBitmap(test.code) if ret[test.which] != test.exp { t.Fatalf("expected %x, got %02x", test.exp, ret[test.which]) } |