1
0
mirror of https://github.com/GOSTSec/sgminer synced 2025-01-25 14:04:25 +00:00

Use cgsem timed waits in avalon driver to not miss any queued wake ups to account for async messages coming during a flush work.

This commit is contained in:
Con Kolivas 2013-11-05 21:09:08 +11:00
parent 7011a7a008
commit a4c96d759a
2 changed files with 14 additions and 18 deletions

View File

@ -1187,9 +1187,10 @@ static void *avalon_send_tasks(void *userdata)
} }
avalon_rotate_array(avalon); avalon_rotate_array(avalon);
pthread_cond_signal(&info->qcond);
mutex_unlock(&info->qlock); mutex_unlock(&info->qlock);
cgsem_post(&info->qsem);
if (unlikely(idled)) { if (unlikely(idled)) {
applog(LOG_WARNING, "%s%i: Idled %d miners", applog(LOG_WARNING, "%s%i: Idled %d miners",
avalon->drv->name, avalon->device_id, idled); avalon->drv->name, avalon->device_id, idled);
@ -1271,9 +1272,10 @@ static void *bitburner_send_tasks(void *userdata)
} }
bitburner_rotate_array(avalon); bitburner_rotate_array(avalon);
pthread_cond_signal(&info->qcond);
mutex_unlock(&info->qlock); mutex_unlock(&info->qlock);
cgsem_post(&info->qsem);
if (unlikely(idled)) { if (unlikely(idled)) {
applog(LOG_WARNING, "%s%i: Idled %d miners", applog(LOG_WARNING, "%s%i: Idled %d miners",
avalon->drv->name, avalon->device_id, idled); avalon->drv->name, avalon->device_id, idled);
@ -1303,8 +1305,7 @@ static bool avalon_prepare(struct thr_info *thr)
info->thr = thr; info->thr = thr;
mutex_init(&info->lock); mutex_init(&info->lock);
mutex_init(&info->qlock); mutex_init(&info->qlock);
if (unlikely(pthread_cond_init(&info->qcond, NULL))) cgsem_init(&info->qsem);
quit(1, "Failed to pthread_cond_init avalon qcond");
if (pthread_create(&info->read_thr, NULL, avalon_get_results, (void *)avalon)) if (pthread_create(&info->read_thr, NULL, avalon_get_results, (void *)avalon))
quit(1, "Failed to create avalon read_thr"); quit(1, "Failed to create avalon read_thr");
@ -1513,22 +1514,15 @@ static int64_t avalon_scanhash(struct thr_info *thr)
struct cgpu_info *avalon = thr->cgpu; struct cgpu_info *avalon = thr->cgpu;
struct avalon_info *info = avalon->device_data; struct avalon_info *info = avalon->device_data;
const int miner_count = info->miner_count; const int miner_count = info->miner_count;
struct timeval now, then, tdiff; int64_t hash_count, ms_timeout;
int64_t hash_count, us_timeout;
struct timespec abstime;
/* Half nonce range */ /* Half nonce range */
us_timeout = 0x80000000ll / info->asic_count / info->frequency; ms_timeout = 0x80000000ll / info->asic_count / info->frequency / 1000;
us_to_timeval(&tdiff, us_timeout);
cgtime(&now);
timeradd(&now, &tdiff, &then);
timeval_to_spec(&abstime, &then);
/* Wait until avalon_send_tasks signals us that it has completed /* Wait until avalon_send_tasks signals us that it has completed
* sending its work or a full nonce range timeout has occurred */ * sending its work or a full nonce range timeout has occurred. We use
mutex_lock(&info->qlock); * cgsems to never miss a wakeup. */
pthread_cond_timedwait(&info->qcond, &info->qlock, &abstime); cgsem_mswait(&info->qsem, ms_timeout);
mutex_unlock(&info->qlock);
mutex_lock(&info->lock); mutex_lock(&info->lock);
hash_count = 0xffffffffull * (uint64_t)info->nonces; hash_count = 0xffffffffull * (uint64_t)info->nonces;
@ -1567,8 +1561,10 @@ static void avalon_flush_work(struct cgpu_info *avalon)
mutex_lock(&info->qlock); mutex_lock(&info->qlock);
/* Will overwrite any work queued */ /* Will overwrite any work queued */
avalon->queued = 0; avalon->queued = 0;
pthread_cond_signal(&info->qcond);
mutex_unlock(&info->qlock); mutex_unlock(&info->qlock);
/* Signal main loop we need more work */
cgsem_post(&info->qsem);
} }
static struct api_data *avalon_api_stats(struct cgpu_info *cgpu) static struct api_data *avalon_api_stats(struct cgpu_info *cgpu)

View File

@ -145,7 +145,7 @@ struct avalon_info {
pthread_t write_thr; pthread_t write_thr;
pthread_mutex_t lock; pthread_mutex_t lock;
pthread_mutex_t qlock; pthread_mutex_t qlock;
pthread_cond_t qcond; cgsem_t qsem;
int nonces; int nonces;
int auto_queued; int auto_queued;