mirror of
https://github.com/GOSTSec/sgminer
synced 2025-01-25 14:04:25 +00:00
Do not sleep longer than 2s max in bflsc scan code to stabilise displayed 5s hashrate, put locking around values, and set a minimum of 1ms.
This commit is contained in:
parent
b30f9bb72a
commit
a2d188921a
@ -284,6 +284,7 @@ struct SaveString {
|
|||||||
#define BAL_RES_TIME 72
|
#define BAL_RES_TIME 72
|
||||||
#define BAJ_SCAN_TIME 1000
|
#define BAJ_SCAN_TIME 1000
|
||||||
#define BAJ_RES_TIME 100
|
#define BAJ_RES_TIME 100
|
||||||
|
#define BFLSC_MAX_SLEEP 2000
|
||||||
|
|
||||||
#define BFLSC_TEMP_SLEEPMS 5
|
#define BFLSC_TEMP_SLEEPMS 5
|
||||||
#define BFLSC_QUE_SIZE 20
|
#define BFLSC_QUE_SIZE 20
|
||||||
@ -1653,7 +1654,7 @@ static int64_t bflsc_scanwork(struct thr_info *thr)
|
|||||||
int64_t ret, unsent;
|
int64_t ret, unsent;
|
||||||
bool flushed, cleanup;
|
bool flushed, cleanup;
|
||||||
struct work *work, *tmp;
|
struct work *work, *tmp;
|
||||||
int dev, waited = ETIMEDOUT, i;
|
int dev, waited, i;
|
||||||
|
|
||||||
// Device is gone
|
// Device is gone
|
||||||
if (bflsc->usbinfo.nodev)
|
if (bflsc->usbinfo.nodev)
|
||||||
@ -1699,29 +1700,43 @@ static int64_t bflsc_scanwork(struct thr_info *thr)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// avoid a hard loop
|
waited = restart_wait(sc_info->scan_sleep_time);
|
||||||
if (sc_info->scan_sleep_time > 0)
|
|
||||||
waited = restart_wait(sc_info->scan_sleep_time);
|
|
||||||
if (waited == ETIMEDOUT) {
|
if (waited == ETIMEDOUT) {
|
||||||
|
unsigned int old_sleep_time, new_sleep_time = 0;
|
||||||
|
int min_queued = BFLSC_QUE_SIZE;
|
||||||
/* Only adjust the scan_sleep_time if we did not receive a
|
/* Only adjust the scan_sleep_time if we did not receive a
|
||||||
* restart message while waiting. Try to adjust sleep time
|
* restart message while waiting. Try to adjust sleep time
|
||||||
* so we drop to BFLSC_QUE_WATERMARK before getting more work.
|
* so we drop to BFLSC_QUE_WATERMARK before getting more work.
|
||||||
*/
|
*/
|
||||||
int min_queued = BFLSC_QUE_SIZE;
|
|
||||||
|
|
||||||
|
rd_lock(&sc_info->stat_lock);
|
||||||
|
old_sleep_time = sc_info->scan_sleep_time;
|
||||||
for (i = 0; i < sc_info->sc_count; i++) {
|
for (i = 0; i < sc_info->sc_count; i++) {
|
||||||
if (sc_info->sc_devs[i].work_queued < min_queued)
|
if (sc_info->sc_devs[i].work_queued < min_queued)
|
||||||
min_queued = sc_info->sc_devs[i].work_queued;
|
min_queued = sc_info->sc_devs[i].work_queued;
|
||||||
}
|
}
|
||||||
|
rd_unlock(&sc_info->stat_lock);
|
||||||
|
new_sleep_time = old_sleep_time;
|
||||||
|
|
||||||
/* Increase slowly but decrease quickly */
|
/* Increase slowly but decrease quickly */
|
||||||
if (min_queued > BFLSC_QUE_WATERMARK) {
|
if (min_queued > BFLSC_QUE_WATERMARK && old_sleep_time < BFLSC_MAX_SLEEP)
|
||||||
sc_info->scan_sleep_time = sc_info->scan_sleep_time * 21 / 20;
|
new_sleep_time = old_sleep_time * 21 / 20;
|
||||||
applog(LOG_DEBUG, "%s%i: Increased scan_sleep_time to %d",
|
else if (min_queued < BFLSC_QUE_WATERMARK)
|
||||||
bflsc->drv->name, bflsc->device_id, sc_info->scan_sleep_time);
|
new_sleep_time = old_sleep_time * 2 / 3;
|
||||||
} else if (min_queued < BFLSC_QUE_WATERMARK) {
|
|
||||||
sc_info->scan_sleep_time = sc_info->scan_sleep_time * 2 / 3;
|
/* Do not sleep more than BFLSC_MAX_SLEEP so we can always
|
||||||
applog(LOG_DEBUG, "%s%i: Decreased scan_sleep_time to %d",
|
* report in at least 2 results per 5s log interval. */
|
||||||
bflsc->drv->name, bflsc->device_id, sc_info->scan_sleep_time);
|
if (new_sleep_time != old_sleep_time) {
|
||||||
|
if (new_sleep_time > BFLSC_MAX_SLEEP)
|
||||||
|
new_sleep_time = BFLSC_MAX_SLEEP;
|
||||||
|
else if (new_sleep_time == 0)
|
||||||
|
new_sleep_time = 1;
|
||||||
|
applog(LOG_DEBUG, "%s%i: Changed scan sleep time to %d",
|
||||||
|
bflsc->drv->name, bflsc->device_id, new_sleep_time);
|
||||||
|
|
||||||
|
wr_lock(&sc_info->stat_lock);
|
||||||
|
sc_info->scan_sleep_time = new_sleep_time;
|
||||||
|
wr_unlock(&sc_info->stat_lock);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user