Blame support/support.h

Packit 6c4009
/* Common extra functions.
Packit 6c4009
   Copyright (C) 2016-2018 Free Software Foundation, Inc.
Packit 6c4009
   This file is part of the GNU C Library.
Packit 6c4009
Packit 6c4009
   The GNU C Library is free software; you can redistribute it and/or
Packit 6c4009
   modify it under the terms of the GNU Lesser General Public
Packit 6c4009
   License as published by the Free Software Foundation; either
Packit 6c4009
   version 2.1 of the License, or (at your option) any later version.
Packit 6c4009
Packit 6c4009
   The GNU C Library is distributed in the hope that it will be useful,
Packit 6c4009
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 6c4009
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit 6c4009
   Lesser General Public License for more details.
Packit 6c4009
Packit 6c4009
   You should have received a copy of the GNU Lesser General Public
Packit 6c4009
   License along with the GNU C Library; if not, see
Packit 6c4009
   <http://www.gnu.org/licenses/>.  */
Packit 6c4009
Packit 6c4009
/* This header file should only contain definitions compatible with
Packit 6c4009
   C90.  (Using __attribute__ is fine because <features.h> provides a
Packit 6c4009
   fallback.)  */
Packit 6c4009
Packit 6c4009
#ifndef SUPPORT_H
Packit 6c4009
#define SUPPORT_H
Packit 6c4009
Packit 6c4009
#include <stddef.h>
Packit 6c4009
#include <sys/cdefs.h>
Packit Bot 3f3af5
/* For mode_t.  */
Packit Bot 3f3af5
#include <sys/stat.h>
Packit Bot 3f3af5
/* For ssize_t and off64_t.  */
Packit Bot 3f3af5
#include <sys/types.h>
Packit 6c4009
Packit 6c4009
__BEGIN_DECLS
Packit 6c4009
Packit 6c4009
/* Write a message to standard output.  Can be used in signal
Packit 6c4009
   handlers.  */
Packit 6c4009
void write_message (const char *message) __attribute__ ((nonnull (1)));
Packit 6c4009
Packit 6c4009
/* Avoid all the buffer overflow messages on stderr.  */
Packit 6c4009
void ignore_stderr (void);
Packit 6c4009
Packit 6c4009
/* Set fortification error handler.  Used when tests want to verify that bad
Packit 6c4009
   code is caught by the library.  */
Packit 6c4009
void set_fortify_handler (void (*handler) (int sig));
Packit 6c4009
Packit 6c4009
/* Report an out-of-memory error for the allocation of SIZE bytes in
Packit 6c4009
   FUNCTION, terminating the process.  */
Packit 6c4009
void oom_error (const char *function, size_t size)
Packit 6c4009
  __attribute__ ((nonnull (1)));
Packit 6c4009
Packit 6c4009
/* Return a pointer to a memory region of SIZE bytes.  The memory is
Packit 6c4009
   initialized to zero and will be shared with subprocesses (across
Packit 6c4009
   fork).  The returned pointer must be freed using
Packit 6c4009
   support_shared_free; it is not compatible with the malloc
Packit 6c4009
   functions.  */
Packit 6c4009
void *support_shared_allocate (size_t size);
Packit 6c4009
Packit 6c4009
/* Deallocate a pointer returned by support_shared_allocate.  */
Packit 6c4009
void support_shared_free (void *);
Packit 6c4009
Packit 6c4009
/* Write CONTENTS to the file PATH.  Create or truncate the file as
Packit 6c4009
   needed.  The file mode is 0666 masked by the umask.  Terminate the
Packit 6c4009
   process on error.  */
Packit 6c4009
void support_write_file_string (const char *path, const char *contents);
Packit 6c4009
Packit 6c4009
/* Quote the contents of the byte array starting at BLOB, of LENGTH
Packit 6c4009
   bytes, in such a way that the result string can be included in a C
Packit 6c4009
   literal (in single/double quotes, without putting the quotes into
Packit 6c4009
   the result).  */
Packit 6c4009
char *support_quote_blob (const void *blob, size_t length);
Packit 6c4009
Packit Bot df0834
/* Quote the contents of the string, in such a way that the result
Packit Bot 9d5ae7
   string can be included in a C literal (in single/double quotes,
Packit Bot 9d5ae7
   without putting the quotes into the result).  */
Packit Bot df0834
char *support_quote_string (const char *);
Packit Bot 9d5ae7
Packit Bot 3f3af5
/* Returns non-zero if the file descriptor is a regular file on a file
Packit Bot 3f3af5
   system which supports holes (that is, seeking and writing does not
Packit Bot 3f3af5
   allocate storage for the range of zeros).  FD must refer to a
Packit Bot 3f3af5
   regular file open for writing, and initially empty.  */
Packit Bot 3f3af5
int support_descriptor_supports_holes (int fd);
Packit Bot 3f3af5
Packit 6c4009
/* Error-checking wrapper functions which terminate the process on
Packit 6c4009
   error.  */
Packit 6c4009
Packit 6c4009
void *xmalloc (size_t) __attribute__ ((malloc));
Packit 6c4009
void *xcalloc (size_t n, size_t s) __attribute__ ((malloc));
Packit 6c4009
void *xrealloc (void *p, size_t n);
Packit Bot ecc1b9
void *xposix_memalign (size_t alignment, size_t n);
Packit 6c4009
char *xasprintf (const char *format, ...)
Packit 6c4009
  __attribute__ ((format (printf, 1, 2), malloc));
Packit 6c4009
char *xstrdup (const char *);
Packit 6c4009
char *xstrndup (const char *, size_t);
Packit Service 0bbb8c
Packit Bot 3f3af5
/* These point to the TOP of the source/build tree, not your (or
Packit Bot 3f3af5
   support's) subdirectory.  */
Packit Bot 3f3af5
extern const char support_srcdir_root[];
Packit Bot 3f3af5
extern const char support_objdir_root[];
Packit Bot 3f3af5
Packit Bot 3f3af5
/* Corresponds to the path to the runtime linker used by the testsuite,
Packit Bot 3f3af5
   e.g. OBJDIR_PATH/elf/ld-linux-x86-64.so.2  */
Packit Bot 3f3af5
extern const char support_objdir_elf_ldso[];
Packit Bot 3f3af5
Packit Bot 3f3af5
/* Corresponds to the --prefix= passed to configure.  */
Packit Bot 3f3af5
extern const char support_install_prefix[];
Packit Bot 3f3af5
/* Corresponds to the install's lib/ or lib64/ directory.  */
Packit Bot 3f3af5
extern const char support_libdir_prefix[];
Packit Bot d1d011
/* Corresponds to the install's bin/ directory.  */
Packit Bot d1d011
extern const char support_bindir_prefix[];
Packit Bot 2bf7f3
/* Corresponds to the install's sbin/ directory.  */
Packit Bot 2bf7f3
extern const char support_install_rootsbindir[];
Packit Bot 3f3af5
Packit Bot 3f3af5
extern ssize_t support_copy_file_range (int, off64_t *, int, off64_t *,
Packit Bot 3f3af5
					size_t, unsigned int);
Packit Bot 3f3af5
Packit 6c4009
__END_DECLS
Packit 6c4009
Packit 6c4009
#endif /* SUPPORT_H */