在我的情况下,我试图写入帧缓冲区/ dev / fb1。一旦我守护程序,我就没有有效的文件描述符。我尝试使用常规文件(具有正确的权限) - 结果相同。当我注释掉daemonize();一切都很顺利。
int fbfd;
void initFB()
{
fbfd = open("/dev/fb1", O_RDWR);
if (!fbfd)
{
exit(EXIT_FAILURE);
}
...
}
int daemonize()
{
pid_t pid,sid;
int lockFile;
char ProcessID[10];
pid = fork();
if (pid < 0)
{
exit(EXIT_FAILURE);
} else if (pid != 0)
{
exit(EXIT_SUCCESS);
}
umask(0);
sid = setsid();
if(sid < 0)
{
exit(EXIT_FAILURE);
}
lockFile = open("/var/run/program.pid",O_RDWR|O_CREAT,0640);
if (lockFile < 0)
{
exit(EXIT_FAILURE);
}
if (lockf(lockFile,F_TLOCK,0)<0)
{
exit(EXIT_SUCCESS);
}
sprintf(ProcessID,"%d\n",getpid());
write(lockFile,ProcessID,strlen(ProcessID));
close(STDIN_FILENO);
close(STDOUT_FILENO);
close(STDERR_FILENO);
signal(SIGCHLD,SIG_IGN);
signal(SIGTSTP,SIG_IGN);
signal(SIGTTOU,SIG_IGN);
signal(SIGTTIN,SIG_IGN);
signal(SIGHUP,signal_handler);
signal(SIGTERM,signal_handler);
return(1);
}
int main(int argc,char **argv)
{
daemonize();
initFB();
...
}
答案 0 :(得分:2)
您对open()
的结果的检查不正确。如果失败,open()
会返回-1
,而不是0
。在您的情况下,会发生这种情况,因为当您关闭open()
时,0
将以最低可用文件描述符结束,此处为stdin
。
答案 1 :(得分:1)
嗯,那是因为open()返回零。 我怀疑这是你的守护进程获得的第一个文件描述符。
它将为零。