logo
Free, unlimited AI code reviews that run on commit
git-lrc git-lrc GitHub Install Now We'd appreciate a star git-lrc - Free, unlimited AI code reviews that run on commit | Product Hunt git-lrc - Free, unlimited AI code reviews that run on commit | Product Hunt

io_uring_prep_cmd_discard - prepare a discard command

Description

       The  io_uring_prep_cmd_discard(3) function prepares a discard command request. The submission queue entry
       sqe is setup to use the file descriptor fd to start discarding nbytes at the specified offset.

       The command is an asynchronous equivalent of BLOCK_URING_CMD_DISCARD ioctl with  a  few  differences.  It
       allows  multiple  parallel discards, and it does not exclude concurrent writes and reads. As a result, it
       may lead to races for the data on the disk, if the application has IO inflight for the same  ranges  that
       the  discard  operates  on.  It's  the user's responsibility to account for that.  Furthermore, only best
       efforts are done to invalidate page caches. The user has to make sure that no other inflight requests are
       modifying or reading the range(s). If that is the case, it might result in  stale  page  cache  and  data
       inconsistencies.

       Available since 6.12.

Errors

       The CQE res field will contain the result of the operation. On success, this field will be set to 0.  On
       error,  a  negative  error  value is returned. Note that where synchronous system calls will return -1 on
       failure and set errno to the actual error value, io_uring never  uses  errno.   Instead  it  returns  the
       negated errno directly in the CQE res field.

Name

       io_uring_prep_cmd_discard - prepare a discard command

Return Value

       None

See Also

io_uring_get_sqe(3), io_uring_submit(3),

liburing-2.8                                      Oct 13, 2024                      io_uring_prep_cmd_discard(3)

Synopsis

#include<liburing.h>voidio_uring_prep_cmd_discard(structio_uring_sqe*sqe,intfd,uint64_toffset,uint64_tnbytes);

See Also