1
0
mirror of https://github.com/GOSTSec/sgminer synced 2025-01-11 15:27:53 +00:00

Further simplify the total_queued counting mechanism and do all dec_queued from the one location.

This commit is contained in:
Con Kolivas 2012-06-24 21:42:34 +10:00
parent 9bae0f1674
commit 790acad9f9

View File

@ -2371,18 +2371,6 @@ void switch_pools(struct pool *selected)
mutex_unlock(&lp_lock); mutex_unlock(&lp_lock);
} }
static void discard_work(struct work *work)
{
if (!work->clone && !work->rolls && !work->mined) {
if (work->pool)
work->pool->discarded_work++;
total_discarded++;
applog(LOG_DEBUG, "Discarded work");
} else
applog(LOG_DEBUG, "Discarded cloned or rolled work");
free_work(work);
}
/* Done lockless since this is not a critical value */ /* Done lockless since this is not a critical value */
static inline void inc_queued(void) static inline void inc_queued(void)
{ {
@ -2395,15 +2383,25 @@ static inline void dec_queued(void)
total_queued--; total_queued--;
} }
static int requests_queued(void) static void discard_work(struct work *work)
{ {
return requests_staged() - staged_extras; if (!work->clone)
dec_queued();
if (!work->clone && !work->rolls && !work->mined) {
if (work->pool)
work->pool->discarded_work++;
total_discarded++;
applog(LOG_DEBUG, "Discarded work");
} else
applog(LOG_DEBUG, "Discarded cloned or rolled work");
free_work(work);
} }
static int discard_stale(void) static int discard_stale(void)
{ {
struct work *work, *tmp; struct work *work, *tmp;
int i, stale = 0; int stale = 0;
mutex_lock(stgd_lock); mutex_lock(stgd_lock);
HASH_ITER(hh, staged_work, work, tmp) { HASH_ITER(hh, staged_work, work, tmp) {
@ -2419,10 +2417,6 @@ static int discard_stale(void)
applog(LOG_DEBUG, "Discarded %d stales that didn't match current hash", stale); applog(LOG_DEBUG, "Discarded %d stales that didn't match current hash", stale);
/* Dec queued outside the loop to not have recursive locks */
for (i = 0; i < stale; i++)
dec_queued();
return stale; return stale;
} }
@ -3498,11 +3492,11 @@ static void pool_resus(struct pool *pool)
static bool queue_request(struct thr_info *thr, bool needed) static bool queue_request(struct thr_info *thr, bool needed)
{ {
int rs = requests_staged(), rq = requests_queued(); int rs = requests_staged();
struct workio_cmd *wc; struct workio_cmd *wc;
if ((rq >= mining_threads || (rq >= opt_queue && rs >= mining_threads)) && if ((total_queued >= opt_queue && rs >= mining_threads) ||
total_queued >= opt_queue) total_queued >= mining_threads)
return true; return true;
/* fill out work request message */ /* fill out work request message */
@ -3521,7 +3515,7 @@ static bool queue_request(struct thr_info *thr, bool needed)
/* If we're queueing work faster than we can stage it, consider the /* If we're queueing work faster than we can stage it, consider the
* system lagging and allow work to be gathered from another pool if * system lagging and allow work to be gathered from another pool if
* possible */ * possible */
if (rq && needed && !requests_staged() && !opt_fail_only) if (total_queued && needed && !rs && !opt_fail_only)
wc->lagging = true; wc->lagging = true;
applog(LOG_DEBUG, "Queueing getwork request to work thread"); applog(LOG_DEBUG, "Queueing getwork request to work thread");
@ -3671,7 +3665,7 @@ static bool get_work(struct work *work, bool requested, struct thr_info *thr,
} }
retry: retry:
pool = current_pool(); pool = current_pool();
if (!requested || requests_queued() < opt_queue) { if (!requested || total_queued < opt_queue) {
if (unlikely(!queue_request(thr, true))) { if (unlikely(!queue_request(thr, true))) {
applog(LOG_WARNING, "Failed to queue_request in get_work"); applog(LOG_WARNING, "Failed to queue_request in get_work");
goto out; goto out;
@ -3721,7 +3715,6 @@ retry:
} }
if (stale_work(work_heap, false)) { if (stale_work(work_heap, false)) {
dec_queued();
discard_work(work_heap); discard_work(work_heap);
goto retry; goto retry;
} }
@ -3737,8 +3730,6 @@ retry:
work_heap = clone_work(work_heap); work_heap = clone_work(work_heap);
memcpy(work, work_heap, sizeof(struct work)); memcpy(work, work_heap, sizeof(struct work));
free_work(work_heap); free_work(work_heap);
if (!work->clone)
dec_queued();
ret = true; ret = true;
out: out:
@ -4336,7 +4327,6 @@ static void *watchdog_thread(void __maybe_unused *userdata)
struct timeval now; struct timeval now;
sleep(interval); sleep(interval);
if (requests_queued() < opt_queue || total_queued < opt_queue)
queue_request(NULL, false); queue_request(NULL, false);
age_work(); age_work();