Quellcode durchsuchen

consensus/ethash: close mmap before rename, windows limitation

Péter Szilágyi vor 8 Jahren
Ursprung
Commit
65e1095c3f
1 geänderte Dateien mit 8 neuen und 5 gelöschten Zeilen
  1. 8 5
      consensus/ethash/ethash.go

+ 8 - 5
consensus/ethash/ethash.go

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