IOCTL-FICLONERANGE(2) | Руководство программиста Linux | IOCTL-FICLONERANGE(2) |
ioctl_ficlonerange, ioctl_ficlone - сделать некоторые данные одного файла общими с другим файлом
#include <sys/ioctl.h> #include <linux/fs.h>
int ioctl(int dest_fd, FICLONERANGE, struct file_clone_range *arg); int ioctl(int dest_fd, FICLONE, int src_fd);
Если файловая система поддерживает общее файловое физическое хранилище для файлов («reflink»), то эту операцию ioctl(2) можно использовать для того, чтобы часть данных файла src_fd появилась в файле dest_fd в виде общего пространства на носителе, что быстрее по сравнению с созданием отдельной физической копии данных. Оба файла должны располагаться в одной файловой системе. Если выполняется запись в эту общую область, то файловая система должна гарантировать, что изменения будут видны только в файле, в который производится запись. Такое поведение часто называют как «копирование при записи» (copy on write).
Данный ioctl создаёт ссылку (reflink) на не более src_length байт из файлового дескриптора src_fd по смещению src_offset в файл dest_fd по смещению dest_offset, предоставляя её обоим файлам. Если src_length равно нулю, то ioctl делает ссылку на конец файла-источника. Данная информация передаётся в структуре следующего вида:
struct file_clone_range { __s64 src_fd; __u64 src_offset; __u64 src_length; __u64 dest_offset; };
Клоны атомарны для одновременной записи, поэтому для получения корректной копии не нужно получать блокировки.
Операция FICLONE ioctl клонирует файлы полностью.
В случае ошибки возвращается -1, а errno устанавливается в значение ошибки.
Возможные коды ошибок (помимо прочих):
Данные операции ioctl появились в Linux 4.5. Раньше они назывались BTRFS_IOC_CLONE и BTRFS_IOC_CLONE_RANGE и работали только в Btrfs.
Данный программный интерфейс существует только в Linux.
Так как для операции копирования-при-записи требуется выделение нового пространства в хранилище, операция fallocate(2) может отменить совместное использование общих блоков для гарантии того, что последующие операции записи не завершатся ошибкой из-за нехватки места на диске.
2017-09-15 | Linux |