main.cpp revision a2760a4d593af57a19ec32cdfd1723b68495df8c
/** @file
*
* VirtualBox Guest Service:
* Linux guest.
*/
/*
* Copyright (C) 2006-2007 innotek GmbH
*
* This file is part of VirtualBox Open Source Edition (OSE), as
* available from http://www.virtualbox.org. This file is free software;
* General Public License (GPL) as published by the Free Software
* Foundation, in version 2 as it comes in the "COPYING" file of the
* VirtualBox OSE distribution. VirtualBox OSE is distributed in the
* hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
*/
#define LOG_GROUP LOG_GROUP_DEV_VMM_BACKDOOR
#include <VBox/VBoxGuest.h>
#include <iprt/initterm.h>
#include <iostream>
#include <fcntl.h> /* For open */
#include <stdlib.h> /* For exit */
#include <unistd.h>
#include <getopt.h>
#include <X11/Intrinsic.h>
#include "clipboard.h"
#ifdef SEAMLESS_LINUX
# include "seamless.h"
#endif
static bool gbDaemonise = true;
/**
* Go through the long Un*x ritual required to become a daemon process.
*/
void vboxDaemonise(void)
{
/** rlimit structure for finding out how many open files we may have. */
/* To make sure that we are not currently a session leader, we must first fork and let
the parent process exit, as a newly created child is never session leader. This will
allow us to call setsid() later. */
if (fork() != 0)
{
exit(0);
}
/* Find the maximum number of files we can have open and close them all. */
{
/* For some reason the call failed. In that case we will just close the three
standard files and hope. */
}
{
close(i);
}
/* Change to the root directory to avoid keeping the one we were started in open. */
chdir("/");
/* Set our umask to zero. */
umask(0);
dup(1);
/* Detach from the controlling terminal by creating our own session, to avoid receiving
signals from the old session. */
setsid();
/* And fork again, letting the parent exit, to make us a child of init and avoid zombies. */
if (fork() != 0)
{
exit(0);
}
}
/**
* Xlib error handler, so that we don't abort when we get a BadAtom error.
*/
{
char errorText[1024];
LogFlowFunc(("\n"));
{
/* This can be triggered in debug builds if a guest application passes a bad atom
in its list of supported clipboard formats. As such it is harmless. */
LogFlowFunc(("ignoring BadAtom error and returning\n"));
return 0;
}
if (!gbDaemonise)
{
}
Log(("%s: an X Window protocol error occurred: %s. Request code: %d, minor code: %d, serial number: %d\n",
LogFlowFunc(("exiting\n"));
exit(1);
}
{
int rc;
#ifdef SEAMLESS_LINUX
/** Our instance of the seamless class. */
#endif
/* Parse our option(s) */
while (1)
{
{
{"nodaemon", 0, 0, 'd'},
{0, 0, 0, 0}
};
if (cOpt == -1)
{
{
exit(1);
}
break;
}
switch(cOpt)
{
case 'd':
gbDaemonise = false;
break;
default:
case '?':
exit(1);
}
}
if (gbDaemonise)
{
}
/* Initialise our runtime before all else. */
RTR3Init(false);
LogFlowFunc(("\n"));
/* Initialise threading in X11 and in Xt. */
if (!XInitThreads() || !XtToolkitThreadInitialize())
{
LogRelFunc(("Error initialising threads in X11, returning 1."));
cout << "Your guest system appears to be using an old, single-threaded version of the X Window System libraries. This program cannot continue." << endl;
return 1;
}
/* Set an X11 error handler, so that we don't die when we get BadAtom errors. */
/* Connect to the host clipboard. */
LogRel(("Starting clipboard Guest Additions...\n"));
rc = vboxClipboardConnect();
if (rc != VINF_SUCCESS)
{
}
#ifdef SEAMLESS_LINUX
try
{
LogRel(("Starting seamless Guest Additions...\n"));
if (rc != VINF_SUCCESS)
{
}
}
{
}
catch (...)
{
LogRel(("Failed to initialise seamless Additions - caught unknown exception.\n"));
}
#endif /* SEAMLESS_LINUX defined */
#ifdef SEAMLESS_LINUX
try
{
}
{
}
catch (...)
{
LogRel(("Error shutting down seamless Additions - caught unknown exception.\n"));
}
#endif /* SEAMLESS_LINUX defined */
return rc;
}