mirror of
https://github.com/morgan9e/systemd
synced 2026-04-14 08:25:20 +09:00
Let's not leak details from src/shared and src/libsystemd into src/basic, even though you can't actually do anything useful with just forward declarations from src/shared. The sd-forward.h header is put in src/libsystemd/sd-common as we don't have a directory for shared internal headers for libsystemd yet. Let's also rename forward.h to basic-forward.h to keep things self-explanatory.
64 lines
2.1 KiB
C
64 lines
2.1 KiB
C
/* SPDX-License-Identifier: LGPL-2.1-or-later */
|
|
|
|
#pragma once
|
|
|
|
#include "basic-forward.h"
|
|
|
|
int dlopen_gcrypt(void);
|
|
|
|
int initialize_libgcrypt(bool secmem);
|
|
|
|
#if HAVE_GCRYPT
|
|
#include <gcrypt.h> /* IWYU pragma: export */
|
|
|
|
#include "dlfcn-util.h"
|
|
|
|
extern DLSYM_PROTOTYPE(gcry_md_close);
|
|
extern DLSYM_PROTOTYPE(gcry_md_copy);
|
|
extern DLSYM_PROTOTYPE(gcry_md_ctl);
|
|
extern DLSYM_PROTOTYPE(gcry_md_get_algo_dlen);
|
|
extern DLSYM_PROTOTYPE(gcry_md_open);
|
|
extern DLSYM_PROTOTYPE(gcry_md_read);
|
|
extern DLSYM_PROTOTYPE(gcry_md_reset);
|
|
extern DLSYM_PROTOTYPE(gcry_md_setkey);
|
|
extern DLSYM_PROTOTYPE(gcry_md_write);
|
|
extern DLSYM_PROTOTYPE(gcry_mpi_add);
|
|
extern DLSYM_PROTOTYPE(gcry_mpi_add_ui);
|
|
extern DLSYM_PROTOTYPE(gcry_mpi_cmp);
|
|
extern DLSYM_PROTOTYPE(gcry_mpi_cmp_ui);
|
|
extern DLSYM_PROTOTYPE(gcry_mpi_get_nbits);
|
|
extern DLSYM_PROTOTYPE(gcry_mpi_invm);
|
|
extern DLSYM_PROTOTYPE(gcry_mpi_mod);
|
|
extern DLSYM_PROTOTYPE(gcry_mpi_mul);
|
|
extern DLSYM_PROTOTYPE(gcry_mpi_mulm);
|
|
extern DLSYM_PROTOTYPE(gcry_mpi_new);
|
|
extern DLSYM_PROTOTYPE(gcry_mpi_powm);
|
|
extern DLSYM_PROTOTYPE(gcry_mpi_print);
|
|
extern DLSYM_PROTOTYPE(gcry_mpi_release);
|
|
extern DLSYM_PROTOTYPE(gcry_mpi_scan);
|
|
extern DLSYM_PROTOTYPE(gcry_mpi_set_ui);
|
|
extern DLSYM_PROTOTYPE(gcry_mpi_sub);
|
|
extern DLSYM_PROTOTYPE(gcry_mpi_subm);
|
|
extern DLSYM_PROTOTYPE(gcry_mpi_sub_ui);
|
|
extern DLSYM_PROTOTYPE(gcry_prime_check);
|
|
extern DLSYM_PROTOTYPE(gcry_randomize);
|
|
extern DLSYM_PROTOTYPE(gcry_strerror);
|
|
|
|
/* Copied from gcry_md_putc from gcrypt.h due to the need to call the sym_ variant */
|
|
#define sym_gcry_md_putc(h,c) \
|
|
do { \
|
|
gcry_md_hd_t h__ = (h); \
|
|
if ((h__)->bufpos == (h__)->bufsize) \
|
|
sym_gcry_md_write((h__), NULL, 0); \
|
|
(h__)->buf[(h__)->bufpos++] = (c) & 0xff; \
|
|
} while(false)
|
|
#else
|
|
typedef struct gcry_md_handle *gcry_md_hd_t;
|
|
|
|
static inline void sym_gcry_md_close(gcry_md_hd_t h) {
|
|
assert(h == NULL);
|
|
}
|
|
#endif
|
|
|
|
DEFINE_TRIVIAL_CLEANUP_FUNC_FULL(gcry_md_hd_t, sym_gcry_md_close, NULL);
|