From: Joakim Tjernlund Date: Sat, 12 Jul 2014 13:47:06 +0000 (+0200) Subject: qemu-user: Impl. setsockopt(SO_BINDTODEVICE) X-Git-Tag: qemu-xen-4.6.0-rc1~305^2~3 X-Git-Url: http://xenbits.xensource.com/gitweb?a=commitdiff_plain;h=451aaf688c709c91a0d511c24624104677cc754e;p=qemu-upstream-4.6-testing.git qemu-user: Impl. setsockopt(SO_BINDTODEVICE) Signed-off-by: Joakim Tjernlund Reviewed-by: Peter Maydell Signed-off-by: Riku Voipio --- diff --git a/linux-user/syscall.c b/linux-user/syscall.c index 5a272d3d0..dcf13238e 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;