Correzione per gestire IPv4 e IPv6, fase 1
authorSimone Piccardi <piccardi@gnulinux.it>
Tue, 7 Dec 2004 00:38:00 +0000 (00:38 +0000)
committerSimone Piccardi <piccardi@gnulinux.it>
Tue, 7 Dec 2004 00:38:00 +0000 (00:38 +0000)
sources/TCP_echod.c
sources/sockbind.c
sources/sockconn.c

index 7062c3b8e658ff0ec7a7f524fffd1dd5951313c2..f0eab95c2f7c5064b3bb8611eb684eef27629d35 100644 (file)
@@ -116,7 +116,7 @@ int main(int argc, char *argv[])
        SignalRestart(SIGCHLD, HandSigCHLD);  /* restarting handler */
     }
     /* create and bind socket */
-    if ( (list_fd = sockbind(argv[optind], "echo", 6, SOCK_STREAM)) < 0) {
+    if ( (list_fd = sockbind(NULL, "echo", 6, SOCK_STREAM)) < 0) {
        if (errno) perror("Socket creation error");
        return 1;
     }   
index 3e31fe7e9c4998880793828ea0c20a63e450a51e..4ecbe97962ac8a8c6cd41f6fdf69a73652da944a 100644 (file)
@@ -37,7 +37,7 @@
 
 int sockbind(char *host, char *serv, int prot, int type) 
 {
-    struct addrinfo hint, *addr;
+    struct addrinfo hint, *addr, *save;
     int res;
     int sock;
     /* initialize hint structure */
@@ -50,20 +50,26 @@ int sockbind(char *host, char *serv, int prot, int type)
     if (res != 0) {                                /* on error exit */
        printf("sockbind cannot resolve host %s, service %s, ", host, serv);
        printf("protocol %d: %s\n", prot, gai_strerror(res));
+       errno = 0;                                 /* clear errno */
        return -1;
     }
-    /* get a socket */
-    sock = socket(addr->ai_family, addr->ai_socktype, addr->ai_protocol);
-    if (sock < 0) {
-       printf("sockconn cannot create socket\n");
-       return sock;
+    /* loop on possible addresses */
+    save = addr;
+    while (addr != NULL) {
+       /* get a socket */
+       sock = socket(addr->ai_family, addr->ai_socktype, addr->ai_protocol);
+       if ( (sock < 0) && (addr->ai_next == NULL) ) {
+           printf("sockbind cannot create socket\n");
+           return sock;
+       } else continue;
+       /* connect the socket */
+       res = bind(sock, addr->ai_addr, addr->ai_addrlen);
+       if ( (res < 0) && (addr->ai_next == NULL) ) {
+           printf("sockbind cannot bind socket\n");
+           return res;
+       }
+       addr=addr->ai_next;
     }
-    /* connect the socket */
-    res = bind(sock, addr->ai_addr, addr->ai_addrlen);
-    if (res < 0) {
-       printf("sockconn cannot bind socket\n");
-       return res;
-    }
-    freeaddrinfo(addr);         /* done, release memory */
+    freeaddrinfo(save);                            /* done, release memory */
     return sock;
 }
index 81c982d0481ec37036f48aa5167b70a9efd88867..952910a362892377c9318a45030e5af87652efaa 100644 (file)
@@ -37,7 +37,7 @@
 
 int sockconn(char *host, char *serv, int prot, int type) 
 {
-    struct addrinfo hint, *addr;
+    struct addrinfo hint, *addr, *save;
     int res;
     int sock;
     /* initialize hint structure */
@@ -49,20 +49,36 @@ int sockconn(char *host, char *serv, int prot, int type)
     if (res != 0) {                                /* on error exit */
        printf("sockconn cannot resolve host %s, service %s, ", host, serv);
        printf("protocol %d: %s\n", prot, gai_strerror(res));
+       errno = 0;                                 /* clear errno */
        return -1;
     }
-    /* get a socket */
-    sock = socket(addr->ai_family, addr->ai_socktype, addr->ai_protocol);
-    if (sock < 0) {
-       printf("sockconn cannot create socket\n");
-       return sock;
+    /* loop on possible addresses */
+    save = addr;
+    while (addr != NULL) {
+       /* get a socket */
+       sock = socket(addr->ai_family, addr->ai_socktype, addr->ai_protocol);
+       if (sock < 0) {
+           if (addr->ai_next == NULL) {
+               addr=addr->ai_next;
+               continue;
+           } else {
+               printf("sockconn cannot create socket\n");
+               return sock;
+           }
+       }
+       /* connect the socket */
+       res = connect(sock, addr->ai_addr, addr->ai_addrlen);
+       if (res < 0) {
+           if (addr->ai_next == NULL) {
+               close(sock);
+               addr=addr->ai_next;
+               continue;
+           } else {
+               printf("sockconn cannot connect socket\n");
+               return res;
+           }
+       }
     }
-    /* connect the socket */
-    res = connect(sock, addr->ai_addr, addr->ai_addrlen);
-    if (res < 0) {
-       printf("sockconn cannot connect socket\n");
-       return res;
-    }
-    freeaddrinfo(addr);         /* done, release memory */
+    freeaddrinfo(save);         /* done, release memory */
     return sock;
 }