Special-case CTL_ALIAS instead of CTL_DNS in udp loopback test.
authorbalrog <balrog@c046a42c-6fe2-441c-8c8c-71466251a162>
Sat, 10 May 2008 01:49:53 +0000 (01:49 +0000)
committerbalrog <balrog@c046a42c-6fe2-441c-8c8c-71466251a162>
Sat, 10 May 2008 01:49:53 +0000 (01:49 +0000)
At the same time remove a bogus test (tested by Jason Wessel).
Quiet some gcc4 warnings from slirp compilation.

git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@4402 c046a42c-6fe2-441c-8c8c-71466251a162

slirp/if.c
slirp/misc.c
slirp/socket.c
slirp/udp.c

index 67a7b6ff82580210a30db97a2ddd7f18a8f1a7ae..361d7f3640e545c7735ee3db3bcbbbfc40a47384 100644 (file)
@@ -291,7 +291,7 @@ if_start(void)
        }
 
        /* Encapsulate the packet for sending */
-        if_encap(ifm->m_data, ifm->m_len);
+        if_encap((uint8_t *)ifm->m_data, ifm->m_len);
 
         m_free(ifm);
 
index 14808fe21d3e3c10ff696c580edd45dcc923bc8b..337f8a857472131eb9269129880deebf5f8eb3e2 100644 (file)
@@ -304,7 +304,7 @@ fork_exec(struct socket *so, const char *ex, int do_pty)
 {
        int s;
        struct sockaddr_in addr;
-       int addrlen = sizeof(addr);
+       socklen_t addrlen = sizeof(addr);
        int opt;
         int master = -1;
        char *argv[256];
index 0c15132eae901a9d4361844db32c4584de6ea538..75003af15330b9f8beabf2faf50557d6e8dc5cb3 100644 (file)
@@ -392,7 +392,7 @@ sorecvfrom(so)
        struct socket *so;
 {
        struct sockaddr_in addr;
-       int addrlen = sizeof(struct sockaddr_in);
+       socklen_t addrlen = sizeof(struct sockaddr_in);
 
        DEBUG_CALL("sorecvfrom");
        DEBUG_ARG("so = %lx", (long)so);
@@ -545,7 +545,8 @@ solisten(port, laddr, lport, flags)
 {
        struct sockaddr_in addr;
        struct socket *so;
-       int s, addrlen = sizeof(addr), opt = 1;
+       int s, opt = 1;
+       socklen_t addrlen = sizeof(addr);
 
        DEBUG_CALL("solisten");
        DEBUG_ARG("port = %d", port);
index 3f0c08b3b1f70820aef53e9f46688bec31133d8c..0583d7e9795645504f89d09c93dfdc17b810c5bd 100644 (file)
@@ -322,7 +322,7 @@ int udp_output(struct socket *so, struct mbuf *m,
         if ((so->so_faddr.s_addr & htonl(0x000000ff)) == htonl(0xff))
             saddr.sin_addr.s_addr = alias_addr.s_addr;
         else if (addr->sin_addr.s_addr == loopback_addr.s_addr ||
-                 ((so->so_faddr.s_addr & htonl(CTL_DNS)) == htonl(CTL_DNS)))
+                 (ntohl(so->so_faddr.s_addr) & 0xff) != CTL_ALIAS)
             saddr.sin_addr.s_addr = so->so_faddr.s_addr;
     }
     daddr.sin_addr = so->so_laddr;
@@ -410,7 +410,7 @@ static void
 udp_emu(struct socket *so, struct mbuf *m)
 {
        struct sockaddr_in addr;
-        int addrlen = sizeof(addr);
+       socklen_t addrlen = sizeof(addr);
 #ifdef EMULATE_TALK
        CTL_MSG_OLD *omsg;
        CTL_MSG *nmsg;
@@ -641,7 +641,7 @@ udp_listen(port, laddr, lport, flags)
 {
        struct sockaddr_in addr;
        struct socket *so;
-       int addrlen = sizeof(struct sockaddr_in), opt = 1;
+       socklen_t addrlen = sizeof(struct sockaddr_in), opt = 1;
 
        if ((so = socreate()) == NULL) {
                free(so);