X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=lib%2Fvconn-unix.c;h=93d14e831ccb39db6494c137366f81d3cea56a61;hb=8b61709d5ec6c4ef58a04fcaefde617ff63fa10d;hp=fddf6e85185c6e6a7394bcd6455cf8d55c651d3c;hpb=193456d581423f894e57e8463ff5049c0d802f0a;p=openvswitch diff --git a/lib/vconn-unix.c b/lib/vconn-unix.c index fddf6e85..93d14e83 100644 --- a/lib/vconn-unix.c +++ b/lib/vconn-unix.c @@ -60,7 +60,7 @@ unix_open(const char *name, char *suffix, struct vconn **vconnp) } return new_stream_vconn(name, fd, check_connection_completion(fd), - 0, 0, true, NULL, vconnp); + true, vconnp); } struct vconn_class unix_vconn_class = { @@ -81,7 +81,7 @@ static int punix_accept(int fd, const struct sockaddr *sa, size_t sa_len, static int punix_open(const char *name UNUSED, char *suffix, struct pvconn **pvconnp) { - int fd; + int fd, error; fd = make_unix_socket(SOCK_STREAM, true, true, suffix, NULL); if (fd < 0) { @@ -89,6 +89,19 @@ punix_open(const char *name UNUSED, char *suffix, struct pvconn **pvconnp) return errno; } + error = set_nonblocking(fd); + if (error) { + close(fd); + return error; + } + + if (listen(fd, 10) < 0) { + error = errno; + VLOG_ERR("%s: listen: %s", name, strerror(error)); + close(fd); + return error; + } + return new_pstream_pvconn("punix", fd, punix_accept, pvconnp); } @@ -105,7 +118,7 @@ punix_accept(int fd, const struct sockaddr *sa, size_t sa_len, } else { strcpy(name, "unix"); } - return new_stream_vconn(name, fd, 0, 0, 0, true, NULL, vconnp); + return new_stream_vconn(name, fd, 0, true, vconnp); } struct pvconn_class punix_pvconn_class = {