qemu-devel
[Top][All Lists]
Advanced

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

Re: [PATCH v2] linux-user: Fix SO_ERROR return code of getsockopt()


From: Laurent Vivier
Subject: Re: [PATCH v2] linux-user: Fix SO_ERROR return code of getsockopt()
Date: Mon, 30 Jan 2023 09:42:18 +0100
User-agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.6.0

Le 27/01/2023 à 21:25, Helge Deller a écrit :
Add translation for the host error return code of:
     getsockopt(19, SOL_SOCKET, SO_ERROR, [ECONNREFUSED], [4]) = 0

This fixes the testsuite of the cockpit debian package with a
hppa-linux guest on a x86-64 host.

Signed-off-by: Helge Deller <deller@gmx.de>
---
v2: Fix indenting to make checkscript.sh happy


diff --git a/linux-user/syscall.c b/linux-user/syscall.c
index dac0cfe6c4..06e8612675 100644
--- a/linux-user/syscall.c
+++ b/linux-user/syscall.c
@@ -2809,8 +2809,13 @@ get_timeout:
          ret = get_errno(getsockopt(sockfd, level, optname, &val, &lv));
          if (ret < 0)
              return ret;
-        if (optname == SO_TYPE) {
+        switch (optname) {
+        case SO_TYPE:
              val = host_to_target_sock_type(val);
+            break;
+        case SO_ERROR:
+            val = host_to_target_errno(val);
+            break;
          }
          if (len > lv)
              len = lv;


Reviewed-by: Laurent Vivier <laurent@vivier.eu>



reply via email to

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