return 0;
}
+/* return value:
+ * >= 0 => fd
+ * -1 => error
+ */
int receive_fd(int fd) {
struct msghdr msg;
struct iovec iov;
msg.msg_control = ccmsg;
msg.msg_controllen = sizeof(ccmsg);
- rv = recvmsg(fd, &msg, 0);
+ while(((rv = recvmsg(fd, &msg, 0)) == -1) && errno == EINTR);
if (rv == -1) {
perror("recvmsg");
return -1;
}
-
+ if(!rv) {
+ /* EOF */
+ fprintf(stderr, "got EOF\n");
+ return -1;
+ }
+
cmsg = CMSG_FIRSTHDR(&msg);
if (!cmsg->cmsg_type == SCM_RIGHTS) {
fprintf(stderr, "got control message of unknown type %d\n",
/* FIXME: parse mount_args (or just pass it to fusermount ???) */
mount_args = mount_args;
- if(socketpair(PF_UNIX,SOCK_DGRAM,0,fds)) {
+ /* make sure the socket fds are greater than 0 */
+ fd = open("/dev/null",O_RDONLY);
+ rv = socketpair(PF_UNIX,SOCK_STREAM,0,fds);
+ close(fd);
+ if(rv) {
fprintf(stderr,"fuse: failed to socketpair()\n");
+ close(fd);
return -1;
}
pid = fork();
fd = fds[1];
close(fds[0]);
- while((rv = receive_fd(fd)) < 0)
- sleep(1);
+ rv = receive_fd(fd);
close(fd);
- while(wait(NULL) != pid); /* bury zombie */
+ waitpid(pid,NULL,0); /* bury zombie */
return rv;
}
-#include <stdio.h> /* fprintf */
-#include <errno.h> /* errno */
+#include <stdio.h> /* fprintf */
+#include <errno.h> /* errno */
#include <string.h> /* strerror */
#include <unistd.h> /* read,write,close */
#include <stdlib.h> /* getenv,strtol */
#undef IOSLAVE_DEBUG
char *scratch;
+/* return values:
+ * 0 => success
+ * -1 => error condition
+ */
int send_fd(int sock_fd, int send_fd) {
int retval;
struct msghdr msg;
*/
vec.iov_base = &sendchar;
vec.iov_len = sizeof(sendchar);
- retval = sendmsg(sock_fd, &msg, 0);
+ while((retval = sendmsg(sock_fd, &msg, 0)) == -1 && errno == EINTR);
if (retval != 1) {
perror("sendmsg");
+ return -1;
}
- return retval;
+ return 0;
}
int main() {
if (!env)
exit(fprintf(stderr, "fuse_ioslave: do not run me directly\n"));
fd = strtol(env, NULL, 0);
- while (send_fd(fd, 0) < 0) {
- sleep(5);
- }
+ if(send_fd(fd, 0) == -1)
+ fprintf(stderr,"failed to send fd\n");
return 0;
}