Browse Source

ethminer no longer depends on boost

Introducing an extra boolean argument to remove the boost::optional
dependency. Too bad we have to wait for C++17 to get an std::optional
cl-refactor
Lefteris Karapetsas 10 years ago
parent
commit
1863def3a1
  1. 6
      ethminer/MinerAux.h
  2. 5
      libethash-cl/ethash_cl_miner.cpp
  3. 4
      libethash-cl/ethash_cl_miner.h
  4. 4
      libethcore/Ethash.cpp
  5. 5
      libethcore/Ethash.h

6
ethminer/MinerAux.h

@ -211,7 +211,10 @@ public:
else if (arg == "-G" || arg == "--opencl") else if (arg == "-G" || arg == "--opencl")
m_minerType = MinerType::GPU; m_minerType = MinerType::GPU;
else if (arg == "--current-block" && i + 1 < argc) else if (arg == "--current-block" && i + 1 < argc)
{
m_currentBlock = stol(argv[++i]); m_currentBlock = stol(argv[++i]);
m_currentBlockGiven = true;
}
else if (arg == "--no-precompute") else if (arg == "--no-precompute")
{ {
m_precompute = false; m_precompute = false;
@ -306,6 +309,7 @@ public:
m_openclDevice, m_openclDevice,
m_clAllowCPU, m_clAllowCPU,
m_extraGPUMemory, m_extraGPUMemory,
m_currentBlockGiven,
m_currentBlock m_currentBlock
)) ))
exit(1); exit(1);
@ -553,7 +557,7 @@ private:
unsigned m_localWorkSize = ethash_cl_miner::c_defaultLocalWorkSize; unsigned m_localWorkSize = ethash_cl_miner::c_defaultLocalWorkSize;
unsigned m_msPerBatch = ethash_cl_miner::c_defaultMSPerBatch; unsigned m_msPerBatch = ethash_cl_miner::c_defaultMSPerBatch;
#endif #endif
boost::optional<uint64_t> m_currentBlock; uint64_t m_currentBlock = 0;
// default value is 350MB of GPU memory for other stuff (windows system rendering, e.t.c.) // default value is 350MB of GPU memory for other stuff (windows system rendering, e.t.c.)
unsigned m_extraGPUMemory = 350000000; unsigned m_extraGPUMemory = 350000000;

5
libethash-cl/ethash_cl_miner.cpp

@ -149,7 +149,8 @@ bool ethash_cl_miner::configureGPU(
unsigned _msPerBatch, unsigned _msPerBatch,
bool _allowCPU, bool _allowCPU,
unsigned _extraGPUMemory, unsigned _extraGPUMemory,
boost::optional<uint64_t> _currentBlock bool _currentBlockGiven,
uint64_t _currentBlock
) )
{ {
s_workgroupSize = _localWorkSize; s_workgroupSize = _localWorkSize;
@ -158,7 +159,7 @@ bool ethash_cl_miner::configureGPU(
s_allowCPU = _allowCPU; s_allowCPU = _allowCPU;
s_extraRequiredGPUMem = _extraGPUMemory; s_extraRequiredGPUMem = _extraGPUMemory;
// by default let's only consider the DAG of the first epoch // by default let's only consider the DAG of the first epoch
uint64_t dagSize = _currentBlock ? ethash_get_datasize(*_currentBlock) : 1073739904U; uint64_t dagSize = _currentBlockGiven ? ethash_get_datasize(_currentBlock) : 1073739904U;
uint64_t requiredSize = dagSize + _extraGPUMemory; uint64_t requiredSize = dagSize + _extraGPUMemory;
return searchForAllDevices(_platformId, [&requiredSize](cl::Device const _device) -> bool return searchForAllDevices(_platformId, [&requiredSize](cl::Device const _device) -> bool
{ {

4
libethash-cl/ethash_cl_miner.h

@ -12,7 +12,6 @@
#include "cl.hpp" #include "cl.hpp"
#endif #endif
#include <boost/optional.hpp>
#include <time.h> #include <time.h>
#include <functional> #include <functional>
#include <libethash/ethash.h> #include <libethash/ethash.h>
@ -50,7 +49,8 @@ public:
unsigned _msPerBatch, unsigned _msPerBatch,
bool _allowCPU, bool _allowCPU,
unsigned _extraGPUMemory, unsigned _extraGPUMemory,
boost::optional<uint64_t> _currentBlock bool _currentBlockGiven,
uint64_t _currentBlock
); );
bool init( bool init(

4
libethcore/Ethash.cpp

@ -416,7 +416,8 @@ bool Ethash::GPUMiner::configureGPU(
unsigned _deviceId, unsigned _deviceId,
bool _allowCPU, bool _allowCPU,
unsigned _extraGPUMemory, unsigned _extraGPUMemory,
boost::optional<uint64_t> _currentBlock bool _currentBlockGiven,
uint64_t _currentBlock
) )
{ {
s_platformId = _platformId; s_platformId = _platformId;
@ -435,6 +436,7 @@ bool Ethash::GPUMiner::configureGPU(
_msPerBatch, _msPerBatch,
_allowCPU, _allowCPU,
_extraGPUMemory, _extraGPUMemory,
_currentBlockGiven,
_currentBlock) _currentBlock)
) )
{ {

5
libethcore/Ethash.h

@ -88,7 +88,7 @@ public:
static unsigned instances() { return s_numInstances > 0 ? s_numInstances : std::thread::hardware_concurrency(); } static unsigned instances() { return s_numInstances > 0 ? s_numInstances : std::thread::hardware_concurrency(); }
static std::string platformInfo(); static std::string platformInfo();
static void listDevices() {} static void listDevices() {}
static bool configureGPU(unsigned, unsigned, unsigned, unsigned, unsigned, bool, unsigned, boost::optional<uint64_t>) { return false; } static bool configureGPU(unsigned, unsigned, unsigned, unsigned, unsigned, bool, unsigned, bool, uint64_t) { return false; }
static void setNumInstances(unsigned _instances) { s_numInstances = std::min<unsigned>(_instances, std::thread::hardware_concurrency()); } static void setNumInstances(unsigned _instances) { s_numInstances = std::min<unsigned>(_instances, std::thread::hardware_concurrency()); }
protected: protected:
void kickOff() override void kickOff() override
@ -125,7 +125,8 @@ public:
unsigned _deviceId, unsigned _deviceId,
bool _allowCPU, bool _allowCPU,
unsigned _extraGPUMemory, unsigned _extraGPUMemory,
boost::optional<uint64_t> _currentBlock bool _currentBlockGiven,
uint64_t _currentBlock
); );
static void setNumInstances(unsigned _instances) { s_numInstances = std::min<unsigned>(_instances, getNumDevices()); } static void setNumInstances(unsigned _instances) { s_numInstances = std::min<unsigned>(_instances, getNumDevices()); }

Loading…
Cancel
Save