From: Karim Taha <kariem.taha2.7@gmail.com>
To: qemu-devel@nongnu.org
Cc: imp@bsdimp.com, Michal Meloun <mmel@FreeBSD.org>,
Stacey Son <sson@FreeBSD.org>,
Karim Taha <kariem.taha2.7@gmail.com>,
Richard Henderson <richard.henderson@linaro.org>
Subject: [PATCH v3 23/32] Implement freebsd11 stat related syscalls
Date: Sun, 13 Aug 2023 10:41:44 +0200 [thread overview]
Message-ID: <20230813084153.6510-24-kariem.taha2.7@gmail.com> (raw)
In-Reply-To: <20230813084153.6510-1-kariem.taha2.7@gmail.com>
From: Michal Meloun <mmel@FreeBSD.org>
Implement the freebsd11 variant of the following syscalls:
fstat(2)
fstatat(2)
fhstat(2)
fhstatfs(2)
Co-authored-by: Stacey Son <sson@FreeBSD.org>
Signed-off-by: Stacey Son <sson@FreeBSD.org>
Signed-off-by: Michal Meloun <mmel@FreeBSD.org>
Signed-off-by: Karim Taha <kariem.taha2.7@gmail.com>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
---
bsd-user/freebsd/os-stat.h | 78 ++++++++++++++++++++++++++++++++++++++
1 file changed, 78 insertions(+)
diff --git a/bsd-user/freebsd/os-stat.h b/bsd-user/freebsd/os-stat.h
index aef55c8bb5..2e0c7245df 100644
--- a/bsd-user/freebsd/os-stat.h
+++ b/bsd-user/freebsd/os-stat.h
@@ -24,6 +24,17 @@ int freebsd11_stat(const char *path, struct freebsd11_stat *stat);
__sym_compat(stat, freebsd11_stat, FBSD_1.0);
int freebsd11_lstat(const char *path, struct freebsd11_stat *stat);
__sym_compat(lstat, freebsd11_lstat, FBSD_1.0);
+int freebsd11_fstat(int fd, struct freebsd11_stat *stat);
+__sym_compat(fstat, freebsd11_fstat, FBSD_1.0);
+int freebsd11_fstatat(int fd, const char *path, struct freebsd11_stat *stat,
+ int flag);
+__sym_compat(fstatat, freebsd11_fstatat, FBSD_1.1);
+
+int freebsd11_fhstat(const fhandle_t *fhandle, struct freebsd11_stat *stat);
+__sym_compat(fhstat, freebsd11_fhstat, FBSD_1.0);
+int freebsd11_fhstatfs(const fhandle_t *fhandle, struct freebsd11_statfs * buf);
+__sym_compat(fhstatfs, freebsd11_fhstatfs, FBSD_1.0);
+int freebsd11_statfs(const char *path, struct freebsd11_statfs *buf);
/* stat(2) */
static inline abi_long do_freebsd11_stat(abi_long arg1, abi_long arg2)
@@ -57,6 +68,19 @@ static inline abi_long do_freebsd11_lstat(abi_long arg1, abi_long arg2)
return ret;
}
+/* fstat(2) */
+static inline abi_long do_freebsd11_fstat(abi_long arg1, abi_long arg2)
+{
+ abi_long ret;
+ struct freebsd11_stat st;
+
+ ret = get_errno(freebsd11_fstat(arg1, &st));
+ if (!is_error(ret)) {
+ ret = h2t_freebsd11_stat(arg2, &st);
+ }
+ return ret;
+}
+
/* fstat(2) */
static inline abi_long do_freebsd_fstat(abi_long arg1, abi_long arg2)
{
@@ -70,6 +94,23 @@ static inline abi_long do_freebsd_fstat(abi_long arg1, abi_long arg2)
return ret;
}
+/* fstatat(2) */
+static inline abi_long do_freebsd11_fstatat(abi_long arg1, abi_long arg2,
+ abi_long arg3, abi_long arg4)
+{
+ abi_long ret;
+ void *p;
+ struct freebsd11_stat st;
+
+ LOCK_PATH(p, arg2);
+ ret = get_errno(freebsd11_fstatat(arg1, p, &st, arg4));
+ UNLOCK_PATH(p, arg2);
+ if (!is_error(ret) && arg3) {
+ ret = h2t_freebsd11_stat(arg3, &st);
+ }
+ return ret;
+}
+
/* fstatat(2) */
static inline abi_long do_freebsd_fstatat(abi_long arg1, abi_long arg2,
abi_long arg3, abi_long arg4)
@@ -178,6 +219,24 @@ static inline abi_long do_freebsd_fhopen(abi_long arg1, abi_long arg2)
return get_errno(fhopen(&host_fh, arg2));
}
+/* fhstat(2) */
+static inline abi_long do_freebsd11_fhstat(abi_long arg1, abi_long arg2)
+{
+ abi_long ret;
+ fhandle_t host_fh;
+ struct freebsd11_stat host_sb;
+
+ ret = t2h_freebsd_fhandle(&host_fh, arg1);
+ if (is_error(ret)) {
+ return ret;
+ }
+ ret = get_errno(freebsd11_fhstat(&host_fh, &host_sb));
+ if (is_error(ret)) {
+ return ret;
+ }
+ return h2t_freebsd11_stat(arg2, &host_sb);
+}
+
/* fhstat(2) */
static inline abi_long do_freebsd_fhstat(abi_long arg1, abi_long arg2)
{
@@ -196,6 +255,25 @@ static inline abi_long do_freebsd_fhstat(abi_long arg1, abi_long arg2)
return h2t_freebsd_stat(arg2, &host_sb);
}
+/* fhstatfs(2) */
+static inline abi_long do_freebsd11_fhstatfs(abi_ulong target_fhp_addr,
+ abi_ulong target_stfs_addr)
+{
+ abi_long ret;
+ fhandle_t host_fh;
+ struct freebsd11_statfs host_stfs;
+
+ ret = t2h_freebsd_fhandle(&host_fh, target_fhp_addr);
+ if (is_error(ret)) {
+ return ret;
+ }
+ ret = get_errno(freebsd11_fhstatfs(&host_fh, &host_stfs));
+ if (is_error(ret)) {
+ return ret;
+ }
+ return h2t_freebsd11_statfs(target_stfs_addr, &host_stfs);
+}
+
/* fhstatfs(2) */
static inline abi_long do_freebsd_fhstatfs(abi_ulong target_fhp_addr,
abi_ulong target_stfs_addr)
--
2.40.0
next prev parent reply other threads:[~2023-08-13 19:49 UTC|newest]
Thread overview: 35+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-08-13 8:41 [PATCH v3 00/32] Implement the stat system calls for FreeBSD Karim Taha
2023-08-13 8:41 ` [PATCH v3 01/32] Move _WANT_FREEBSD macros to include/qemu/osdep.h Karim Taha
2023-08-13 8:41 ` [PATCH v3 02/32] Disable clang warnings Karim Taha
2023-08-13 8:41 ` [PATCH v3 03/32] Update the definitions of __put_user and __get_user macros Karim Taha
2023-08-13 8:41 ` [PATCH v3 04/32] Declarations of h2t and t2h conversion functions Karim Taha
2023-08-13 8:41 ` [PATCH v3 05/32] Add struct target_freebsd11_stat to bsd-user/syscall_defs Karim Taha
2023-08-13 8:41 ` [PATCH v3 06/32] Add struct target_stat to bsd-user/syscall_defs.h Karim Taha
2023-08-13 8:41 ` [PATCH v3 07/32] Add structs target_freebsd11_nstat and target_freebsd11_statfs " Karim Taha
2023-08-13 8:41 ` [PATCH v3 08/32] Add struct target_statfs " Karim Taha
2023-08-13 8:41 ` [PATCH v3 09/32] Add struct target_freebsd_fhandle and fcntl flags " Karim Taha
2023-08-13 8:41 ` [PATCH v3 10/32] Define safe_fcntl macro in bsd-user/syscall_defs.h Karim Taha
2023-08-13 8:41 ` [PATCH v3 11/32] Rename target_freebsd_time_t to target_time_t Karim Taha
2023-08-13 8:41 ` [PATCH v3 12/32] Implement h2t_freebsd11_stat h2t_freebsd_nstat Karim Taha
2023-08-13 8:41 ` [PATCH v3 13/32] Implement h2t_freebsd_fhandle t2h_freebsd_fhandle functions Karim Taha
2023-08-13 8:41 ` [PATCH v3 14/32] Implement h2t_freebds11_statfs Karim Taha
2023-08-13 8:41 ` [PATCH v3 15/32] Implement target_to_host_fcntl_cmd Karim Taha
2023-08-13 8:41 ` [PATCH v3 16/32] Implement h2t_freebsd_stat and h2t_freebsd_statfs functions Karim Taha
2023-08-13 8:41 ` [PATCH v3 17/32] Implement stat related syscalls Karim Taha
2023-08-13 8:41 ` [PATCH v3 18/32] " Karim Taha
2023-08-13 8:41 ` [PATCH v3 19/32] " Karim Taha
2023-08-13 8:41 ` [PATCH v3 20/32] " Karim Taha
2023-08-13 8:41 ` [PATCH v3 21/32] " Karim Taha
2023-08-13 8:41 ` [PATCH v3 22/32] Implement freebsd11 " Karim Taha
2023-08-13 8:41 ` Karim Taha [this message]
2023-08-13 8:41 ` [PATCH v3 24/32] " Karim Taha
2023-08-13 8:41 ` [PATCH v3 25/32] " Karim Taha
2023-08-13 8:41 ` [PATCH v3 26/32] " Karim Taha
2023-08-13 8:41 ` [PATCH v3 27/32] Implement do_freebsd_realpathat syscall Karim Taha
2023-08-13 8:41 ` [PATCH v3 28/32] Add os-stat.c to the build Karim Taha
2023-08-13 8:41 ` [PATCH v3 29/32] Add glue to call the following syscalls to the freebsd_syscall function: Karim Taha
2023-08-13 8:41 ` [PATCH v3 30/32] " Karim Taha
2023-08-13 8:41 ` [PATCH v3 31/32] " Karim Taha
2023-08-13 8:41 ` [PATCH v3 32/32] " Karim Taha
2023-08-20 4:03 ` [PATCH v3 00/32] Implement the stat system calls for FreeBSD Warner Losh
2023-08-21 11:59 ` Markus Armbruster
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20230813084153.6510-24-kariem.taha2.7@gmail.com \
--to=kariem.taha2.7@gmail.com \
--cc=imp@bsdimp.com \
--cc=mmel@FreeBSD.org \
--cc=qemu-devel@nongnu.org \
--cc=richard.henderson@linaro.org \
--cc=sson@FreeBSD.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).