[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PULL 02/37] semihosting/uaccess: Briefly document returned values
From: |
Alex Bennée |
Subject: |
[PULL 02/37] semihosting/uaccess: Briefly document returned values |
Date: |
Fri, 17 Jan 2025 13:42:21 +0000 |
From: Philippe Mathieu-Daudé <philmd@linaro.org>
Since it is not obvious the get/put_user*() methods
can return an error, add brief docstrings about it.
Also remind to use *unlock_user() when appropriate.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Message-Id: <20241212115413.42109-1-philmd@linaro.org>
Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
Message-Id: <20250116160306.1709518-3-alex.bennee@linaro.org>
diff --git a/include/semihosting/uaccess.h b/include/semihosting/uaccess.h
index c2fa5a655d..6bc90b12d6 100644
--- a/include/semihosting/uaccess.h
+++ b/include/semihosting/uaccess.h
@@ -19,41 +19,96 @@
#include "exec/tswap.h"
#include "exec/page-protection.h"
+/**
+ * get_user_u64:
+ *
+ * Returns: 0 on success, -1 on error.
+ */
#define get_user_u64(val, addr) \
({ uint64_t val_ = 0; \
int ret_ = cpu_memory_rw_debug(env_cpu(env), (addr), \
&val_, sizeof(val_), 0); \
(val) = tswap64(val_); ret_; })
+/**
+ * get_user_u32:
+ *
+ * Returns: 0 on success, -1 on error.
+ */
#define get_user_u32(val, addr) \
({ uint32_t val_ = 0; \
int ret_ = cpu_memory_rw_debug(env_cpu(env), (addr), \
&val_, sizeof(val_), 0); \
(val) = tswap32(val_); ret_; })
+/**
+ * get_user_u8:
+ *
+ * Returns: 0 on success, -1 on error.
+ */
#define get_user_u8(val, addr) \
({ uint8_t val_ = 0; \
int ret_ = cpu_memory_rw_debug(env_cpu(env), (addr), \
&val_, sizeof(val_), 0); \
(val) = val_; ret_; })
+/**
+ * get_user_ual:
+ *
+ * Returns: 0 on success, -1 on error.
+ */
#define get_user_ual(arg, p) get_user_u32(arg, p)
+/**
+ * put_user_u64:
+ *
+ * Returns: 0 on success, -1 on error.
+ */
#define put_user_u64(val, addr) \
({ uint64_t val_ = tswap64(val); \
cpu_memory_rw_debug(env_cpu(env), (addr), &val_, sizeof(val_), 1); })
+/**
+ * put_user_u32:
+ *
+ * Returns: 0 on success, -1 on error.
+ */
#define put_user_u32(val, addr) \
({ uint32_t val_ = tswap32(val); \
cpu_memory_rw_debug(env_cpu(env), (addr), &val_, sizeof(val_), 1); })
+/**
+ * put_user_ual:
+ *
+ * Returns: 0 on success, -1 on error.
+ */
#define put_user_ual(arg, p) put_user_u32(arg, p)
+/**
+ * uaccess_lock_user:
+ *
+ * The returned pointer should be freed using uaccess_unlock_user().
+ */
void *uaccess_lock_user(CPUArchState *env, target_ulong addr,
target_ulong len, bool copy);
+/**
+ * lock_user:
+ *
+ * The returned pointer should be freed using unlock_user().
+ */
#define lock_user(type, p, len, copy) uaccess_lock_user(env, p, len, copy)
+/**
+ * uaccess_lock_user_string:
+ *
+ * The returned string should be freed using uaccess_unlock_user().
+ */
char *uaccess_lock_user_string(CPUArchState *env, target_ulong addr);
+/**
+ * uaccess_lock_user_string:
+ *
+ * The returned string should be freed using unlock_user().
+ */
#define lock_user_string(p) uaccess_lock_user_string(env, p)
void uaccess_unlock_user(CPUArchState *env, void *p,
--
2.39.5
- [PULL 00/37] maintainer updates for gdb, plugins, documentation and windows builds, Alex Bennée, 2025/01/17
- [PULL 04/37] semihosting/uaccess: Include missing 'exec/cpu-all.h' header, Alex Bennée, 2025/01/17
- [PULL 05/37] semihosting/arm-compat: Include missing 'cpu.h' header, Alex Bennée, 2025/01/17
- [PULL 01/37] semihosting: add guest_error logging for failed opens, Alex Bennée, 2025/01/17
- [PULL 11/37] tests/tcg/plugins/insn: remove unused callback parameter, Alex Bennée, 2025/01/17
- [PULL 08/37] system/vl: more error exit into config enumeration code, Alex Bennée, 2025/01/17
- [PULL 13/37] tests/tcg/plugins/syscall: fix 32-bit build, Alex Bennée, 2025/01/17
- [PULL 02/37] semihosting/uaccess: Briefly document returned values,
Alex Bennée <=
- [PULL 07/37] semihosting/meson: Build config.o and console.o once, Alex Bennée, 2025/01/17
- [PULL 21/37] configure: reenable plugins by default for 32-bit hosts, Alex Bennée, 2025/01/17
- [PULL 03/37] semihosting/syscalls: Include missing 'exec/cpu-defs.h' header, Alex Bennée, 2025/01/17
- [PULL 18/37] contrib/plugins/cflow: fix 32-bit build, Alex Bennée, 2025/01/17
- [PULL 16/37] contrib/plugins/cache: fix 32-bit build, Alex Bennée, 2025/01/17
- [PULL 17/37] contrib/plugins/hotblocks: fix 32-bit build, Alex Bennée, 2025/01/17
- [PULL 10/37] system: propagate Error to gdbserver_start (and other device setups), Alex Bennée, 2025/01/17
- [PULL 15/37] contrib/plugins/stoptrigger: fix 32-bit build, Alex Bennée, 2025/01/17
- [PULL 23/37] win32: remove usage of attribute gcc_struct, Alex Bennée, 2025/01/17
- [PULL 12/37] contrib/plugins/howvec: ensure we don't regress if this plugin is extended, Alex Bennée, 2025/01/17