qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH v3 08/49] semihosting: Inline set_swi_errno into common_semi_


From: Richard Henderson
Subject: Re: [PATCH v3 08/49] semihosting: Inline set_swi_errno into common_semi_cb
Date: Mon, 23 May 2022 07:58:07 -0700
User-agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.8.0

On 5/23/22 03:58, Peter Maydell wrote:
On Sat, 21 May 2022 at 01:04, Richard Henderson
<richard.henderson@linaro.org> wrote:

Do not store 'err' into errno only to read it back immediately.
Use 'ret' for the return value, not 'reg0'.

Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
---
  semihosting/arm-compat-semi.c | 19 ++++++++++---------
  1 file changed, 10 insertions(+), 9 deletions(-)

diff --git a/semihosting/arm-compat-semi.c b/semihosting/arm-compat-semi.c
index c6bfd4d1ba..b00ed2c6d1 100644
--- a/semihosting/arm-compat-semi.c
+++ b/semihosting/arm-compat-semi.c
@@ -290,28 +290,29 @@ static target_ulong common_semi_syscall_len;

  static void common_semi_cb(CPUState *cs, target_ulong ret, target_ulong err)
  {
-    target_ulong reg0 = common_semi_arg(cs, 0);
-
      if (ret == (target_ulong)-1) {
-        errno = err;
-        set_swi_errno(cs, -1);
-        reg0 = ret;
+#ifdef CONFIG_USER_ONLY
+        TaskState *ts = cs->opaque;
+        ts->swi_errno = err;
+#else
+        syscall_err = err;
+#endif
      } else {
          /* Fixup syscalls that use nonstardard return conventions.  */
+        target_ulong reg0 = common_semi_arg(cs, 0);

This should be "ret = ", right? (Otherwise I think this fails to
compile. I assume that some later patch has this fix in it.)

Eh?  No, we're extracting argument reg 0, and then switching on it.
Why would it not compile -- I've moved the whole declaration down.


r~



Otherwise
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>

thanks
-- PMM




reply via email to

[Prev in Thread] Current Thread [Next in Thread]