table of contents
- Tumbleweed 4.30.2-1.1
- Leap-16.0
- Leap-15.6
| io_submit(2) | System Calls Manual | io_submit(2) |
НАИМЕНОВАНИЕ¶
io_submit - отправляет асинхронные блоки ввода-вывода для обработки
БИБЛИОТЕКА¶
Стандартная библиотека языка C (libc, -lc)
СИНТАКСИС¶
#include <linux/aio_abi.h> #include <sys/syscall.h> /* Definition of SYS_* constants */ #include <unistd.h>
int syscall(SYS_io_submit, aio_context_t ctx_id,
long n, struct iocb *iocbpp[n]);
ОПИСАНИЕ¶
Note: you probably want to use the io_setup(3) wrapper function provided by libaio; see VERSIONS.
The io_submit() system call queues n I/O request blocks for processing in the AIO context ctx_id. The iocbpp argument should be an array of n AIO control blocks, which will be submitted to context ctx_id.
Структура iocb (блок управления вводом-выводом), определённая в linux/aio_abi.h, описывает параметры, которыми управляется операция ввода-вывода.
#include <linux/aio_abi.h>
struct iocb {
__u64 aio_data;
__u32 PADDED(aio_key, aio_rw_flags);
__u16 aio_lio_opcode;
__s16 aio_reqprio;
__u32 aio_fildes;
__u64 aio_buf;
__u64 aio_nbytes;
__s64 aio_offset;
__u64 aio_reserved2;
__u32 aio_flags;
__u32 aio_resfd;
};
Поля этой структуры имеют следующее назначение:
- aio_data
- Эти данные копируются в поле data структуры io_event при завершении ввода-вывода (смотрите io_getevents(2)).
- aio_key
- Внутреннее поле, используется ядром. Не изменяйте это поле после вызова io_submit().
- aio_rw_flags
- Флаги чтения-записи, передаваемые со структурой. Возможные значения:
- RWF_APPEND (начиная с Linux 4.16)
- Добавить данный в конец файла. Смотрите описание флага с таким же именем в pwritev2(2), а также описание O_APPEND в open(2). Поле aio_offset игнорируется. Файловое смещение не изменяется.
- RWF_DSYNC (начиная с Linux 4.13)
- Операция записи завершается согласно требованиям целостности данных синхронизированного ввода-вывода. Смотрите описание флага с тем же именем в pwritev2(2), а также описание O_DSYNC в open(2).
- RWF_HIPRI (начиная с Linux 4.13)
- Запрос с высоким приоритетом; опросить, если возможно
- RWF_NOWAIT (начиная с Linux 4.14)
- Не ждать, если ввод-вывод блокирует операции, такие как выделение файловых блоков, очистка грязной страницы, блокировку мьютексов или вызывает перегрузку блочного устройства внутри ядра. Если имеется что-то из этого, то управляющий блок возвращается немедленно со значением -EAGAIN в поле res структуры io_event (смотрите io_getevents(2)).
- RWF_SYNC (начиная с Linux 4.13)
- Операция записи завершается согласно требованиям целостности файла синхронизированного ввода-вывода. Смотрите описание флага с тем же именем в pwritev2(2), а также описание O_SYNC в open(2).
- RWF_NOAPPEND (начиная с Linux 6.9)
- Do not honor O_APPEND open(2) flag. See the description of RWF_NOAPPEND in pwritev2(2).
- RWF_ATOMIC (начиная с Linux 6.11)
- Write a block of data such that a write will never be torn from power fail or similar. See the description of RWF_ATOMIC in pwritev2(2). For usage with IOCB_CMD_PWRITEV, the upper vector limit is stx_atomic_write_segments_max. See STATX_WRITE_ATOMIC and stx_atomic_write_segments_max description in statx(2).
- aio_lio_opcode
- Тип ввода-вывода, выполняемый структурой iocb. Возможные значения, определены перечислением в linux/aio_abi.h:
-
enum {
IOCB_CMD_PREAD = 0,
IOCB_CMD_PWRITE = 1,
IOCB_CMD_FSYNC = 2,
IOCB_CMD_FDSYNC = 3,
IOCB_CMD_POLL = 5,
IOCB_CMD_NOOP = 6,
IOCB_CMD_PREADV = 7,
IOCB_CMD_PWRITEV = 8, };
- aio_reqprio
- Определяет приоритет запросов.
- aio_fildes
- Файловый дескриптор, над которым будут выполняться операции ввода-вывода.
- aio_buf
- Буфер, используемый для пересылки данных при операции чтения или записи.
- aio_nbytes
- Размер буфера, на который указывает aio_buf.
- aio_offset
- Файловое смещение, начиная с которого будут выполняться операции ввода-вывода.
- aio_flags
- Набор флагов, связанный со структурой iocb. Допускаемые значения:
- IOCB_FLAG_RESFD
- Управление асинхронным вводом-выводом должно сигнализировать файловому дескриптору в aio_resfd после выполнения.
- IOCB_FLAG_IOPRIO (начиная с Linux 4.18)
- Считать поле aio_reqprio как IOPRIO_VALUE, определённое в linux/ioprio.h.
- aio_resfd
- Файловый дескриптор для сигнализации завершения асинхронного ввода-вывода.
ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ¶
On success, io_submit() returns the number of iocbs submitted (which may be less than n, or 0 if n is zero).
В случае ошибки возвращается -1, а errno устанавливается в значение ошибки.
ОШИБКИ¶
- EAGAIN
- Недостаточно ресурсов для постановки в очередь iocb.
- EBADF
- Некорректный файловый дескриптор, указанный в первом iocb.
- EFAULT
- Одна из структур данных указывает на некорректные данные.
- EINVAL
- Некорректен контекст AIO, указанный ctx_id.
- EINVAL
- n is less than 0.
- EINVAL
- The iocb at *iocbpp[0] is not properly initialized.
- EINVAL
- The operation specified is invalid for the file descriptor in the iocb.
- EINVAL
- The value in the aio_reqprio field is invalid.
- ENOSYS
- Вызов io_submit() не реализован для этой архитектуры.
- EPERM
- Поле aio_reqprio содержит класс IOPRIO_CLASS_RT, но представляющий контекст не имеет мандата CAP_SYS_ADMIN.
ВЕРСИИ¶
libaio provides a wrapper function with the same name, but different prototype and return value. You probably want to use that wrapper.
СТАНДАРТЫ¶
Linux.
ИСТОРИЯ¶
Linux 2.5.
СМОТРИТЕ ТАКЖЕ¶
io_cancel(2), io_destroy(2), io_getevents(2), io_setup(2), io_submit(3), aio(7)
ПЕРЕВОД¶
Русский перевод этой страницы руководства разработал(и) Azamat Hackimov <azamat.hackimov@gmail.com>, Dmitriy S. Seregin <dseregin@59.ru>, Yuri Kozlov <yuray@komyakino.ru> и Иван Павлов <pavia00@gmail.com>
Этот перевод является свободной программной документацией; он распространяется на условиях общедоступной лицензии GNU (GNU General Public License - GPL, https://www.gnu.org/licenses/gpl-3.0.html версии 3 или более поздней) в отношении авторского права, но БЕЗ КАКИХ-ЛИБО ГАРАНТИЙ.
Если вы обнаружите какие-либо ошибки в переводе этой страницы руководства, пожалуйста, сообщите об этом разработчику(ам) по его(их) адресу(ам) электронной почты или по адресу списка рассылки русских переводчиков.
| 11 апреля 2026 г. | Страницы руководства Linux (не выпущены) |