Browse Source

working stratum miner (coinotron)

cl-refactor
Jan Willem Penterman 9 years ago
parent
commit
e92022a137
  1. 17
      ethminer/MinerAux.h
  2. 68
      libstratum/EthStratumClient.cpp
  3. 2
      libstratum/EthStratumClient.h
  4. BIN
      releases/ethminer-0.9.41-genoil-10.0.4.zip

17
ethminer/MinerAux.h

@ -133,7 +133,7 @@ public:
BOOST_THROW_EXCEPTION(BadArgument()); BOOST_THROW_EXCEPTION(BadArgument());
} }
#if ETH_STRATUM || !ETH_TRUE #if ETH_STRATUM || !ETH_TRUE
if ((arg == "-S" || arg == "--stratum") && i + 1 < argc) else if ((arg == "-S" || arg == "--stratum") && i + 1 < argc)
{ {
mode = OperationMode::Stratum; mode = OperationMode::Stratum;
string url = string(argv[++i]); string url = string(argv[++i]);
@ -886,25 +886,22 @@ private:
EthStratumClient client(&f, host, port, user, pass); EthStratumClient client(&f, host, port, user, pass);
f.setSealers(sealers); f.setSealers(sealers);
/*
if (_m == MinerType::CPU) if (_m == MinerType::CPU)
f.start("cpu"); f.start("cpu");
else if (_m == MinerType::CL) else if (_m == MinerType::CL)
f.start("opencl"); f.start("opencl");
else if (_m == MinerType::CUDA) else if (_m == MinerType::CUDA)
f.start("cuda"); f.start("cuda");
*/
bool completed = false; bool completed = false;
EthashProofOfWork::Solution solution;
/*
f.onSolutionFound([&](EthashProofOfWork::Solution sol) f.onSolutionFound([&](EthashProofOfWork::Solution sol)
{ {
solution = sol; client.submit(sol);
minelog << "Solution!";
client.submit(solution);
return false; return false;
}); });
*/
while (client.isRunning()) while (client.isRunning())
{ {
auto mp = f.miningProgress(); auto mp = f.miningProgress();
@ -912,7 +909,7 @@ private:
if (client.current()) if (client.current())
minelog << "Mining on PoWhash" << client.currentHeaderHash() << ": " << mp; minelog << "Mining on PoWhash" << client.currentHeaderHash() << ": " << mp;
else else
minelog << "Getting work package..."; minelog << "Waiting for work package...";
this_thread::sleep_for(chrono::milliseconds(_recheckPeriod)); this_thread::sleep_for(chrono::milliseconds(_recheckPeriod));
} }

68
libstratum/EthStratumClient.cpp

@ -14,6 +14,7 @@ EthStratumClient::EthStratumClient(GenericFarm<EthashProofOfWork> * f, string co
m_authorized = false; m_authorized = false;
m_running = true; m_running = true;
m_precompute = true; m_precompute = true;
m_pending = 0;
p_farm = f; p_farm = f;
connect(); connect();
} }
@ -82,13 +83,20 @@ void EthStratumClient::connect_handler(const boost::system::error_code& ec, tcp:
} }
void EthStratumClient::handleResponse(const boost::system::error_code& ec) { void EthStratumClient::readline() {
if (!ec)
{ if (m_pending == 0) {
async_read_until(m_socket, m_responseBuffer, "\n", async_read_until(m_socket, m_responseBuffer, "\n",
boost::bind(&EthStratumClient::readResponse, this, boost::bind(&EthStratumClient::readResponse, this,
boost::asio::placeholders::error, boost::asio::placeholders::bytes_transferred)); boost::asio::placeholders::error, boost::asio::placeholders::bytes_transferred));
m_pending++;
}
}
void EthStratumClient::handleResponse(const boost::system::error_code& ec) {
if (!ec)
{
readline();
} }
else else
{ {
@ -98,19 +106,13 @@ void EthStratumClient::handleResponse(const boost::system::error_code& ec) {
void EthStratumClient::readResponse(const boost::system::error_code& ec, std::size_t bytes_transferred) void EthStratumClient::readResponse(const boost::system::error_code& ec, std::size_t bytes_transferred)
{ {
m_pending = m_pending > 0 ? m_pending - 1 : 0;
if (!ec) if (!ec)
{ {
std::istream is(&m_responseBuffer); std::istream is(&m_responseBuffer);
std::string response; std::string response;
getline(is, response); getline(is, response);
cnote << response;
if (response.back() != '}') {
m_response = response;
}
if (response.front() != '{') {
response = m_response + response;
}
Json::Value responseObject; Json::Value responseObject;
Json::Reader reader; Json::Reader reader;
@ -129,9 +131,8 @@ void EthStratumClient::readResponse(const boost::system::error_code& ec, std::si
cwarn << "Read response failed: " << ec.message(); cwarn << "Read response failed: " << ec.message();
} }
async_read_until(m_socket, m_responseBuffer, "\n", readline();
boost::bind(&EthStratumClient::readResponse, this,
boost::asio::placeholders::error, boost::asio::placeholders::bytes_transferred));
} }
void EthStratumClient::processReponse(Json::Value& responseObject) void EthStratumClient::processReponse(Json::Value& responseObject)
@ -166,7 +167,11 @@ void EthStratumClient::processReponse(Json::Value& responseObject)
cnote << "Authorized worker " << m_user; cnote << "Authorized worker " << m_user;
break; break;
case 4: case 4:
cnote << m_response; if (responseObject.get("result", false).asBool())
cnote << "B-) Submitted and accepted.";
else
cwarn << ":-( Not accepted.";
break;
default: default:
string method = responseObject.get("method", "").asString(); string method = responseObject.get("method", "").asString();
if (method == "mining.notify") if (method == "mining.notify")
@ -201,7 +206,7 @@ void EthStratumClient::processReponse(Json::Value& responseObject)
{ {
m_current.headerHash = h256(sHeaderHash); m_current.headerHash = h256(sHeaderHash);
m_current.seedHash = seedHash; m_current.seedHash = seedHash;
m_current.boundary = h256(sShareTarget, h256::AlignRight); m_current.boundary = h256(sShareTarget);// , h256::AlignRight);
p_farm->setWork(m_current); p_farm->setWork(m_current);
} }
} }
@ -213,7 +218,7 @@ void EthStratumClient::processReponse(Json::Value& responseObject)
} }
else if (method == "client.get_version") else if (method == "client.get_version")
{ {
os << "{\"error\": null, \"id\" : " << id << ", \"result\" : \"" << ETH_PROJECT_VERSION << "\"}"; os << "{\"error\": null, \"id\" : " << id << ", \"result\" : \"" << ETH_PROJECT_VERSION << "\"}\n";
async_write(m_socket, m_requestBuffer, async_write(m_socket, m_requestBuffer,
boost::bind(&EthStratumClient::handleResponse, this, boost::bind(&EthStratumClient::handleResponse, this,
boost::asio::placeholders::error)); boost::asio::placeholders::error));
@ -223,11 +228,28 @@ void EthStratumClient::processReponse(Json::Value& responseObject)
} }
bool EthStratumClient::submit(EthashProofOfWork::Solution solution) { bool EthStratumClient::submit(EthashProofOfWork::Solution solution) {
std::ostream os(&m_requestBuffer);
os << "{\"id\": 4, \"method\": \"mining.submit\", \"params\": [\"" << m_user << "\",\"" << m_job << "\",\"" << solution.nonce.hex() << "\",\"" << m_current.headerHash.hex() << "\",\"" << solution.mixHash.hex() << "\"]}\n"; cnote << "Solution found; Submitting to" << m_host << "...";
async_write(m_socket, m_requestBuffer, cnote << " Nonce:" << solution.nonce.hex();
boost::bind(&EthStratumClient::handleResponse, this, cnote << " Mixhash:" << solution.mixHash.hex();
boost::asio::placeholders::error)); cnote << " Header-hash:" << m_current.headerHash.hex();
return true; cnote << " Seedhash:" << m_current.seedHash.hex();
cnote << " Target: " << h256(m_current.boundary).hex();
cnote << " Ethash: " << h256(EthashAux::eval(m_current.seedHash, m_current.headerHash, solution.nonce).value).hex();
if (EthashAux::eval(m_current.seedHash, m_current.headerHash, solution.nonce).value < m_current.boundary)
{
string json = "{\"id\": 4, \"method\": \"mining.submit\", \"params\": [\"" + m_user + "\",\"" + m_job + "\",\"0x" + solution.nonce.hex() + "\",\"0x" + m_current.headerHash.hex() + "\",\"0x" + solution.mixHash.hex() + "\"]}\n";
std::ostream os(&m_requestBuffer);
os << json;
async_write(m_socket, m_requestBuffer,
boost::bind(&EthStratumClient::handleResponse, this,
boost::asio::placeholders::error));
return true;
}
else
cwarn << "FAILURE: GPU gave incorrect result!";
return false;
} }

2
libstratum/EthStratumClient.h

@ -32,6 +32,7 @@ private:
void resolve_handler(const boost::system::error_code& ec, tcp::resolver::iterator i); void resolve_handler(const boost::system::error_code& ec, tcp::resolver::iterator i);
void connect_handler(const boost::system::error_code& ec, tcp::resolver::iterator i); void connect_handler(const boost::system::error_code& ec, tcp::resolver::iterator i);
void readline();
void handleResponse(const boost::system::error_code& ec); void handleResponse(const boost::system::error_code& ec);
void readResponse(const boost::system::error_code& ec, std::size_t bytes_transferred); void readResponse(const boost::system::error_code& ec, std::size_t bytes_transferred);
void processReponse(Json::Value& responseObject); void processReponse(Json::Value& responseObject);
@ -44,6 +45,7 @@ private:
bool m_running; bool m_running;
bool m_precompute; bool m_precompute;
int m_pending;
string m_response; string m_response;
GenericFarm<EthashProofOfWork> * p_farm; GenericFarm<EthashProofOfWork> * p_farm;

BIN
releases/ethminer-0.9.41-genoil-10.0.4.zip

Binary file not shown.
Loading…
Cancel
Save