mirror of
git://git.gnupg.org/gnupg.git
synced 2024-12-31 11:41:32 +01:00
953dd67368
* agent/genkey.c (do_check_passphrase_pattern): Use the gpgrt API. * common/asshelp.c (start_new_service): Ditto. * common/exechelp.h: Remove gnupg_process_spawn API. * common/exechelp-posix.c: Remove gnupg_process_spawn implementation. * common/exechelp-w32.c: Likewise. * common/exectool.c (gnupg_exec_tool_stream): Use the gpgrt API. * common/t-exechelp.c (test_pipe_stream): Remove. * dirmngr/ldap-wrapper.c (destroy_wrapper, ldap_reaper_thread): Use the gpgrt API. (ldap_wrapper_connection_cleanup, ldap_wrapper): Ditto. * dirmngr/ldap.c, g10/call-keyboxd.c: No need to include exechelp.h. * g10/photoid.c (run_with_pipe, show_photo): Use the gpgrt API. * g13/be-encfs.c (run_umount_helper, run_encfs_tool): Ditto. * g13/g13.c, g13/mount.c, g13/runner.c: No need to include exechelp.h. * scd/apdu.c: No need to include exechelp.h. * scd/app.c (report_change): Use the gpgrt API. * sm/export.c, sm/import.c: No need to include exechelp.h. * tests/gpgscm/ffi.c (proc_object_finalize, proc_wrap) (do_process_spawn_io, do_process_spawn_fd, do_process_wait): Use the gpgrt API. * tools/gpg-auth.c: No need to include exechelp.h. * tools/gpg-card.c (cmd_gpg): Use the gpgrt API. * tools/gpg-connect-agent.c: No need to include exechelp.h. * tools/gpg-mail-tube.c (mail_tube_encrypt, prepare_for_appimage) (start_gpg_encrypt): Use the gpgrt API. * tools/gpgconf-comp.c (gpg_agent_runtime_change) (scdaemon_runtime_change, tpm2daemon_runtime_change) (dirmngr_runtime_change, keyboxd_runtime_change) (gc_component_launch, gc_component_check_options) (retrieve_options_from_program): Ditto. * tools/gpgconf.c (show_versions_via_dirmngr): Ditto. * tools/gpgtar-create.c (gpgtar_create): Ditto. * tools/gpgtar-extract.c (gpgtar_extract): Ditto. * tools/gpgtar-list.c (gpgtar_list): Ditto. -- GnuPG-bug-id: 7192 Signed-off-by: NIIBE Yutaka <gniibe@fsij.org>
273 lines
5.6 KiB
C
273 lines
5.6 KiB
C
/* t-exechelp.c - Module test for exechelp.c
|
|
* Copyright (C) 2009 Free Software Foundation, Inc.
|
|
*
|
|
* This file is part of GnuPG.
|
|
*
|
|
* GnuPG 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 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* GnuPG 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, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include <config.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <errno.h>
|
|
#include <assert.h>
|
|
#include <unistd.h>
|
|
|
|
#include "util.h"
|
|
#include "sysutils.h"
|
|
#include "exechelp.h"
|
|
|
|
static int verbose;
|
|
|
|
#ifndef HAVE_W32_SYSTEM
|
|
static void
|
|
print_open_fds (int *array)
|
|
{
|
|
int n;
|
|
|
|
if (!verbose)
|
|
return;
|
|
|
|
for (n=0; array[n] != -1; n++)
|
|
;
|
|
printf ("open file descriptors: %d", n);
|
|
putchar (' ');
|
|
putchar (' ');
|
|
putchar ('(');
|
|
for (n=0; array[n] != -1; n++)
|
|
printf ("%d%s", array[n], array[n+1] == -1?"":" ");
|
|
putchar (')');
|
|
putchar ('\n');
|
|
}
|
|
|
|
|
|
static int *
|
|
xget_all_open_fds (void)
|
|
{
|
|
int *array;
|
|
|
|
array = get_all_open_fds ();
|
|
if (!array)
|
|
{
|
|
fprintf (stderr, "%s:%d: get_all_open_fds failed: %s\n",
|
|
__FILE__, __LINE__, strerror (errno));
|
|
exit (1);
|
|
}
|
|
return array;
|
|
}
|
|
|
|
|
|
/* That is a very crude test. To do a proper test we would need to
|
|
fork a test process and best return information by some other means
|
|
than file descriptors. */
|
|
static void
|
|
test_close_all_fds (void)
|
|
{
|
|
int max_fd = get_max_fds ();
|
|
int *array;
|
|
int fd;
|
|
int initial_count, count, n;
|
|
#if 0
|
|
char buffer[100];
|
|
|
|
snprintf (buffer, sizeof buffer, "/bin/ls -l /proc/%d/fd", (int)getpid ());
|
|
system (buffer);
|
|
#endif
|
|
|
|
if (verbose)
|
|
printf ("max. file descriptors: %d\n", max_fd);
|
|
array = xget_all_open_fds ();
|
|
print_open_fds (array);
|
|
for (initial_count=n=0; array[n] != -1; n++)
|
|
initial_count++;
|
|
free (array);
|
|
|
|
/* Some dups to get more file descriptors and close one. */
|
|
dup (1);
|
|
dup (1);
|
|
fd = dup (1);
|
|
dup (1);
|
|
close (fd);
|
|
|
|
array = xget_all_open_fds ();
|
|
if (verbose)
|
|
print_open_fds (array);
|
|
for (count=n=0; array[n] != -1; n++)
|
|
count++;
|
|
if (count != initial_count+3)
|
|
{
|
|
fprintf (stderr, "%s:%d: dup or close failed\n",
|
|
__FILE__, __LINE__);
|
|
exit (1);
|
|
}
|
|
free (array);
|
|
|
|
/* Close the non standard ones. */
|
|
close_all_fds (3, NULL);
|
|
|
|
/* Get a list to check whether they are all closed. */
|
|
array = xget_all_open_fds ();
|
|
if (verbose)
|
|
print_open_fds (array);
|
|
for (count=n=0; array[n] != -1; n++)
|
|
count++;
|
|
if (count > initial_count)
|
|
{
|
|
fprintf (stderr, "%s:%d: not all files were closed\n",
|
|
__FILE__, __LINE__);
|
|
exit (1);
|
|
}
|
|
initial_count = count;
|
|
free (array);
|
|
|
|
/* Now let's check the realloc we use. We do this and the next
|
|
tests only if we are allowed to open enough descriptors. */
|
|
if (get_max_fds () > 32)
|
|
{
|
|
int except[] = { 20, 23, 24, -1 };
|
|
|
|
for (n=initial_count; n < 31; n++)
|
|
dup (1);
|
|
array = xget_all_open_fds ();
|
|
if (verbose)
|
|
print_open_fds (array);
|
|
free (array);
|
|
for (n=0; n < 5; n++)
|
|
{
|
|
dup (1);
|
|
array = xget_all_open_fds ();
|
|
if (verbose)
|
|
print_open_fds (array);
|
|
free (array);
|
|
}
|
|
|
|
/* Check whether the except list works. */
|
|
close_all_fds (3, except);
|
|
array = xget_all_open_fds ();
|
|
if (verbose)
|
|
print_open_fds (array);
|
|
for (count=n=0; array[n] != -1; n++)
|
|
count++;
|
|
free (array);
|
|
|
|
if (count != initial_count + DIM(except)-1)
|
|
{
|
|
fprintf (stderr, "%s:%d: close_all_fds failed\n",
|
|
__FILE__, __LINE__);
|
|
exit (1);
|
|
}
|
|
}
|
|
|
|
}
|
|
#endif
|
|
|
|
static char buff12k[1024*12];
|
|
static char buff4k[1024*4];
|
|
|
|
static void
|
|
run_server (void)
|
|
{
|
|
estream_t fp;
|
|
int i;
|
|
char *p;
|
|
unsigned int len;
|
|
int ret;
|
|
es_syshd_t syshd;
|
|
size_t n;
|
|
off_t o;
|
|
|
|
#ifdef HAVE_W32_SYSTEM
|
|
syshd.type = ES_SYSHD_HANDLE;
|
|
syshd.u.handle = (HANDLE)_get_osfhandle (1);
|
|
#else
|
|
syshd.type = ES_SYSHD_FD;
|
|
syshd.u.fd = 1;
|
|
#endif
|
|
|
|
fp = es_sysopen_nc (&syshd, "w");
|
|
if (fp == NULL)
|
|
{
|
|
fprintf (stderr, "es_fdopen failed\n");
|
|
exit (1);
|
|
}
|
|
|
|
/* Fill the buffer by ASCII chars. */
|
|
p = buff12k;
|
|
for (i = 0; i < sizeof (buff12k); i++)
|
|
if ((i % 64) == 63)
|
|
*p++ = '\n';
|
|
else
|
|
*p++ = (i % 64) + '@';
|
|
|
|
len = sizeof (buff12k);
|
|
|
|
ret = es_write (fp, (void *)&len, sizeof (len), NULL);
|
|
if (ret)
|
|
{
|
|
fprintf (stderr, "es_write (1) failed\n");
|
|
exit (1);
|
|
}
|
|
|
|
es_fflush (fp);
|
|
|
|
o = 0;
|
|
n = len;
|
|
|
|
while (1)
|
|
{
|
|
size_t n0, n1;
|
|
|
|
n0 = n > 4096 ? 4096 : n;
|
|
memcpy (buff4k, buff12k + o, n0);
|
|
|
|
ret = es_write (fp, buff4k, n0, &n1);
|
|
if (ret || n0 != n1)
|
|
{
|
|
fprintf (stderr, "es_write (2) failed\n");
|
|
exit (1);
|
|
}
|
|
|
|
o += n0;
|
|
n -= n0;
|
|
if (n == 0)
|
|
break;
|
|
}
|
|
|
|
es_fclose (fp);
|
|
exit (0);
|
|
}
|
|
|
|
|
|
int
|
|
main (int argc, char **argv)
|
|
{
|
|
if (argc)
|
|
{
|
|
argc--; argv++;
|
|
}
|
|
if (argc && !strcmp (argv[0], "--verbose"))
|
|
{
|
|
verbose = 1;
|
|
argc--; argv++;
|
|
}
|
|
if (argc && !strcmp (argv[0], "--server"))
|
|
run_server ();
|
|
|
|
#ifndef HAVE_W32_SYSTEM
|
|
test_close_all_fds ();
|
|
#endif
|
|
|
|
return 0;
|
|
}
|