在 2024/4/24 11:39, libao...@huaweicloud.com 写道:
From: Baokun Li <libaok...@huawei.com> This prevents concurrency from causing access to a freed req. Signed-off-by: Baokun Li <libaok...@huawei.com>
Reviewed-by: Jia Zhu <zhujia...@bytedance.com>
--- fs/cachefiles/daemon.c | 1 + 1 file changed, 1 insertion(+) diff --git a/fs/cachefiles/daemon.c b/fs/cachefiles/daemon.c index 6465e2574230..ccb7b707ea4b 100644 --- a/fs/cachefiles/daemon.c +++ b/fs/cachefiles/daemon.c @@ -159,6 +159,7 @@ static void cachefiles_flush_reqs(struct cachefiles_cache *cache) xa_for_each(xa, index, req) { req->error = -EIO; complete(&req->done); + __xa_erase(xa, index); } xa_unlock(xa);