|
@ -105,23 +105,18 @@ void EthashAux::killCache(h256 const& _s) |
|
|
m_lights.erase(_s); |
|
|
m_lights.erase(_s); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
EthashAux::LightType EthashAux::light(BlockInfo const& _header) |
|
|
EthashAux::LightType EthashAux::light(h256 const& _seedHash) |
|
|
{ |
|
|
|
|
|
return light((uint64_t)_header.number); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
EthashAux::LightType EthashAux::light(uint64_t _blockNumber) |
|
|
|
|
|
{ |
|
|
{ |
|
|
RecursiveGuard l(get()->x_lights); |
|
|
RecursiveGuard l(get()->x_lights); |
|
|
h256 seedHash = EthashAux::seedHash(_blockNumber); |
|
|
LightType ret = get()->m_lights[_seedHash]; |
|
|
LightType ret = get()->m_lights[seedHash]; |
|
|
return ret ? ret : (get()->m_lights[_seedHash] = make_shared<LightAllocation>(_seedHash)); |
|
|
return ret ? ret : (get()->m_lights[seedHash] = make_shared<LightAllocation>(_blockNumber)); |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
EthashAux::LightAllocation::LightAllocation(uint64_t _blockNumber) |
|
|
EthashAux::LightAllocation::LightAllocation(h256 const& _seedHash) |
|
|
{ |
|
|
{ |
|
|
light = ethash_light_new(_blockNumber); |
|
|
uint64_t blockNumber = EthashAux::number(_seedHash); |
|
|
size = ethash_get_cachesize(_blockNumber); |
|
|
light = ethash_light_new(blockNumber); |
|
|
|
|
|
size = ethash_get_cachesize(blockNumber); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
EthashAux::LightAllocation::~LightAllocation() |
|
|
EthashAux::LightAllocation::~LightAllocation() |
|
@ -156,14 +151,13 @@ static int dagCallbackShim(unsigned _p) |
|
|
return s_dagCallback ? s_dagCallback(_p) : 0; |
|
|
return s_dagCallback ? s_dagCallback(_p) : 0; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
EthashAux::FullType EthashAux::full(uint64_t _blockNumber, function<int(unsigned)> const& _f) |
|
|
EthashAux::FullType EthashAux::full(h256 const& _seedHash, function<int(unsigned)> const& _f) |
|
|
{ |
|
|
{ |
|
|
auto l = light(_blockNumber); |
|
|
|
|
|
h256 seedHash = EthashAux::seedHash(_blockNumber); |
|
|
|
|
|
FullType ret; |
|
|
FullType ret; |
|
|
|
|
|
auto l = light(_seedHash); |
|
|
|
|
|
|
|
|
DEV_GUARDED(get()->x_fulls) |
|
|
DEV_GUARDED(get()->x_fulls) |
|
|
if ((ret = get()->m_fulls[seedHash].lock())) |
|
|
if ((ret = get()->m_fulls[_seedHash].lock())) |
|
|
{ |
|
|
{ |
|
|
get()->m_lastUsedFull = ret; |
|
|
get()->m_lastUsedFull = ret; |
|
|
return ret; |
|
|
return ret; |
|
@ -175,15 +169,15 @@ EthashAux::FullType EthashAux::full(uint64_t _blockNumber, function<int(unsigned |
|
|
cnote << "Done loading."; |
|
|
cnote << "Done loading."; |
|
|
|
|
|
|
|
|
DEV_GUARDED(get()->x_fulls) |
|
|
DEV_GUARDED(get()->x_fulls) |
|
|
get()->m_fulls[seedHash] = get()->m_lastUsedFull = ret; |
|
|
get()->m_fulls[_seedHash] = get()->m_lastUsedFull = ret; |
|
|
return ret; |
|
|
return ret; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
unsigned EthashAux::computeFull(uint64_t _blockNumber) |
|
|
unsigned EthashAux::computeFull(h256 const& _seedHash) |
|
|
{ |
|
|
{ |
|
|
Guard l(get()->x_fulls); |
|
|
Guard l(get()->x_fulls); |
|
|
h256 seedHash = EthashAux::seedHash(_blockNumber); |
|
|
uint64_t blockNumber = EthashAux::number(_seedHash); |
|
|
if (FullType ret = get()->m_fulls[seedHash].lock()) |
|
|
if (FullType ret = get()->m_fulls[_seedHash].lock()) |
|
|
{ |
|
|
{ |
|
|
get()->m_lastUsedFull = ret; |
|
|
get()->m_lastUsedFull = ret; |
|
|
return 100; |
|
|
return 100; |
|
@ -192,17 +186,17 @@ unsigned EthashAux::computeFull(uint64_t _blockNumber) |
|
|
if (!get()->m_fullGenerator || !get()->m_fullGenerator->joinable()) |
|
|
if (!get()->m_fullGenerator || !get()->m_fullGenerator->joinable()) |
|
|
{ |
|
|
{ |
|
|
get()->m_fullProgress = 0; |
|
|
get()->m_fullProgress = 0; |
|
|
get()->m_generatingFullNumber = _blockNumber / ETHASH_EPOCH_LENGTH * ETHASH_EPOCH_LENGTH; |
|
|
get()->m_generatingFullNumber = blockNumber / ETHASH_EPOCH_LENGTH * ETHASH_EPOCH_LENGTH; |
|
|
get()->m_fullGenerator = unique_ptr<thread>(new thread([=](){ |
|
|
get()->m_fullGenerator = unique_ptr<thread>(new thread([=](){ |
|
|
cnote << "Loading full DAG of" << _blockNumber; |
|
|
cnote << "Loading full DAG of seedhash: " << _seedHash; |
|
|
get()->full(_blockNumber, [](unsigned p){ get()->m_fullProgress = p; return 0; }); |
|
|
get()->full(_seedHash, [](unsigned p){ get()->m_fullProgress = p; return 0; }); |
|
|
cnote << "Full DAG loaded"; |
|
|
cnote << "Full DAG loaded"; |
|
|
get()->m_fullProgress = 0; |
|
|
get()->m_fullProgress = 0; |
|
|
get()->m_generatingFullNumber = NotGenerating; |
|
|
get()->m_generatingFullNumber = NotGenerating; |
|
|
})); |
|
|
})); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
return (get()->m_generatingFullNumber == _blockNumber) ? get()->m_fullProgress : 0; |
|
|
return (get()->m_generatingFullNumber == blockNumber) ? get()->m_fullProgress : 0; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
Ethash::Result EthashAux::FullAllocation::compute(h256 const& _headerHash, Nonce const& _nonce) const |
|
|
Ethash::Result EthashAux::FullAllocation::compute(h256 const& _headerHash, Nonce const& _nonce) const |
|
@ -223,13 +217,12 @@ Ethash::Result EthashAux::LightAllocation::compute(h256 const& _headerHash, Nonc |
|
|
|
|
|
|
|
|
Ethash::Result EthashAux::eval(BlockInfo const& _header, Nonce const& _nonce) |
|
|
Ethash::Result EthashAux::eval(BlockInfo const& _header, Nonce const& _nonce) |
|
|
{ |
|
|
{ |
|
|
return eval((uint64_t)_header.number, _header.headerHash(WithoutNonce), _nonce); |
|
|
return eval(_header.seedHash(), _header.headerHash(WithoutNonce), _nonce); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
Ethash::Result EthashAux::eval(uint64_t _blockNumber, h256 const& _headerHash, Nonce const& _nonce) |
|
|
Ethash::Result EthashAux::eval(h256 const& _seedHash, h256 const& _headerHash, Nonce const& _nonce) |
|
|
{ |
|
|
{ |
|
|
h256 seedHash = EthashAux::seedHash(_blockNumber); |
|
|
if (FullType dag = get()->m_fulls[_seedHash].lock()) |
|
|
if (FullType dag = get()->m_fulls[seedHash].lock()) |
|
|
|
|
|
return dag->compute(_headerHash, _nonce); |
|
|
return dag->compute(_headerHash, _nonce); |
|
|
return EthashAux::get()->light(_blockNumber)->compute(_headerHash, _nonce); |
|
|
return EthashAux::get()->light(_seedHash)->compute(_headerHash, _nonce); |
|
|
} |
|
|
} |
|
|