【发布时间】:2011-03-24 18:08:09
【问题描述】:
我正在尝试使用 sendmsg、recvmsg 函数在两个进程之间传递文件描述符..
我通过在 unix 域中创建套接字来做到这一点。
当我执行它时,我得到了 recvmsg 的操作不支持错误,它与 sendmsg 一起工作正常..
以下是代码..
struct sockaddr_un serveraddr;
if((sfd=socket(AF_UNIX,SOCK_STREAM,0))<0)
{
perror("socket() failed");
unlink(SERVER_PATH);
exit(0);
}
memset(&serveraddr, 0, sizeof(serveraddr));
serveraddr.sun_family = AF_UNIX;
strcpy(serveraddr.sun_path, SERVER_PATH);
if((rc = bind(sfd, (struct sockaddr *)&serveraddr, SUN_LEN(&serveraddr)))<0)
{
perror("bind() failed");
unlink(SERVER_PATH);
exit(0);
}
if((rc = listen(sfd, 10))<0)
{
perror("listen() failed");
exit(0);
}
printf("Ready for client connect().\n");
nsfd = accept(sfd, NULL, NULL);
if (nsfd < 0)
{
perror("accept() failed");
unlink(SERVER_PATH);
exit(0);
}
/*rc = setsockopt(nsfd, SOL_SOCKET, SO_RCVLOWAT,(char *)&length, sizeof(length));
if (rc < 0)
{
perror("setsockopt(SO_RCVLOWAT) failed");
unlink(SERVER_PATH);
exit(0);
}*/
recv(nsfd,buffer,200,0);
printf("the data recieved from client is %s\n",buffer);
struct iovec iov[1];
struct msghdr msg;
iov[0].iov_base = (char*)0;
iov[0].iov_len=0;
msg.msg_iov=iov;
msg.msg_iovlen=1;
msg.msg_name=(caddr_t)0;
msg.msg_control=(caddr_t)&fd;
msg.msg_controllen=sizeof(fd);
if(recvmsg(nsfd,&msg,0)<0)
{
perror("recvmsg error:");
unlink(SERVER_PATH);
exit(0);
}
任何人请让我知道我可以做些什么来解决这个错误..
【问题讨论】:
-
请接受您之前问题的答案。如果您这样做,人们将更有可能愿意帮助您。
-
我在你的代码中没有看到
SCM_RIGHTS。据我所知,这是一个必要的部分......
标签: c linux sockets unix file-descriptor