Files
libguestfs/daemon/internal.c
Richard W.M. Jones 494c18802b daemon: When valgrinding the daemon, take steps to cleanly exit daemon.
This adds a new internal API: internal_exit

Only when valgrinding the daemon, have the library call internal_exit
along the close path, and close the sockets first.  This ensures we
will see normal valgrind messages (we were only seeing valgrind aborts
before).

Note this is not used in production builds.
2013-10-11 09:13:11 +01:00

62 lines
1.6 KiB
C

/* libguestfs - the guestfsd daemon
* Copyright (C) 2012 Red Hat Inc.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
/* Internal functions are not part of the public API. */
#include <config.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include "daemon.h"
#include "actions.h"
/* Older versions of libguestfs used to issue separate 'umount_all'
* and 'sync' commands just before closing the handle. Since
* libguestfs 1.9.7 the library issues this 'internal_autosync'
* internal operation instead, allowing more control in the daemon.
*/
int
do_internal_autosync (void)
{
int r = 0;
if (autosync_umount)
r = do_umount_all ();
sync_disks ();
return r;
}
/* NB: Only called when valgrinding the daemon. */
int
do_internal_exit (void)
{
if (!autosync_umount) {
reply_with_error ("guestfsd -r flag used, ignoring");
return -1;
}
/* Send a reply before exiting so the protocol doesn't get confused. */
reply (NULL, NULL);
exit (EXIT_SUCCESS);
}