Le 12/03/2020 à 17:55, Laurent Vivier a écrit :
> print_socket_type() doesn't manage flags and the correct type cannot
> be displayed
> 
> Signed-off-by: Laurent Vivier <laur...@vivier.eu>
> ---
> 
> Notes:
>     v2: replace gemu_log() by qemu_log() as it has been removed from qemu
> 
>  linux-user/strace.c | 8 +++++++-
>  1 file changed, 7 insertions(+), 1 deletion(-)
> 
> diff --git a/linux-user/strace.c b/linux-user/strace.c
> index 4f7130b2ff63..69232f7e27b8 100644
> --- a/linux-user/strace.c
> +++ b/linux-user/strace.c
> @@ -444,7 +444,7 @@ print_socket_domain(int domain)
>  static void
>  print_socket_type(int type)
>  {
> -    switch (type) {
> +    switch (type & TARGET_SOCK_TYPE_MASK) {
>      case TARGET_SOCK_DGRAM:
>          qemu_log("SOCK_DGRAM");
>          break;
> @@ -464,6 +464,12 @@ print_socket_type(int type)
>          qemu_log("SOCK_PACKET");
>          break;
>      }
> +    if (type & TARGET_SOCK_CLOEXEC) {
> +        qemu_log("|SOCK_CLOEXEC");
> +    }
> +    if (type & TARGET_SOCK_NONBLOCK) {
> +        qemu_log("|SOCK_NONBLOCK");
> +    }
>  }
>  
>  static void
> 

Applied to my linux-user branch.

Thanks,
Laurent

Reply via email to