mirror of
https://github.com/LBRYFoundation/pool.git
synced 2025-08-23 09:27:25 +00:00
Update job_core.cpp
This commit is contained in:
parent
94d8a35a1d
commit
e38be4128e
1 changed files with 85 additions and 80 deletions
|
@ -3,130 +3,135 @@
|
||||||
|
|
||||||
void job_sort()
|
void job_sort()
|
||||||
{
|
{
|
||||||
for(CLI li = g_list_job.first; li && li->next; li = li->next)
|
for(CLI li = g_list_job.first; li && li->next; li = li->next)
|
||||||
{
|
{
|
||||||
YAAMP_JOB *job1 = (YAAMP_JOB *)li->data;
|
YAAMP_JOB *job1 = (YAAMP_JOB *)li->data;
|
||||||
YAAMP_JOB *job2 = (YAAMP_JOB *)li->next->data;
|
YAAMP_JOB *job2 = (YAAMP_JOB *)li->next->data;
|
||||||
|
|
||||||
if(job1->profit < job2->profit)
|
if(job1->profit < job2->profit)
|
||||||
{
|
{
|
||||||
g_list_job.Swap(li, li->next);
|
g_list_job.Swap(li, li->next);
|
||||||
job_sort();
|
job_sort();
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool job_has_free_client()
|
bool job_has_free_client()
|
||||||
{
|
{
|
||||||
g_list_client.Enter();
|
g_list_client.Enter();
|
||||||
for(CLI li = g_list_client.first; li; li = li->next)
|
for(CLI li = g_list_client.first; li; li = li->next)
|
||||||
{
|
{
|
||||||
YAAMP_CLIENT *client = (YAAMP_CLIENT *)li->data;
|
YAAMP_CLIENT *client = (YAAMP_CLIENT *)li->data;
|
||||||
if(client->deleted) continue;
|
if(client->deleted) continue;
|
||||||
|
|
||||||
if(!client->jobid_next)
|
if(!client->jobid_next)
|
||||||
{
|
{
|
||||||
g_list_client.Leave();
|
g_list_client.Leave();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
g_list_client.Leave();
|
g_list_client.Leave();
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void job_reset_clients(YAAMP_JOB *job)
|
void job_reset_clients(YAAMP_JOB *job)
|
||||||
{
|
{
|
||||||
g_list_client.Enter();
|
g_list_client.Enter();
|
||||||
for(CLI li = g_list_client.first; li; li = li->next)
|
for(CLI li = g_list_client.first; li; li = li->next)
|
||||||
{
|
{
|
||||||
YAAMP_CLIENT *client = (YAAMP_CLIENT *)li->data;
|
YAAMP_CLIENT *client = (YAAMP_CLIENT *)li->data;
|
||||||
if(client->deleted) continue;
|
if(client->deleted) continue;
|
||||||
|
|
||||||
if(!job || job->id == client->jobid_next)
|
if(!job || job->id == client->jobid_next)
|
||||||
client->jobid_next = 0;
|
client->jobid_next = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
g_list_client.Leave();
|
g_list_client.Leave();
|
||||||
}
|
}
|
||||||
|
|
||||||
void job_relock_clients(int jobid_old, int jobid_new)
|
void job_relock_clients(int jobid_old, int jobid_new)
|
||||||
{
|
{
|
||||||
if(!jobid_old || !jobid_new) return;
|
if(!jobid_old || !jobid_new) return;
|
||||||
|
|
||||||
g_list_client.Enter();
|
g_list_client.Enter();
|
||||||
for(CLI li = g_list_client.first; li; li = li->next)
|
for(CLI li = g_list_client.first; li; li = li->next)
|
||||||
{
|
{
|
||||||
YAAMP_CLIENT *client = (YAAMP_CLIENT *)li->data;
|
YAAMP_CLIENT *client = (YAAMP_CLIENT *)li->data;
|
||||||
if(client->jobid_locked != jobid_old) continue;
|
if(client->jobid_locked != jobid_old) continue;
|
||||||
|
|
||||||
// debuglog("relock job %x to %x\n", client->jobid_locked, jobid_new);
|
// debuglog("relock job %x to %x\n", client->jobid_locked, jobid_new);
|
||||||
client->jobid_locked = jobid_new;
|
client->jobid_locked = jobid_new;
|
||||||
}
|
}
|
||||||
|
|
||||||
g_list_client.Leave();
|
g_list_client.Leave();
|
||||||
}
|
}
|
||||||
|
|
||||||
void job_assign_locked_clients(YAAMP_JOB *job)
|
void job_assign_locked_clients(YAAMP_JOB *job)
|
||||||
{
|
{
|
||||||
if(!job) return;
|
if(!job) return;
|
||||||
|
|
||||||
job->speed = 0;
|
job->speed = 0;
|
||||||
job->count = 0;
|
job->count = 0;
|
||||||
|
|
||||||
g_list_client.Enter();
|
g_list_client.Enter();
|
||||||
for(CLI li = g_list_client.first; li; li = li->next)
|
for(CLI li = g_list_client.first; li; li = li->next)
|
||||||
{
|
{
|
||||||
YAAMP_CLIENT *client = (YAAMP_CLIENT *)li->data;
|
YAAMP_CLIENT *client = (YAAMP_CLIENT *)li->data;
|
||||||
if(client->jobid_locked != job->id) continue;
|
if(client->jobid_locked != job->id) continue;
|
||||||
|
|
||||||
// debuglog("assign job %x %x\n", client->jobid_locked, job->id);
|
// debuglog("assign job %x %x\n", client->jobid_locked, job->id);
|
||||||
|
|
||||||
client->jobid_next = job->id;
|
client->jobid_next = job->id;
|
||||||
job->remote_subids[client->extranonce1_id] = true;
|
job->remote_subids[client->extranonce1_id] = true;
|
||||||
|
|
||||||
job->speed += client->speed;
|
job->speed += client->speed;
|
||||||
job->count++;
|
job->count++;
|
||||||
}
|
}
|
||||||
|
|
||||||
g_list_client.Leave();
|
g_list_client.Leave();
|
||||||
}
|
}
|
||||||
|
|
||||||
void job_unlock_clients(YAAMP_JOB *job)
|
void job_unlock_clients(YAAMP_JOB *job)
|
||||||
{
|
{
|
||||||
g_list_client.Enter();
|
g_list_client.Enter();
|
||||||
for(CLI li = g_list_client.first; li; li = li->next)
|
for(CLI li = g_list_client.first; li; li = li->next)
|
||||||
{
|
{
|
||||||
YAAMP_CLIENT *client = (YAAMP_CLIENT *)li->data;
|
YAAMP_CLIENT *client = (YAAMP_CLIENT *)li->data;
|
||||||
if(client->deleted) continue;
|
if(client->deleted) continue;
|
||||||
if(!client->jobid_locked) continue;
|
if(!client->jobid_locked) continue;
|
||||||
if(client->jobid_locked == client->jobid_next) continue;
|
if(client->jobid_locked == client->jobid_next) continue;
|
||||||
if(job && client->jobid_locked != job->id) continue;
|
if(job && client->jobid_locked != job->id) continue;
|
||||||
|
|
||||||
// debuglog("unlock job %x %x\n", client->jobid_locked, job->id);
|
// debuglog("unlock job %x %x\n", client->jobid_locked, job->id);
|
||||||
client->jobid_locked = 0;
|
client->jobid_locked = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
g_list_client.Leave();
|
g_list_client.Leave();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool job_can_mine(YAAMP_JOB *job)
|
bool job_can_mine(YAAMP_JOB *job)
|
||||||
{
|
{
|
||||||
if(job->deleted) return false;
|
if(job->deleted) {
|
||||||
|
debuglog("Job was deleted\n");
|
||||||
if(job->remote)
|
return false;
|
||||||
return remote_can_mine(job->remote);
|
}
|
||||||
|
if(job->remote) {
|
||||||
else if(job->coind)
|
debuglog("job is remote?\n");
|
||||||
return coind_can_mine(job->coind);
|
return remote_can_mine(job->remote);
|
||||||
|
}
|
||||||
return false;
|
else if(job->coind) {
|
||||||
|
debuglog("job is coind\n");
|
||||||
|
return coind_can_mine(job->coind);
|
||||||
|
} else {
|
||||||
|
debuglog("returning false for job_can_mine\n");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue