mirror of
https://github.com/GOSTSec/sgminer
synced 2025-01-24 13:34:22 +00:00
Return ETIMEDOUT regardless if we fail in cgsem_mswait since we may be waiting on it on shutdown and the return response is harmless.
This commit is contained in:
parent
82a97a04f5
commit
3dcae53e38
24
util.c
24
util.c
@ -2579,11 +2579,14 @@ int _cgsem_mswait(cgsem_t *cgsem, int ms, const char *file, const char *func, co
|
|||||||
ret = read(fd, &buf, 1);
|
ret = read(fd, &buf, 1);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if (likely(!ret))
|
|
||||||
return ETIMEDOUT;
|
/* Harmless to time out regardless here since we may be waiting on sems
|
||||||
quitfrom(1, file, func, line, "Failed to sem_timedwait errno=%d cgsem=0x%p", errno, cgsem);
|
* during shutdown. */
|
||||||
/* We don't reach here */
|
if (unlikely(ret)) {
|
||||||
return 0;
|
applog(LOG_WARNING, "Failed to sem_timedwait %s %s %d errno=%d cgsem=0x%p",
|
||||||
|
file, func, line, errno, cgsem);
|
||||||
|
}
|
||||||
|
return ETIMEDOUT;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
void _cgsem_init(cgsem_t *cgsem, const char *file, const char *func, const int line)
|
void _cgsem_init(cgsem_t *cgsem, const char *file, const char *func, const int line)
|
||||||
@ -2617,12 +2620,13 @@ int _cgsem_mswait(cgsem_t *cgsem, int ms, const char *file, const char *func, co
|
|||||||
timeraddspec(&abs_timeout, &ts_now);
|
timeraddspec(&abs_timeout, &ts_now);
|
||||||
ret = sem_timedwait(cgsem, &abs_timeout);
|
ret = sem_timedwait(cgsem, &abs_timeout);
|
||||||
|
|
||||||
if (ret) {
|
/* Harmless to time out regardless here since we may be waiting on sems
|
||||||
if (likely(sock_timeout()))
|
* during shutdown. */
|
||||||
return ETIMEDOUT;
|
if (unlikely(ret && !sock_timeout())) {
|
||||||
quitfrom(1, file, func, line, "Failed to sem_timedwait errno=%d cgsem=0x%p", errno, cgsem);
|
applog(LOG_WARNING, "Failed to sem_timedwait %s %s %d errno=%d cgsem=0x%p",
|
||||||
|
file, func, line, errno, cgsem);
|
||||||
}
|
}
|
||||||
return 0;
|
return ETIMEDOUT;
|
||||||
}
|
}
|
||||||
|
|
||||||
void cgsem_destroy(cgsem_t *cgsem)
|
void cgsem_destroy(cgsem_t *cgsem)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user