1
0
Fork 0
mirror of https://github.com/borgbackup/borg.git synced 2024-12-27 10:18:12 +00:00

fixup: do not access os.POSIX_FADV_* early

before we know posix_fadvise support exists on the platform.
This commit is contained in:
Thomas Waldmann 2017-01-30 03:11:42 +01:00
parent e19537ff6f
commit 7f2a108c94
3 changed files with 5 additions and 4 deletions

View file

@ -65,6 +65,7 @@ def sync_dir(path):
def safe_fadvise(fd, offset, len, advice): def safe_fadvise(fd, offset, len, advice):
if hasattr(os, 'posix_fadvise'): if hasattr(os, 'posix_fadvise'):
advice = getattr(os, 'POSIX_FADV_' + advice)
try: try:
os.posix_fadvise(fd, offset, len, advice) os.posix_fadvise(fd, offset, len, advice)
except OSError: except OSError:
@ -120,7 +121,7 @@ def sync(self):
platform.fdatasync(self.fileno) platform.fdatasync(self.fileno)
# tell the OS that it does not need to cache what we just wrote, # tell the OS that it does not need to cache what we just wrote,
# avoids spoiling the cache for the OS and other processes. # avoids spoiling the cache for the OS and other processes.
safe_fadvise(self.fileno, 0, 0, os.POSIX_FADV_DONTNEED) safe_fadvise(self.fileno, 0, 0, 'DONTNEED')
def close(self): def close(self):
"""sync() and close.""" """sync() and close."""

View file

@ -217,7 +217,7 @@ cdef _sync_file_range(fd, offset, length, flags):
assert length & PAGE_MASK == 0, "length %d not page-aligned" % length assert length & PAGE_MASK == 0, "length %d not page-aligned" % length
if sync_file_range(fd, offset, length, flags) != 0: if sync_file_range(fd, offset, length, flags) != 0:
raise OSError(errno.errno, os.strerror(errno.errno)) raise OSError(errno.errno, os.strerror(errno.errno))
safe_fadvise(fd, offset, length, os.POSIX_FADV_DONTNEED) safe_fadvise(fd, offset, length, 'DONTNEED')
cdef unsigned PAGE_MASK = resource.getpagesize() - 1 cdef unsigned PAGE_MASK = resource.getpagesize() - 1
@ -254,7 +254,7 @@ class SyncFile(BaseSyncFile):
os.fdatasync(self.fileno) os.fdatasync(self.fileno)
# tell the OS that it does not need to cache what we just wrote, # tell the OS that it does not need to cache what we just wrote,
# avoids spoiling the cache for the OS and other processes. # avoids spoiling the cache for the OS and other processes.
safe_fadvise(self.fileno, 0, 0, os.POSIX_FADV_DONTNEED) safe_fadvise(self.fileno, 0, 0, 'DONTNEED')
def umount(mountpoint): def umount(mountpoint):

View file

@ -909,7 +909,7 @@ def close(self):
self.fds = None # Just to make sure we're disabled self.fds = None # Just to make sure we're disabled
def close_fd(self, fd): def close_fd(self, fd):
safe_fadvise(fd.fileno(), 0, 0, os.POSIX_FADV_DONTNEED) safe_fadvise(fd.fileno(), 0, 0, 'DONTNEED')
fd.close() fd.close()
def segment_iterator(self, segment=None, reverse=False): def segment_iterator(self, segment=None, reverse=False):