From aeed1373724e862acec9fda972d352c9241ee901 Mon Sep 17 00:00:00 2001 From: Marek Vasut Date: Sun, 13 Apr 2025 10:54:59 +0200 Subject: [PATCH] fs: exfat: Flush node before put in read() callback Make sure the node is never dirty before being released, flush the node first using exfat_flush_node() and only then release the node using exfat_put_node(). This now matches the behavior of exfat_fs_write() too. Fixes: b86a651b646c ("fs: exfat: Add U-Boot porting layer") Signed-off-by: Marek Vasut --- fs/exfat/io.c | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/fs/exfat/io.c b/fs/exfat/io.c index 81e82829c72..12498a4a6ec 100644 --- a/fs/exfat/io.c +++ b/fs/exfat/io.c @@ -898,9 +898,7 @@ int exfat_fs_read(const char *filename, void *buf, loff_t offset, loff_t len, *actread = sz; - exfat_put_node(&ctxt.ef, node); - - return exfat_flush_node(&ctxt.ef, node); + err = exfat_flush_node(&ctxt.ef, node); exit: exfat_put_node(&ctxt.ef, node); return err; -- 2.39.5