consensus/ethash: close mmap before rename, windows limitation

pull/14329/head
Péter Szilágyi 8 years ago
parent ee05cc4a27
commit 65e1095c3f
No known key found for this signature in database
GPG Key ID: E9AE538CEDF8293D
  1. 13
      consensus/ethash/ethash.go

@ -130,13 +130,16 @@ func memoryMapAndGenerate(path string, size uint64, generator func(buffer []uint
data := buffer[len(dumpMagic):] data := buffer[len(dumpMagic):]
generator(data) generator(data)
if err := mem.Flush(); err != nil { if err := mem.Unmap(); err != nil {
mem.Unmap() return nil, nil, nil, err
dump.Close() }
if err := dump.Close(); err != nil {
return nil, nil, nil, err
}
if err := os.Rename(temp, path); err != nil {
return nil, nil, nil, err return nil, nil, nil, err
} }
os.Rename(temp, path) return memoryMap(path)
return dump, mem, data, nil
} }
// cache wraps an ethash cache with some metadata to allow easier concurrent use. // cache wraps an ethash cache with some metadata to allow easier concurrent use.

Loading…
Cancel
Save