--- rpl/src/instructions_w1.c 2011/11/26 10:01:32 1.53 +++ rpl/src/instructions_w1.c 2011/12/02 10:43:22 1.54 @@ -2685,6 +2685,8 @@ instruction_wfsock(struct_processus *s_e struct_objet *s_objet_argument; struct_objet *s_objet_resultat; + struct pollfd s_poll; + struct sockaddr_in adresse_ipv4; # ifdef IPV6 struct sockaddr_in6 adresse_ipv6; @@ -2738,375 +2740,430 @@ instruction_wfsock(struct_processus *s_e "STREAM") != 0) && (strcmp((*((struct_socket *) (*s_objet_argument).objet)).type, "SEQUENTIAL DATAGRAM") != 0)) { - liberation(s_etat_processus, s_objet_argument); + // Mode non connecté : l'attente se fait sur un poll() - (*s_etat_processus).erreur_execution = d_ex_erreur_acces_fichier; - return; - } + if ((s_objet_resultat = copie_objet(s_etat_processus, + s_objet_argument, 'P')) == NULL) + { + (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; + return; + } - if ((s_objet_resultat = copie_objet(s_etat_processus, s_objet_argument, - 'O')) == NULL) - { - (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; - return; - } + s_poll.fd = (*((struct_socket *) (*s_objet_argument).objet)).socket; + s_poll.events = POLLIN; + s_poll.revents = 0; + + while(poll(&s_poll, 1, -1) < 0) + { + if (errno != EINTR) + { + (*s_etat_processus).erreur_systeme = + d_es_erreur_fichier; + return; + } + } - (*((struct_socket *) (*s_objet_resultat).objet)).socket_en_ecoute = 'N'; - (*((struct_socket *) (*s_objet_resultat).objet)).effacement = 'N'; + if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile), + s_objet_argument) == d_erreur) + { + return; + } - if ((*((struct_socket *) (*s_objet_resultat).objet)).domaine == PF_INET) + if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile), + s_objet_resultat) == d_erreur) + { + return; + } + } + else { - longueur = sizeof(adresse_ipv4); + // Mode connecté - do + if ((s_objet_resultat = copie_objet(s_etat_processus, + s_objet_argument, 'O')) == NULL) { - drapeau = d_vrai; + (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; + return; + } + + (*((struct_socket *) (*s_objet_resultat).objet)).effacement = 'N'; + (*((struct_socket *) (*s_objet_resultat).objet)).socket_en_ecoute + = 'N'; + + if ((*((struct_socket *) (*s_objet_resultat).objet)).domaine == + PF_INET) + { + longueur = sizeof(adresse_ipv4); + + do + { + drapeau = d_vrai; # ifndef SEMAPHORES_NOMMES - if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0) + if (sem_post(&((*s_etat_processus).semaphore_fork)) + != 0) # else - if (sem_post((*s_etat_processus).semaphore_fork) != 0) + if (sem_post((*s_etat_processus).semaphore_fork) != 0) # endif - { - (*s_etat_processus).erreur_systeme = d_es_processus; - return; - } + { + (*s_etat_processus).erreur_systeme = d_es_processus; + return; + } - if (((*((struct_socket *) (*s_objet_resultat).objet)).socket = - accept((*((struct_socket *) (*s_objet_argument).objet)) - .socket, (struct sockaddr *) &adresse_ipv4, &longueur)) - < 0) - { - erreur = errno; + if (((*((struct_socket *) (*s_objet_resultat).objet)) + .socket = accept((*((struct_socket *) + (*s_objet_argument).objet)).socket, + (struct sockaddr *) &adresse_ipv4, &longueur)) + < 0) + { + erreur = errno; # ifndef SEMAPHORES_NOMMES - while(sem_wait(&((*s_etat_processus).semaphore_fork)) - != 0) + while(sem_wait(&((*s_etat_processus) + .semaphore_fork)) != 0) # else - while(sem_wait((*s_etat_processus).semaphore_fork) != 0) + while(sem_wait((*s_etat_processus).semaphore_fork) + != 0) # endif - { - if (errno != EINTR) { - (*s_etat_processus).erreur_systeme = d_es_processus; - return; + if (errno != EINTR) + { + (*s_etat_processus).erreur_systeme = + d_es_processus; + return; + } } - } - if (erreur != EINTR) - { - liberation(s_etat_processus, s_objet_argument); - liberation(s_etat_processus, s_objet_resultat); + if (erreur != EINTR) + { + liberation(s_etat_processus, s_objet_argument); + liberation(s_etat_processus, s_objet_resultat); - (*s_etat_processus).erreur_execution = - d_ex_erreur_acces_fichier; - return; - } + (*s_etat_processus).erreur_execution = + d_ex_erreur_acces_fichier; + return; + } - scrutation_injection(s_etat_processus); + scrutation_injection(s_etat_processus); - if ((*s_etat_processus).var_volatile_requete_arret != 0) - { - drapeau = d_vrai; + if ((*s_etat_processus).var_volatile_requete_arret != 0) + { + drapeau = d_vrai; + } + else + { + drapeau = d_faux; + } } else { - drapeau = d_faux; - } - } - else - { # ifndef SEMAPHORES_NOMMES - while(sem_wait(&((*s_etat_processus).semaphore_fork)) - != 0) + while(sem_wait(&((*s_etat_processus) + .semaphore_fork)) != 0) # else - while(sem_wait((*s_etat_processus).semaphore_fork) != 0) + while(sem_wait((*s_etat_processus).semaphore_fork) + != 0) # endif - { - if (errno != EINTR) { - (*s_etat_processus).erreur_systeme = d_es_processus; - return; + if (errno != EINTR) + { + (*s_etat_processus).erreur_systeme = + d_es_processus; + return; + } } } + } while(drapeau == d_faux); + + if (((*((struct_socket *) (*s_objet_resultat).objet)) + .adresse_distante = malloc(22 * + sizeof(unsigned char))) == NULL) + { + (*s_etat_processus).erreur_systeme = + d_es_allocation_memoire; + return; } - } while(drapeau == d_faux); - if (((*((struct_socket *) (*s_objet_resultat).objet)) - .adresse_distante = malloc(22 * - sizeof(unsigned char))) == NULL) - { - (*s_etat_processus).erreur_systeme = - d_es_allocation_memoire; - return; + sprintf((*((struct_socket *) (*s_objet_resultat).objet)) + .adresse_distante, "%d.%d.%d.%d(%d)", + (ntohl(adresse_ipv4.sin_addr.s_addr) >> 24) & 0xFF, + (ntohl(adresse_ipv4.sin_addr.s_addr) >> 16) & 0xFF, + (ntohl(adresse_ipv4.sin_addr.s_addr) >> 8) & 0xFF, + ntohl(adresse_ipv4.sin_addr.s_addr) & 0xFF, + ntohs(adresse_ipv4.sin_port)); } - - sprintf((*((struct_socket *) (*s_objet_resultat).objet)) - .adresse_distante, "%d.%d.%d.%d(%d)", - (ntohl(adresse_ipv4.sin_addr.s_addr) >> 24) & 0xFF, - (ntohl(adresse_ipv4.sin_addr.s_addr) >> 16) & 0xFF, - (ntohl(adresse_ipv4.sin_addr.s_addr) >> 8) & 0xFF, - ntohl(adresse_ipv4.sin_addr.s_addr) & 0xFF, - ntohs(adresse_ipv4.sin_port)); - } - else if ((*((struct_socket *) (*s_objet_resultat).objet)).domaine == - PF_INET6) - { + else if ((*((struct_socket *) (*s_objet_resultat).objet)).domaine == + PF_INET6) + { # ifdef IPV6 - longueur = sizeof(adresse_ipv6); + longueur = sizeof(adresse_ipv6); - do - { - drapeau = d_vrai; + do + { + drapeau = d_vrai; # ifndef SEMAPHORES_NOMMES - if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0) + if (sem_post(&((*s_etat_processus).semaphore_fork)) + != 0) # else - if (sem_post((*s_etat_processus).semaphore_fork) != 0) + if (sem_post((*s_etat_processus).semaphore_fork) != 0) # endif - { - (*s_etat_processus).erreur_systeme = d_es_processus; - return; - } + { + (*s_etat_processus).erreur_systeme = d_es_processus; + return; + } - if (((*((struct_socket *) (*s_objet_resultat).objet)).socket = - accept((*((struct_socket *) (*s_objet_argument).objet)) - .socket, (struct sockaddr *) &adresse_ipv6, &longueur)) - < 0) - { - erreur = errno; + if (((*((struct_socket *) (*s_objet_resultat).objet)) + .socket = accept((*((struct_socket *) + (*s_objet_argument).objet)).socket, + (struct sockaddr *) &adresse_ipv6, &longueur)) < 0) + { + erreur = errno; # ifndef SEMAPHORES_NOMMES - while(sem_wait(&((*s_etat_processus).semaphore_fork)) - != 0) + while(sem_wait(&((*s_etat_processus) + .semaphore_fork)) != 0) # else - while(sem_wait((*s_etat_processus).semaphore_fork) != 0) + while(sem_wait((*s_etat_processus).semaphore_fork) + != 0) # endif - { - if (errno != EINTR) { - (*s_etat_processus).erreur_systeme = d_es_processus; - return; + if (errno != EINTR) + { + (*s_etat_processus).erreur_systeme = + d_es_processus; + return; + } } - } - if (erreur != EINTR) - { - liberation(s_etat_processus, s_objet_argument); - liberation(s_etat_processus, s_objet_resultat); + if (erreur != EINTR) + { + liberation(s_etat_processus, s_objet_argument); + liberation(s_etat_processus, s_objet_resultat); - (*s_etat_processus).erreur_execution = - d_ex_erreur_acces_fichier; - return; - } + (*s_etat_processus).erreur_execution = + d_ex_erreur_acces_fichier; + return; + } - scrutation_injection(s_etat_processus); + scrutation_injection(s_etat_processus); - if ((*s_etat_processus).var_volatile_requete_arret != 0) - { - drapeau = d_vrai; + if ((*s_etat_processus).var_volatile_requete_arret != 0) + { + drapeau = d_vrai; + } + else + { + drapeau = d_faux; + } } else { - drapeau = d_faux; - } - } - else - { # ifndef SEMAPHORES_NOMMES - while(sem_wait(&((*s_etat_processus).semaphore_fork)) - != 0) + while(sem_wait(&((*s_etat_processus) + .semaphore_fork)) != 0) # else - while(sem_wait((*s_etat_processus).semaphore_fork) != 0) + while(sem_wait((*s_etat_processus).semaphore_fork) + != 0) # endif - { - if (errno != EINTR) { - (*s_etat_processus).erreur_systeme = d_es_processus; - return; + if (errno != EINTR) + { + (*s_etat_processus).erreur_systeme = + d_es_processus; + return; + } } } + } while(drapeau == d_faux); + + if (((*((struct_socket *) (*s_objet_resultat).objet)) + .adresse_distante = malloc(55 * + sizeof(unsigned char))) == NULL) + { + (*s_etat_processus).erreur_systeme = + d_es_allocation_memoire; + return; } - } while(drapeau == d_faux); - if (((*((struct_socket *) (*s_objet_resultat).objet)) - .adresse_distante = malloc(55 * - sizeof(unsigned char))) == NULL) - { - (*s_etat_processus).erreur_systeme = - d_es_allocation_memoire; - return; - } + (*((struct_socket *) (*s_objet_resultat).objet)) + .adresse_distante = d_code_fin_chaine; - (*((struct_socket *) (*s_objet_resultat).objet)) - .adresse_distante = d_code_fin_chaine; + for(i = 0; i < 16; i++) + { + sprintf((*((struct_socket *) (*s_objet_resultat) + .objet)).adresse_distante, (i == 0) ? "%s%X" + : "%s:%X", (*((struct_socket *) (*s_objet_resultat) + .objet)).adresse_distante, + adresse_ipv6.sin6_addr.s6_addr[i]); + } - for(i = 0; i < 16; i++) - { sprintf((*((struct_socket *) (*s_objet_resultat) - .objet)).adresse_distante, (i == 0) ? "%s%X" : "%s:%X", + .objet)).adresse_distante, "%s(%u)", (*((struct_socket *) (*s_objet_resultat) .objet)).adresse_distante, - adresse_ipv6.sin6_addr.s6_addr[i]); - } - - sprintf((*((struct_socket *) (*s_objet_resultat) - .objet)).adresse_distante, "%s(%u)", - (*((struct_socket *) (*s_objet_resultat) - .objet)).adresse_distante, ntohs(adresse_ipv6.sin6_port)); + ntohs(adresse_ipv6.sin6_port)); # else - if ((*s_etat_processus).langue == 'F') - { - printf("+++Attention : Support du protocole" - " IPv6 indisponible\n"); + if ((*s_etat_processus).langue == 'F') + { + printf("+++Attention : Support du protocole" + " IPv6 indisponible\n"); + } + else + { + printf("+++Warning : IPv6 support " + "unavailable\n"); + } +# endif } else { - printf("+++Warning : IPv6 support " - "unavailable\n"); - } -# endif - } - else - { - longueur = 0; + longueur = 0; - do - { - drapeau = d_vrai; + do + { + drapeau = d_vrai; # ifndef SEMAPHORES_NOMMES - if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0) + if (sem_post(&((*s_etat_processus).semaphore_fork)) + != 0) # else - if (sem_post((*s_etat_processus).semaphore_fork) != 0) + if (sem_post((*s_etat_processus).semaphore_fork) != 0) # endif - { - (*s_etat_processus).erreur_systeme = d_es_processus; - return; - } + { + (*s_etat_processus).erreur_systeme = d_es_processus; + return; + } - if (((*((struct_socket *) (*s_objet_resultat).objet)).socket = - accept((*((struct_socket *) (*s_objet_argument).objet)) - .socket, NULL, &longueur)) < 0) - { - erreur = errno; + if (((*((struct_socket *) (*s_objet_resultat).objet)) + .socket = accept((*((struct_socket *) + (*s_objet_argument).objet)).socket, NULL, + &longueur)) < 0) + { + erreur = errno; # ifndef SEMAPHORES_NOMMES - while(sem_wait(&((*s_etat_processus).semaphore_fork)) - != 0) + while(sem_wait(&((*s_etat_processus) + .semaphore_fork)) != 0) # else - while(sem_wait((*s_etat_processus).semaphore_fork) != 0) + while(sem_wait((*s_etat_processus).semaphore_fork) + != 0) # endif - { - if (errno != EINTR) { - (*s_etat_processus).erreur_systeme = d_es_processus; - return; + if (errno != EINTR) + { + (*s_etat_processus).erreur_systeme = + d_es_processus; + return; + } } - } - if (erreur != EINTR) - { - liberation(s_etat_processus, s_objet_argument); - liberation(s_etat_processus, s_objet_resultat); + if (erreur != EINTR) + { + liberation(s_etat_processus, s_objet_argument); + liberation(s_etat_processus, s_objet_resultat); - (*s_etat_processus).erreur_execution = - d_ex_erreur_acces_fichier; - return; - } + (*s_etat_processus).erreur_execution = + d_ex_erreur_acces_fichier; + return; + } - scrutation_injection(s_etat_processus); + scrutation_injection(s_etat_processus); - if ((*s_etat_processus).var_volatile_requete_arret != 0) - { - drapeau = d_vrai; + if ((*s_etat_processus).var_volatile_requete_arret != 0) + { + drapeau = d_vrai; + } + else + { + drapeau = d_faux; + } } else { - drapeau = d_faux; - } - } - else - { # ifndef SEMAPHORES_NOMMES - while(sem_wait(&((*s_etat_processus).semaphore_fork)) - != 0) + while(sem_wait(&((*s_etat_processus) + .semaphore_fork)) != 0) # else - while(sem_wait((*s_etat_processus).semaphore_fork) != 0) + while(sem_wait((*s_etat_processus).semaphore_fork) + != 0) # endif - { - if (errno != EINTR) { - (*s_etat_processus).erreur_systeme = d_es_processus; - return; + if (errno != EINTR) + { + (*s_etat_processus).erreur_systeme = + d_es_processus; + return; + } } } - } - } while(drapeau == d_faux); - } - - // Si accept() renvoie une erreur non récupérée, il ne peut s'agir - // que de EINTR sachant qu'une requête d'arrêt est en court de - // traitement. + } while(drapeau == d_faux); + } - if ((*((struct_socket *) (*s_objet_resultat).objet)).socket >= 0) - { - l_element_courant = (*s_etat_processus).s_sockets; + // Si accept() renvoie une erreur non récupérée, il ne peut s'agir + // que de EINTR sachant qu'une requête d'arrêt est en court de + // traitement. - if (l_element_courant == NULL) + if ((*((struct_socket *) (*s_objet_resultat).objet)).socket >= 0) { - if (((*s_etat_processus).s_sockets = - allocation_maillon(s_etat_processus)) == NULL) + l_element_courant = (*s_etat_processus).s_sockets; + + if (l_element_courant == NULL) { - (*s_etat_processus).erreur_systeme = - d_es_allocation_memoire; - return; + if (((*s_etat_processus).s_sockets = + allocation_maillon(s_etat_processus)) == NULL) + { + (*s_etat_processus).erreur_systeme = + d_es_allocation_memoire; + return; + } + + (*(*s_etat_processus).s_sockets).suivant = NULL; + l_element_courant = (*s_etat_processus).s_sockets; } + else + { + /* + * Ajout d'un élément à la fin de la liste chaînée + */ - (*(*s_etat_processus).s_sockets).suivant = NULL; - l_element_courant = (*s_etat_processus).s_sockets; - } - else - { - /* - * Ajout d'un élément à la fin de la liste chaînée - */ + while((*l_element_courant).suivant != NULL) + { + l_element_courant = (*l_element_courant).suivant; + } + + if (((*l_element_courant).suivant = + allocation_maillon(s_etat_processus)) == NULL) + { + (*s_etat_processus).erreur_systeme = + d_es_allocation_memoire; + return; + } - while((*l_element_courant).suivant != NULL) - { l_element_courant = (*l_element_courant).suivant; + (*l_element_courant).suivant = NULL; } - if (((*l_element_courant).suivant = - allocation_maillon(s_etat_processus)) == NULL) + if (((*l_element_courant).donnee = copie_objet(s_etat_processus, + s_objet_resultat, 'O')) == NULL) { (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; return; } - - l_element_courant = (*l_element_courant).suivant; - (*l_element_courant).suivant = NULL; } - if (((*l_element_courant).donnee = copie_objet(s_etat_processus, - s_objet_resultat, 'O')) == NULL) + if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile), + s_objet_argument) == d_erreur) { - (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; return; } - } - - if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile), - s_objet_argument) == d_erreur) - { - return; - } - if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile), - s_objet_resultat) == d_erreur) - { - return; + if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile), + s_objet_resultat) == d_erreur) + { + return; + } } } else