2018-06-23 10:57:34 +02:00
|
|
|
import sys
|
|
|
|
import os.path
|
|
|
|
import platform
|
|
|
|
import subprocess
|
|
|
|
import ctypes
|
|
|
|
|
2018-06-23 12:32:05 +02:00
|
|
|
class FastSolverError(Exception):
|
2018-06-23 12:42:01 +02:00
|
|
|
pass
|
2018-06-23 12:32:05 +02:00
|
|
|
|
2018-06-23 10:57:34 +02:00
|
|
|
def loadFastSolver(codePath):
|
|
|
|
if hasattr(sys, "winver"):
|
|
|
|
suffix = "-32"
|
|
|
|
|
|
|
|
if platform.architecture()[0] == "64bit":
|
|
|
|
suffix = "-64"
|
|
|
|
|
|
|
|
path = os.path.join(codePath, "fastsolver/libfastsolver{}.dll".format(suffix))
|
|
|
|
|
2018-06-23 12:32:05 +02:00
|
|
|
try:
|
|
|
|
return ctypes.WinDLL(path)
|
|
|
|
except:
|
|
|
|
raise FastSolverError()
|
2018-06-23 10:57:34 +02:00
|
|
|
|
|
|
|
makePath = os.path.join(codePath, "fastsolver")
|
|
|
|
path = os.path.join(codePath, "fastsolver/libfastsolver.so")
|
|
|
|
|
|
|
|
try:
|
|
|
|
return ctypes.CDLL(path)
|
|
|
|
except:
|
2018-06-23 12:32:05 +02:00
|
|
|
if hasattr(sys, "frozen"):
|
|
|
|
raise FastSolverError()
|
|
|
|
|
|
|
|
try:
|
2018-06-23 10:57:34 +02:00
|
|
|
subprocess.call(["make", "-C", makePath])
|
|
|
|
|
|
|
|
return ctypes.CDLL(path)
|
2018-06-23 12:32:05 +02:00
|
|
|
except:
|
|
|
|
raise FastSolverError()
|
2018-06-23 10:57:34 +02:00
|
|
|
|
|
|
|
class FastSolver(object):
|
|
|
|
def __init__(self, codePath):
|
|
|
|
self.libfastsolver = loadFastSolver(codePath)
|
|
|
|
|
|
|
|
self.libfastsolver.fastsolver_add.restype = ctypes.c_size_t
|
|
|
|
self.libfastsolver.fastsolver_add.argtypes = []
|
|
|
|
|
|
|
|
self.libfastsolver.fastsolver_remove.restype = ctypes.c_size_t
|
|
|
|
self.libfastsolver.fastsolver_remove.argtypes = [ctypes.c_size_t]
|
|
|
|
|
|
|
|
self.libfastsolver.fastsolver_search.restype = ctypes.c_int
|
|
|
|
|
|
|
|
self.libfastsolver.fastsolver_search.argtypes = [
|
|
|
|
ctypes.c_void_p, ctypes.c_void_p,
|
|
|
|
ctypes.c_void_p, ctypes.c_ulonglong, ctypes.c_void_p, ctypes.c_ulonglong
|
|
|
|
]
|
|
|
|
|
|
|
|
self.nonce = ctypes.create_string_buffer(8)
|
|
|
|
self.iterationsCount = ctypes.c_ulonglong()
|
|
|
|
|
|
|
|
self.parallelism = 0
|
|
|
|
|
|
|
|
def search(self, initialHash, target, seed, timeout):
|
|
|
|
found = self.libfastsolver.fastsolver_search(
|
|
|
|
self.nonce, ctypes.byref(self.iterationsCount),
|
|
|
|
initialHash, target, seed, long(1000000000 * timeout)
|
|
|
|
)
|
|
|
|
|
|
|
|
if found == 1:
|
|
|
|
return self.nonce.raw, self.iterationsCount.value
|
|
|
|
else:
|
|
|
|
return None, self.iterationsCount.value
|
|
|
|
|
|
|
|
def setParallelism(self, parallelism):
|
|
|
|
parallelism = min(4096, parallelism)
|
|
|
|
|
|
|
|
for i in xrange(self.parallelism, parallelism):
|
|
|
|
self.parallelism = self.libfastsolver.fastsolver_add()
|
|
|
|
|
|
|
|
if parallelism < self.parallelism:
|
|
|
|
self.parallelism = self.libfastsolver.fastsolver_remove(self.parallelism - parallelism)
|