From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([208.118.235.92]:57222) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1Sqaon-0003M3-0R for qemu-devel@nongnu.org; Sun, 15 Jul 2012 22:13:49 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1Sqaom-0002Lb-3T for qemu-devel@nongnu.org; Sun, 15 Jul 2012 22:13:48 -0400 Received: from mail-gh0-f173.google.com ([209.85.160.173]:54995) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1Sqaol-0002LU-Vn for qemu-devel@nongnu.org; Sun, 15 Jul 2012 22:13:48 -0400 Received: by ghrr14 with SMTP id r14so5134295ghr.4 for ; Sun, 15 Jul 2012 19:13:47 -0700 (PDT) From: Jing Huang Date: Mon, 16 Jul 2012 10:14:12 +0000 Message-Id: <1342433652-3339-1-git-send-email-jing.huang.pku@gmail.com> In-Reply-To: References: Subject: [Qemu-devel] [PATCH v2 2/3] linux-user: make do_setsockopt support SOL_RAW ICMP_FILTER socket option List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org Cc: peter.maydell@linaro.org, riku.voipio@iki.fi, jing.huang.pku@gmail.com This patch makes do_setsockopt() support SOL_RAW ICMP_FILTER socket option. Signed-off-by: Jing Huang --- linux-user/syscall.c | 20 ++++++++++++++++++++ 1 files changed, 20 insertions(+), 0 deletions(-) diff --git a/linux-user/syscall.c b/linux-user/syscall.c index 28c8ba5..fc8690d 100644 --- a/linux-user/syscall.c +++ b/linux-user/syscall.c @@ -60,6 +60,7 @@ int __clone2(int (*fn)(void *), void *child_stack_base, #include #include #include +#include #include "qemu-common.h" #ifdef TARGET_GPROF #include @@ -1442,6 +1443,25 @@ static abi_long do_setsockopt(int sockfd, int level, int optname, goto unimplemented; } break; + case SOL_RAW: + switch (optname) { + case ICMP_FILTER: + /*struct icmp_filter takes an u32 value*/ + optname = ICMP_FILTER; + if (optlen < sizeof(uint32_t)) { + return -TARGET_EINVAL; + } + + if (get_user_u32(val, optval_addr)) { + return -TARGET_EFAULT; + } + ret = get_errno(setsockopt(sockfd, level, optname, + (char *)&val, sizeof(val))); + break; + default: + goto unimplemented; + } + break; case TARGET_SOL_SOCKET: switch (optname) { /* Options with 'int' argument. */ -- 1.7.8.6