qemu-devel
[Top][All Lists]
Advanced

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

Re: [Qemu-devel] [PATCH v2 for-3.2 v2 02/30] slirp: drop <Vista compatib


From: Marc-André Lureau
Subject: Re: [Qemu-devel] [PATCH v2 for-3.2 v2 02/30] slirp: drop <Vista compatibility
Date: Thu, 22 Nov 2018 14:22:30 +0400

Hi

On Thu, Nov 22, 2018 at 2:10 AM Marc-André Lureau
<address@hidden> wrote:
>
> Since commit 12f8def0e02232d7c6416ad9b66640f973c531d1 (v2.9), qemu
> requires Vista. Let's remove some conditional code.
>
> Note that this introduces a missing declaration warning with mingw.
> warning: implicit declaration of function 'inet_ntop'
>
> See also: https://sourceforge.net/p/mingw-w64/mailman/message/36473782/
>
> We could workaround it by declaring it ourself depending on 
> __MINGW64_VERSION_*:
> WINSOCK_API_LINKAGE INT WSAAPI inet_pton(int Family, PCTSTR pszAddrString, 
> PVOID pAddrBuf);

It turns out the warning is because _WIN32_WINNT is not defined to a
recent enough version.
I am sending a tiny seperate win32 build-sys series, it should be
applied before this patch, to avoid the temporary regression. And you
can drop this Note from the commit message.

thanks

>
> Signed-off-by: Marc-André Lureau <address@hidden>
> ---
>  net/slirp.c       | 22 ----------------------
>  slirp/ip6_icmp.c  | 10 ++++------
>  slirp/ndp_table.c | 14 ++++++--------
>  3 files changed, 10 insertions(+), 36 deletions(-)
>
> diff --git a/net/slirp.c b/net/slirp.c
> index 30eda2cca1..4d890287ba 100644
> --- a/net/slirp.c
> +++ b/net/slirp.c
> @@ -290,17 +290,6 @@ static int net_slirp_init(NetClientState *peer, const 
> char *model,
>      }
>  #endif
>
> -#if defined(_WIN32) && (_WIN32_WINNT < 0x0600)
> -    /* No inet_pton helper before Vista... */
> -    if (vprefix6) {
> -        /* Unsupported */
> -        error_setg(errp, "IPv6 prefix not supported");
> -        return -1;
> -    }
> -    memset(&ip6_prefix, 0, sizeof(ip6_prefix));
> -    ip6_prefix.s6_addr[0] = 0xfe;
> -    ip6_prefix.s6_addr[1] = 0xc0;
> -#else
>      if (!vprefix6) {
>          vprefix6 = "fec0::";
>      }
> @@ -308,7 +297,6 @@ static int net_slirp_init(NetClientState *peer, const 
> char *model,
>          error_setg(errp, "Failed to parse IPv6 prefix");
>          return -1;
>      }
> -#endif
>
>      if (!vprefix6_len) {
>          vprefix6_len = 64;
> @@ -320,10 +308,6 @@ static int net_slirp_init(NetClientState *peer, const 
> char *model,
>      }
>
>      if (vhost6) {
> -#if defined(_WIN32) && (_WIN32_WINNT < 0x0600)
> -        error_setg(errp, "IPv6 host not supported");
> -        return -1;
> -#else
>          if (!inet_pton(AF_INET6, vhost6, &ip6_host)) {
>              error_setg(errp, "Failed to parse IPv6 host");
>              return -1;
> @@ -332,17 +316,12 @@ static int net_slirp_init(NetClientState *peer, const 
> char *model,
>              error_setg(errp, "IPv6 Host doesn't belong to network");
>              return -1;
>          }
> -#endif
>      } else {
>          ip6_host = ip6_prefix;
>          ip6_host.s6_addr[15] |= 2;
>      }
>
>      if (vnameserver6) {
> -#if defined(_WIN32) && (_WIN32_WINNT < 0x0600)
> -        error_setg(errp, "IPv6 DNS not supported");
> -        return -1;
> -#else
>          if (!inet_pton(AF_INET6, vnameserver6, &ip6_dns)) {
>              error_setg(errp, "Failed to parse IPv6 DNS");
>              return -1;
> @@ -351,7 +330,6 @@ static int net_slirp_init(NetClientState *peer, const 
> char *model,
>              error_setg(errp, "IPv6 DNS doesn't belong to network");
>              return -1;
>          }
> -#endif
>      } else {
>          ip6_dns = ip6_prefix;
>          ip6_dns.s6_addr[15] |= 3;
> diff --git a/slirp/ip6_icmp.c b/slirp/ip6_icmp.c
> index 3f74d172f4..595a62c8d4 100644
> --- a/slirp/ip6_icmp.c
> +++ b/slirp/ip6_icmp.c
> @@ -74,6 +74,7 @@ void icmp6_send_error(struct mbuf *m, uint8_t type, uint8_t 
> code)
>      Slirp *slirp = m->slirp;
>      struct mbuf *t;
>      struct ip6 *ip = mtod(m, struct ip6 *);
> +    char addrstr[INET6_ADDRSTRLEN];
>
>      DEBUG_CALL("icmp6_send_error");
>      DEBUG_ARGS(" type = %d, code = %d\n", type, code);
> @@ -90,11 +91,8 @@ void icmp6_send_error(struct mbuf *m, uint8_t type, 
> uint8_t code)
>      struct ip6 *rip = mtod(t, struct ip6 *);
>      rip->ip_src = (struct in6_addr)LINKLOCAL_ADDR;
>      rip->ip_dst = ip->ip_src;
> -#if !defined(_WIN32) || (_WIN32_WINNT >= 0x0600)
> -    char addrstr[INET6_ADDRSTRLEN];
>      inet_ntop(AF_INET6, &rip->ip_dst, addrstr, INET6_ADDRSTRLEN);
>      DEBUG_ARG("target = %s", addrstr);
> -#endif
>
>      rip->ip_nh = IPPROTO_ICMPV6;
>      const int error_data_len = MIN(m->m_len,
> @@ -222,12 +220,12 @@ void ndp_send_ra(Slirp *slirp)
>   */
>  void ndp_send_ns(Slirp *slirp, struct in6_addr addr)
>  {
> -    DEBUG_CALL("ndp_send_ns");
> -#if !defined(_WIN32) || (_WIN32_WINNT >= 0x0600)
>      char addrstr[INET6_ADDRSTRLEN];
> +
>      inet_ntop(AF_INET6, &addr, addrstr, INET6_ADDRSTRLEN);
> +
> +    DEBUG_CALL("ndp_send_ns");
>      DEBUG_ARG("target = %s", addrstr);
> -#endif
>
>      /* Build IPv6 packet */
>      struct mbuf *t = m_get(slirp);
> diff --git a/slirp/ndp_table.c b/slirp/ndp_table.c
> index a4e6421fd3..1401e1b322 100644
> --- a/slirp/ndp_table.c
> +++ b/slirp/ndp_table.c
> @@ -10,15 +10,14 @@
>  void ndp_table_add(Slirp *slirp, struct in6_addr ip_addr,
>                      uint8_t ethaddr[ETH_ALEN])
>  {
> +    char addrstr[INET6_ADDRSTRLEN];
>      NdpTable *ndp_table = &slirp->ndp_table;
>      int i;
>
> -    DEBUG_CALL("ndp_table_add");
> -#if !defined(_WIN32) || (_WIN32_WINNT >= 0x0600)
> -    char addrstr[INET6_ADDRSTRLEN];
>      inet_ntop(AF_INET6, &(ip_addr), addrstr, INET6_ADDRSTRLEN);
> +
> +    DEBUG_CALL("ndp_table_add");
>      DEBUG_ARG("ip = %s", addrstr);
> -#endif
>      DEBUG_ARGS(" hw addr = %02x:%02x:%02x:%02x:%02x:%02x\n",
>                 ethaddr[0], ethaddr[1], ethaddr[2],
>                 ethaddr[3], ethaddr[4], ethaddr[5]);
> @@ -50,15 +49,14 @@ void ndp_table_add(Slirp *slirp, struct in6_addr ip_addr,
>  bool ndp_table_search(Slirp *slirp, struct in6_addr ip_addr,
>                        uint8_t out_ethaddr[ETH_ALEN])
>  {
> +    char addrstr[INET6_ADDRSTRLEN];
>      NdpTable *ndp_table = &slirp->ndp_table;
>      int i;
>
> -    DEBUG_CALL("ndp_table_search");
> -#if !defined(_WIN32) || (_WIN32_WINNT >= 0x0600)
> -    char addrstr[INET6_ADDRSTRLEN];
>      inet_ntop(AF_INET6, &(ip_addr), addrstr, INET6_ADDRSTRLEN);
> +
> +    DEBUG_CALL("ndp_table_search");
>      DEBUG_ARG("ip = %s", addrstr);
> -#endif
>
>      assert(!in6_zero(&ip_addr));
>
> --
> 2.20.0.rc1
>
>


-- 
Marc-André Lureau



reply via email to

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