From: Greg Kurz <gr...@kaod.org> Factor out duplicated code to a single helper. More users to come.
Signed-off-by: Greg Kurz <gr...@kaod.org> Reviewed-by: Christian Schoenebeck <qemu_...@crudebyte.com> Message-Id: <20250312152933.383967-2-gr...@kaod.org> Signed-off-by: Christian Schoenebeck <qemu_...@crudebyte.com> --- hw/9pfs/9p-local.c | 25 +++++++++++-------------- 1 file changed, 11 insertions(+), 14 deletions(-) diff --git a/hw/9pfs/9p-local.c b/hw/9pfs/9p-local.c index 928523afcc..99b9560a52 100644 --- a/hw/9pfs/9p-local.c +++ b/hw/9pfs/9p-local.c @@ -766,16 +766,19 @@ out: return err; } +static int local_fid_fd(int fid_type, V9fsFidOpenState *fs) +{ + if (fid_type == P9_FID_DIR) { + return dirfd(fs->dir.stream); + } else { + return fs->fd; + } +} + static int local_fstat(FsContext *fs_ctx, int fid_type, V9fsFidOpenState *fs, struct stat *stbuf) { - int err, fd; - - if (fid_type == P9_FID_DIR) { - fd = dirfd(fs->dir.stream); - } else { - fd = fs->fd; - } + int err, fd = local_fid_fd(fid_type, fs); err = fstat(fd, stbuf); if (err) { @@ -1167,13 +1170,7 @@ out: static int local_fsync(FsContext *ctx, int fid_type, V9fsFidOpenState *fs, int datasync) { - int fd; - - if (fid_type == P9_FID_DIR) { - fd = dirfd(fs->dir.stream); - } else { - fd = fs->fd; - } + int fd = local_fid_fd(fid_type, fs); if (datasync) { return qemu_fdatasync(fd); -- 2.30.2