1 // SPDX-License-Identifier: GPL-2.0
2 #include <linux/kernel.h>
3 #include <linux/errno.h>
4 #include <linux/fs.h>
5 #include <linux/file.h>
6 #include <linux/mm.h>
7 #include <linux/slab.h>
8 #include <linux/syscalls.h>
9 #include <linux/io_uring.h>
10 
11 #include <uapi/linux/io_uring.h>
12 
13 #include "../fs/internal.h"
14 
15 #include "io_uring.h"
16 #include "truncate.h"
17 
18 struct io_ftrunc {
19 	struct file			*file;
20 	loff_t				len;
21 };
22 
io_ftruncate_prep(struct io_kiocb * req,const struct io_uring_sqe * sqe)23 int io_ftruncate_prep(struct io_kiocb *req, const struct io_uring_sqe *sqe)
24 {
25 	struct io_ftrunc *ft = io_kiocb_to_cmd(req, struct io_ftrunc);
26 
27 	if (sqe->rw_flags || sqe->addr || sqe->len || sqe->buf_index ||
28 	    sqe->splice_fd_in || sqe->addr3)
29 		return -EINVAL;
30 
31 	ft->len = READ_ONCE(sqe->off);
32 
33 	req->flags |= REQ_F_FORCE_ASYNC;
34 	return 0;
35 }
36 
io_ftruncate(struct io_kiocb * req,unsigned int issue_flags)37 int io_ftruncate(struct io_kiocb *req, unsigned int issue_flags)
38 {
39 	struct io_ftrunc *ft = io_kiocb_to_cmd(req, struct io_ftrunc);
40 	int ret;
41 
42 	WARN_ON_ONCE(issue_flags & IO_URING_F_NONBLOCK);
43 
44 	ret = do_ftruncate(req->file, ft->len, 1);
45 
46 	io_req_set_res(req, ret, 0);
47 	return IOU_OK;
48 }
49