qemu-user: Impl. setsockopt(SO_BINDTODEVICE)
authorJoakim Tjernlund <joakim.tjernlund@transmode.se>
Sat, 12 Jul 2014 13:47:06 +0000 (15:47 +0200)
committerRiku Voipio <riku.voipio@linaro.org>
Tue, 15 Jul 2014 13:28:20 +0000 (16:28 +0300)
Signed-off-by: Joakim Tjernlund <Joakim.Tjernlund@transmode.se>
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
Signed-off-by: Riku Voipio <riku.voipio@linaro.org>
linux-user/syscall.c

index 5a272d3d08bfa7feeb1d7e0579636e9c26538e04..dcf13238e59148dfd753818ab833c02ad7e8dc25 100644 (file)
@@ -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;