qemu-devel
[Top][All Lists]
Advanced

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

Re: [Qemu-devel] [PATCH 1/2 v3] qemu-user: Impl. setsockopt(SO_BINDTODEV


From: Riku Voipio
Subject: Re: [Qemu-devel] [PATCH 1/2 v3] qemu-user: Impl. setsockopt(SO_BINDTODEVICE)
Date: Tue, 15 Jul 2014 16:33:14 +0300
User-agent: Mutt/1.5.21 (2010-09-15)

On Sat, Jul 12, 2014 at 03:47:06PM +0200, Joakim Tjernlund wrote:
> Signed-off-by: Joakim Tjernlund <address@hidden>

Thanks, applied to linux-user tree,
Riku

> ---
>  linux-user/syscall.c | 19 +++++++++++++++++++
>  1 file changed, 19 insertions(+)
> 
> diff --git a/linux-user/syscall.c b/linux-user/syscall.c
> index 57c1664..3ef046a 100644
> --- a/linux-user/syscall.c
> +++ b/linux-user/syscall.c
> @@ -1497,6 +1497,25 @@ set_timeout:
>                  unlock_user_struct(tfprog, optval_addr, 1);
>                  return ret;
>          }
> +     case TARGET_SO_BINDTODEVICE:
> +     {
> +             char *dev_ifname, *addr_ifname;
> +
> +             if (optlen > IFNAMSIZ - 1) {
> +                 optlen = IFNAMSIZ - 1;
> +             }
> +             dev_ifname = lock_user(VERIFY_READ, optval_addr, optlen, 1);
> +             if (!dev_ifname) {
> +                 return -TARGET_EFAULT;
> +             }
> +             optname = SO_BINDTODEVICE;
> +             addr_ifname = alloca(IFNAMSIZ);
> +             memcpy(addr_ifname, dev_ifname, optlen);
> +             addr_ifname[optlen] = 0;
> +             ret = get_errno(setsockopt(sockfd, level, optname, addr_ifname, 
> optlen));
> +             unlock_user (dev_ifname, optval_addr, 0);
> +             return ret;
> +     }
>              /* Options with 'int' argument.  */
>          case TARGET_SO_DEBUG:
>               optname = SO_DEBUG;
> -- 
> 1.8.5.5
> 



reply via email to

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