mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-07 21:17:55 +03:00
storage: tweak condition to properly test lseek
According to the POSIX standard, off_t (returned by lseek) is defined as signed integral type no shorter than int. Because our offset variable is defined as unsigned long long, the original check was passed successfully if UINT64_MAX had been used as offset value, due to implicit conversion. Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1177219
This commit is contained in:
parent
d9c7f014ee
commit
3fde7986d6
@ -610,7 +610,7 @@ virFDStreamOpenFileInternal(virStreamPtr st,
|
||||
}
|
||||
|
||||
if (offset &&
|
||||
lseek(fd, offset, SEEK_SET) != offset) {
|
||||
lseek(fd, offset, SEEK_SET) < 0) {
|
||||
virReportSystemError(errno,
|
||||
_("Unable to seek %s to %llu"),
|
||||
path, offset);
|
||||
|
Loading…
Reference in New Issue
Block a user