Initial multiple pools support [2/2].

This commit is contained in:
XMRig 2017-06-27 06:32:17 +03:00
parent 952017ae7a
commit c0dcfc2a97
7 changed files with 35 additions and 54 deletions

View file

@ -105,7 +105,7 @@ int App::exec()
Mem::allocate(m_options->algo(), m_options->threads(), m_options->doubleHash()); Mem::allocate(m_options->algo(), m_options->threads(), m_options->doubleHash());
Summary::print(); Summary::print();
Workers::start(m_options->affinity(), m_options->nicehash()); Workers::start(m_options->affinity(), false);
m_network->connect(); m_network->connect();

View file

@ -143,13 +143,10 @@ Options::Options(int argc, char **argv) :
m_background(false), m_background(false),
m_colors(true), m_colors(true),
m_doubleHash(false), m_doubleHash(false),
m_keepAlive(false),
m_nicehash(false),
m_ready(false), m_ready(false),
m_safe(false), m_safe(false),
m_syslog(false), m_syslog(false),
m_logFile(nullptr), m_logFile(nullptr),
m_pass(nullptr),
m_algo(0), m_algo(0),
m_algoVariant(0), m_algoVariant(0),
m_donateLevel(kDonateLevel), m_donateLevel(kDonateLevel),
@ -185,18 +182,6 @@ Options::Options(int argc, char **argv) :
return; return;
} }
// if (!m_nicehash && m_url->isNicehash()) {
// m_nicehash = true;
// }
// if (!m_user) {
// m_user = strdup("x");
// }
if (!m_pass) {
m_pass = strdup("x");
}
m_algoVariant = getAlgoVariant(); m_algoVariant = getAlgoVariant();
if (m_algoVariant == AV2_AESNI_DOUBLE || m_algoVariant == AV4_SOFT_AES_DOUBLE) { if (m_algoVariant == AV2_AESNI_DOUBLE || m_algoVariant == AV4_SOFT_AES_DOUBLE) {
m_doubleHash = true; m_doubleHash = true;
@ -218,7 +203,6 @@ Options::Options(int argc, char **argv) :
Options::~Options() Options::~Options()
{ {
free(m_pass);
} }
@ -236,13 +220,14 @@ bool Options::parseArg(int key, char *arg)
break; break;
case 'O': /* --userpass */ case 'O': /* --userpass */
if (!setUserpass(arg)) { if (!m_pools.back()->setUserpass(arg)) {
return false; return false;
} }
break; break;
case 'o': /* --url */ case 'o': /* --url */
if (m_pools[0]->isValid()) { if (m_pools.size() > 1 || m_pools[0]->isValid()) {
Url *url = new Url(arg); Url *url = new Url(arg);
if (url->isValid()) { if (url->isValid()) {
m_pools.push_back(url); m_pools.push_back(url);
@ -254,6 +239,11 @@ bool Options::parseArg(int key, char *arg)
else { else {
m_pools[0]->parse(arg); m_pools[0]->parse(arg);
} }
if (!m_pools.back()->isValid()) {
return false;
}
break; break;
case 'u': /* --user */ case 'u': /* --user */
@ -315,7 +305,7 @@ bool Options::parseArg(int key, char *arg)
break; break;
case 'k': /* --keepalive */ case 'k': /* --keepalive */
m_keepAlive = true; m_pools.back()->setKeepAlive(true);
break; break;
case 'V': /* --version */ case 'V': /* --version */
@ -371,7 +361,7 @@ bool Options::parseArg(int key, char *arg)
break; break;
case 1006: /* --nicehash */ case 1006: /* --nicehash */
m_nicehash = true; m_pools.back()->setNicehash(true);
break; break;
case 1007: /* --print-time */ case 1007: /* --print-time */
@ -474,25 +464,6 @@ bool Options::setAlgo(const char *algo)
} }
bool Options::setUserpass(const char *userpass)
{
// const char *p = strchr(userpass, ':');
// if (!p) {
// showUsage(1);
// return false;
// }
//// free(m_user);
// free(m_pass);
//// m_user = static_cast<char*>(calloc(p - userpass + 1, 1));
// strncpy(m_user, userpass, p - userpass);
// m_pass = strdup(p + 1);
return true;
}
int Options::getAlgoVariant() const int Options::getAlgoVariant() const
{ {
# ifndef XMRIG_NO_AEON # ifndef XMRIG_NO_AEON

View file

@ -56,11 +56,8 @@ public:
inline bool colors() const { return m_colors; } inline bool colors() const { return m_colors; }
inline bool doubleHash() const { return m_doubleHash; } inline bool doubleHash() const { return m_doubleHash; }
inline bool isReady() const { return m_ready; } inline bool isReady() const { return m_ready; }
inline bool keepAlive() const { return m_keepAlive; }
inline bool nicehash() const { return m_nicehash; }
inline bool syslog() const { return m_syslog; } inline bool syslog() const { return m_syslog; }
inline const char *logFile() const { return m_logFile; } inline const char *logFile() const { return m_logFile; }
inline const char *pass() const { return m_pass; }
inline const std::vector<Url*> &pools() const { return m_pools; } inline const std::vector<Url*> &pools() const { return m_pools; }
inline int algo() const { return m_algo; } inline int algo() const { return m_algo; }
inline int algoVariant() const { return m_algoVariant; } inline int algoVariant() const { return m_algoVariant; }
@ -85,7 +82,6 @@ private:
void showVersion(void); void showVersion(void);
bool setAlgo(const char *algo); bool setAlgo(const char *algo);
bool setUserpass(const char *userpass);
int getAlgoVariant() const; int getAlgoVariant() const;
# ifndef XMRIG_NO_AEON # ifndef XMRIG_NO_AEON
@ -95,14 +91,10 @@ private:
bool m_background; bool m_background;
bool m_colors; bool m_colors;
bool m_doubleHash; bool m_doubleHash;
bool m_keepAlive;
bool m_nicehash;
bool m_ready; bool m_ready;
bool m_safe; bool m_safe;
bool m_syslog; bool m_syslog;
char *m_logFile; char *m_logFile;
char *m_pass;
// char *m_user;
int m_algo; int m_algo;
int m_algoVariant; int m_algoVariant;
int m_donateLevel; int m_donateLevel;

View file

@ -100,12 +100,12 @@ static void print_threads()
buf[0] = '\0'; buf[0] = '\0';
} }
Log::i()->text(Options::i()->colors() ? "\x1B[01;32m * \x1B[01;37mTHREADS: \x1B[01;36m%d\x1B[01;37m, %s, av=%d, donate=%d%%%s%s" : " * THREADS: %d, %s, av=%d, donate=%d%%%s%s", Log::i()->text(Options::i()->colors() ? "\x1B[01;32m * \x1B[01;37mTHREADS: \x1B[01;36m%d\x1B[01;37m, %s, av=%d, donate=%d%%%s" : " * THREADS: %d, %s, av=%d, donate=%d%%%s",
Options::i()->threads(), Options::i()->threads(),
Options::i()->algoName(), Options::i()->algoName(),
Options::i()->algoVariant(), Options::i()->algoVariant(),
Options::i()->donateLevel(), Options::i()->donateLevel(),
Options::i()->nicehash() ? ", nicehash" : "", buf); buf);
} }

View file

@ -45,7 +45,7 @@ Network::Network(const Options *options) :
m_agent = userAgent(); m_agent = userAgent();
addPool(std::make_unique<Url>().get()); addPool(std::make_unique<Url>().get());
// addPool(m_options->url()); addPool(m_options->pools().front());
// addPool(m_options->backupUrl()); // addPool(m_options->backupUrl());
m_timer.data = this; m_timer.data = this;
@ -120,7 +120,7 @@ void Network::onJobResult(const JobResult &result)
void Network::onLoginCredentialsRequired(Client *client) void Network::onLoginCredentialsRequired(Client *client)
{ {
// client->login(m_options->user(), m_options->pass(), m_agent); client->login(m_options->pools().front()->password(), m_options->pools().front()->password(), m_agent);
} }
@ -154,7 +154,7 @@ void Network::addPool(const Url *url)
Client *client = new Client(m_pools.size(), this); Client *client = new Client(m_pools.size(), this);
client->setUrl(url); client->setUrl(url);
client->setRetryPause(m_options->retryPause() * 1000); client->setRetryPause(m_options->retryPause() * 1000);
client->setKeepAlive(m_options->keepAlive()); // client->setKeepAlive(m_options->keepAlive());
m_pools.push_back(client); m_pools.push_back(client);
} }

View file

@ -126,6 +126,24 @@ bool Url::parse(const char *url)
} }
bool Url::setUserpass(const char *userpass)
{
const char *p = strchr(userpass, ':');
if (!p) {
return false;
}
free(m_user);
free(m_password);
m_user = static_cast<char*>(calloc(p - userpass + 1, 1));
strncpy(m_user, userpass, p - userpass);
m_password = strdup(p + 1);
return true;
}
void Url::setPassword(const char *password, bool force) void Url::setPassword(const char *password, bool force)
{ {
if (m_password != nullptr && !force) { if (m_password != nullptr && !force) {

View file

@ -51,9 +51,9 @@ public:
bool isNicehash() const; bool isNicehash() const;
bool parse(const char *url); bool parse(const char *url);
bool setUserpass(const char *userpass);
void setPassword(const char *password, bool force = true); void setPassword(const char *password, bool force = true);
void setUser(const char *user, bool force = true); void setUser(const char *user, bool force = true);
private: private:
bool m_keepAlive; bool m_keepAlive;
bool m_nicehash; bool m_nicehash;