Search code examples
csocketsnetwork-programmingtcppolling

when does poll() return POLLERR


server.c -> always recv client data(use poll() to confirm whether an error occurred)

client.c -> always send data to server

I exec server.c and client.c ,then i try to kill client.c process.

But the POLLERR flag never be set.

The man page only say

POLLERR Error condition (output only)

When does Poll() return POLLERR?

What did I miss?

Thanks.

server.c

#include <stdio.h>
#include <stdlib.h>
#include <sys/poll.h>
#include <sys/socket.h>
#include <sys/time.h>
#include <netinet/in.h>
#include <errno.h>

int main()
{
    int rc = 0;
    char str[100];
    char test[5];
    int listen_fd, comm_fd;
    struct sockaddr_in servaddr;
    struct pollfd fds[200];
    listen_fd = socket(AF_INET, SOCK_STREAM, 0);

    servaddr.sin_family = AF_INET;
    servaddr.sin_addr.s_addr = htons(INADDR_ANY);
    servaddr.sin_port = htons(22000);

    bind(listen_fd, (struct sockaddr *) &servaddr, sizeof(servaddr));
    listen(listen_fd, 10);
    comm_fd = accept(listen_fd, (struct sockaddr*) NULL, NULL);
    fds[0].fd = comm_fd;
    fds[0].events = POLLIN | POLLOUT | POLLERR | POLLHUP;
    printf("start\n");

    while(1) {
        rc = poll(fds,1,1000);
        if (rc < 0)
            printf("failed\n");
        else if(rc==0)
            printf("timeout\n");
        else {
            if (fds[0].revents & POLLERR){
                printf("Error!!\n");
            }


            if(fds[0].revents & POLLHUP){
                printf("handup!!\n");
                break;
            }

            if (fds[0].revents & POLLIN){
                int bl = recv(comm_fd,test,4,0);
                printf("recv:%s %d\n",test,bl);
            }
        }
        sleep(1);

    }
    return 0;
}

client.c

#include <sys/types.h>
#include <sys/socket.h>
#include <netdb.h>
#include <stdio.h>
#include <string.h>

int main(int argc,char **argv)
{
    int sockfd,n;
    char sendline[100];
    char recvline[100];
    struct sockaddr_in servaddr;

    sockfd=socket(AF_INET,SOCK_STREAM,0);
    bzero(&servaddr,sizeof servaddr);

    servaddr.sin_family=AF_INET;
    servaddr.sin_port=htons(22000);

    inet_pton(AF_INET,"127.0.0.1",&(servaddr.sin_addr));

    connect(sockfd,(struct sockaddr *)&servaddr,sizeof(servaddr));
    while(1){
        send(sockfd,"test",4,0); 
        sleep(5);
    } 
    close(sockfd);
    return 0;
}

Solution

  • It's implementation dependent. Most applications just treat POLLERR the same as normal readiness, allowing the subsequent operation to fail.