mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-04 09:18:36 +03:00
dmsetup: check timerfd reads for valid byte count (Coverity)
The timerfd guarantees that it will return 8 bytes when a read(2) is issued (a uint64_t giving the number of timer events during the call). Check that it does so and log a non-fatal error if the byte count is not 8.
This commit is contained in:
parent
074b5de771
commit
12acf852c5
@ -573,18 +573,25 @@ static int _start_timerfd_timer(void)
|
|||||||
static int _do_timerfd_wait(void)
|
static int _do_timerfd_wait(void)
|
||||||
{
|
{
|
||||||
uint64_t expired;
|
uint64_t expired;
|
||||||
|
ssize_t bytes;
|
||||||
|
|
||||||
if (_timer_fd < 0)
|
if (_timer_fd < 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
/* read on timerfd returns a uint64_t in host byte order. */
|
/* read on timerfd returns a uint64_t in host byte order. */
|
||||||
if (read(_timer_fd, &expired, sizeof(expired)) < 0) {
|
bytes = read(_timer_fd, &expired, sizeof(expired));
|
||||||
|
|
||||||
|
if (bytes < 0) {
|
||||||
/* EBADF from invalid timerfd or EINVAL from too small buffer. */
|
/* EBADF from invalid timerfd or EINVAL from too small buffer. */
|
||||||
log_error("Interval timer wait failed: %s",
|
log_error("Interval timer wait failed: %s",
|
||||||
strerror(errno));
|
strerror(errno));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* read(2) on a timerfd descriptor is guaranteed to return 8 bytes. */
|
||||||
|
if (bytes != 8)
|
||||||
|
log_error("Unexepcted byte count on timerfd read: %d", bytes);
|
||||||
|
|
||||||
/* FIXME: attempt to rebase clock? */
|
/* FIXME: attempt to rebase clock? */
|
||||||
if (expired > 1)
|
if (expired > 1)
|
||||||
log_warn("WARNING: Try increasing --interval ("FMTu64
|
log_warn("WARNING: Try increasing --interval ("FMTu64
|
||||||
|
Loading…
Reference in New Issue
Block a user