POSIX_FALLOCATE(3) | Руководство программиста Linux | POSIX_FALLOCATE(3) |
posix_fallocate - выделяет пространство для файла
#include <fcntl.h>
int posix_fallocate(int fd, off_t offset, off_t len);
Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):
posix_fallocate():
Функция posix_fallocate() гарантирует, что дисковое пространство, выделено для файла, на который указывает файловый дескриптор fd, для байт в диапазоне начиная с offset и длиной len байт. После успешного выполнения posix_fallocate() последующие операции записи в байты указанного диапазона гарантировано не закончатся ошибкой из-за нехватки места на диске.
Если размер файла меньше чем offset+len, то файл увеличится до своего размера; в противном случае размер файла останется не изменённым.
При успешном выполнении функции posix_fallocate() возвращается 0, а при ошибке возвращается её номер. Заметим, что errno не изменяется.
Функция posix_fallocate() доступна в glibc начиная с версии 2.1.94.
Описание терминов данного раздела смотрите в attributes(7).
Интерфейс | Атрибут | Значение |
posix_fallocate() | Безвредность в нитях | MT-Safe (но смотрите ДЕФЕКТЫ) |
POSIX.1-2001.
В POSIX.1-2008 указано, что реализация должна возвращать ошибку EINVAL, если len равно 0 или offset меньше 0. В POSIX.1-2001 сказано, что реализация должна возвращать ошибку EINVAL, если len меньше 0 или offset меньше 0, и может возвращать ошибку, если len равно 0.
В glibc функция posix_fallocate() реализована с помощью системного вызова fallocate(2), который является нитебезопасным. Если подлежащая файловая система не поддерживает fallocate(2), то операция эмулируется со следующими оговорками:
Таким образом, эмуляция не является нитебезопасной. В Linux приложения могут использовать fallocate(2), если для них неприемлемы оговорки эмуляции. В общем, функцию рекомендуется использовать только, если приложение планирует завершить операцию, если возвращается EOPNOTSUPP, в противном случае в приложении нужно реализовать обходное решение проблем эмуляции, предоставляемой glibc.
2017-09-15 | GNU |