util: try to be a bit more NFS compatible when checking whether an FS is writable
https://bugs.freedesktop.org/show_bug.cgi?id=81169
This commit is contained in:
parent
3f3cc39704
commit
70421bdce2
|
@ -533,7 +533,16 @@ int path_is_read_only_fs(const char *path) {
|
||||||
if (statvfs(path, &st) < 0)
|
if (statvfs(path, &st) < 0)
|
||||||
return -errno;
|
return -errno;
|
||||||
|
|
||||||
return !!(st.f_flag & ST_RDONLY);
|
if (st.f_flag & ST_RDONLY)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
/* On NFS, statvfs() might not reflect whether we can actually
|
||||||
|
* write to the remote share. Let's try again with
|
||||||
|
* access(W_OK) which is more reliable, at least sometimes. */
|
||||||
|
if (access(path, W_OK) < 0 && errno == EROFS)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
int path_is_os_tree(const char *path) {
|
int path_is_os_tree(const char *path) {
|
||||||
|
|
Loading…
Reference in New Issue