]> git.proxmox.com Git - mirror_ubuntu-kernels.git/commitdiff
cachefiles: remove err_put_fd label in cachefiles_ondemand_daemon_read()
authorBaokun Li <libaokun1@huawei.com>
Wed, 22 May 2024 11:43:01 +0000 (19:43 +0800)
committerRoxana Nicolescu <roxana.nicolescu@canonical.com>
Fri, 2 Aug 2024 14:26:50 +0000 (16:26 +0200)
BugLink: https://bugs.launchpad.net/bugs/2074091
[ Upstream commit 3e6d704f02aa4c50c7bc5fe91a4401df249a137b ]

The err_put_fd label is only used once, so remove it to make the code
more readable. In addition, the logic for deleting error request and
CLOSE request is merged to simplify the code.

Signed-off-by: Baokun Li <libaokun1@huawei.com>
Link: https://lore.kernel.org/r/20240522114308.2402121-6-libaokun@huaweicloud.com
Acked-by: Jeff Layton <jlayton@kernel.org>
Reviewed-by: Jia Zhu <zhujia.zj@bytedance.com>
Reviewed-by: Gao Xiang <hsiangkao@linux.alibaba.com>
Reviewed-by: Jingbo Xu <jefflexu@linux.alibaba.com>
Signed-off-by: Christian Brauner <brauner@kernel.org>
Stable-dep-of: 4b4391e77a6b ("cachefiles: defer exposing anon_fd until after copy_to_user() succeeds")
Signed-off-by: Sasha Levin <sashal@kernel.org>
Signed-off-by: Portia Stephens <portia.stephens@canonical.com>
Signed-off-by: Roxana Nicolescu <roxana.nicolescu@canonical.com>
fs/cachefiles/ondemand.c

index 7b667ddc84ca50d071a322968a94fe4560af12c0..c8389bb118f5ba4338d2ef67f08e0a7ec9af7989 100644 (file)
@@ -337,7 +337,6 @@ ssize_t cachefiles_ondemand_daemon_read(struct cachefiles_cache *cache,
 {
        struct cachefiles_req *req;
        struct cachefiles_msg *msg;
-       unsigned long id = 0;
        size_t n;
        int ret = 0;
        XA_STATE(xas, &cache->reqs, cache->req_id_next);
@@ -372,49 +371,37 @@ ssize_t cachefiles_ondemand_daemon_read(struct cachefiles_cache *cache,
        cachefiles_grab_object(req->object, cachefiles_obj_get_read_req);
        xa_unlock(&cache->reqs);
 
-       id = xas.xa_index;
-
        if (msg->opcode == CACHEFILES_OP_OPEN) {
                ret = cachefiles_ondemand_get_fd(req);
                if (ret) {
                        cachefiles_ondemand_set_object_close(req->object);
-                       goto error;
+                       goto out;
                }
        }
 
-       msg->msg_id = id;
+       msg->msg_id = xas.xa_index;
        msg->object_id = req->object->ondemand->ondemand_id;
 
        if (copy_to_user(_buffer, msg, n) != 0) {
                ret = -EFAULT;
-               goto err_put_fd;
-       }
-
-       cachefiles_put_object(req->object, cachefiles_obj_put_read_req);
-       /* CLOSE request has no reply */
-       if (msg->opcode == CACHEFILES_OP_CLOSE) {
-               xa_erase(&cache->reqs, id);
-               complete(&req->done);
+               if (msg->opcode == CACHEFILES_OP_OPEN)
+                       close_fd(((struct cachefiles_open *)msg->data)->fd);
        }
-
-       cachefiles_req_put(req);
-       return n;
-
-err_put_fd:
-       if (msg->opcode == CACHEFILES_OP_OPEN)
-               close_fd(((struct cachefiles_open *)msg->data)->fd);
-error:
+out:
        cachefiles_put_object(req->object, cachefiles_obj_put_read_req);
-       xas_reset(&xas);
-       xas_lock(&xas);
-       if (xas_load(&xas) == req) {
-               req->error = ret;
-               complete(&req->done);
-               xas_store(&xas, NULL);
+       /* Remove error request and CLOSE request has no reply */
+       if (ret || msg->opcode == CACHEFILES_OP_CLOSE) {
+               xas_reset(&xas);
+               xas_lock(&xas);
+               if (xas_load(&xas) == req) {
+                       req->error = ret;
+                       complete(&req->done);
+                       xas_store(&xas, NULL);
+               }
+               xas_unlock(&xas);
        }
-       xas_unlock(&xas);
        cachefiles_req_put(req);
-       return ret;
+       return ret ? ret : n;
 }
 
 typedef int (*init_req_fn)(struct cachefiles_req *req, void *private);