Переглянути джерело

consensus/ethash: close mmap before rename, windows limitation

Péter Szilágyi 8 роки тому
батько
коміт
65e1095c3f
1 змінених файлів з 8 додано та 5 видалено
  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.