blob: 42a0e92524d7ef4267cbf6f3d0376de54f0dff62 [file] [log] [blame]
Gilles Peskinee9433532021-11-04 12:45:19 +01001/*
2 * Test dynamic loading of libmbed*
3 *
4 * Copyright The Mbed TLS Contributors
Dave Rodgman7ff79652023-11-03 12:04:52 +00005 * SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
Gilles Peskinee9433532021-11-04 12:45:19 +01006 */
7
Gilles Peskine6fa5c1d2021-11-25 18:12:44 +01008#if !defined(MBEDTLS_CONFIG_FILE)
Gilles Peskinee9433532021-11-04 12:45:19 +01009#include "mbedtls/config.h"
Gilles Peskine6fa5c1d2021-11-25 18:12:44 +010010#else
11#include MBEDTLS_CONFIG_FILE
12#endif
Gilles Peskinee9433532021-11-04 12:45:19 +010013
14#include "mbedtls/platform.h"
Gilles Peskinee9433532021-11-04 12:45:19 +010015
16#if defined(MBEDTLS_X509_CRT_PARSE_C)
17#include "mbedtls/x509_crt.h"
18#endif
19
Gilles Peskine8e8e9652021-11-12 14:30:22 +010020#if defined(__APPLE__)
21#define SO_SUFFIX ".dylib"
22#else
23#define SO_SUFFIX ".so"
24#endif
25
26#define CRYPTO_SO_FILENAME "libmbedcrypto" SO_SUFFIX
27#define X509_SO_FILENAME "libmbedx509" SO_SUFFIX
28#define TLS_SO_FILENAME "libmbedtls" SO_SUFFIX
Gilles Peskinee9433532021-11-04 12:45:19 +010029
30#include <dlfcn.h>
31
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010032#define CHECK_DLERROR(function, argument) \
Gilles Peskinee9433532021-11-04 12:45:19 +010033 do \
34 { \
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010035 char *CHECK_DLERROR_error = dlerror(); \
36 if (CHECK_DLERROR_error != NULL) \
Gilles Peskinee9433532021-11-04 12:45:19 +010037 { \
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010038 fprintf(stderr, "Dynamic loading error for %s(%s): %s\n", \
39 function, argument, CHECK_DLERROR_error); \
40 mbedtls_exit(MBEDTLS_EXIT_FAILURE); \
Gilles Peskinee9433532021-11-04 12:45:19 +010041 } \
42 } \
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010043 while (0)
Gilles Peskinee9433532021-11-04 12:45:19 +010044
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010045int main(void)
Gilles Peskinee9433532021-11-04 12:45:19 +010046{
Gilles Peskine3dbb3e72021-11-10 19:11:32 +010047#if defined(MBEDTLS_MD_C) || defined(MBEDTLS_SSL_TLS_C)
Gilles Peskinee9433532021-11-04 12:45:19 +010048 unsigned n;
Gilles Peskine3dbb3e72021-11-10 19:11:32 +010049#endif
Gilles Peskinee9433532021-11-04 12:45:19 +010050
51#if defined(MBEDTLS_SSL_TLS_C)
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010052 void *tls_so = dlopen(TLS_SO_FILENAME, RTLD_NOW);
53 CHECK_DLERROR("dlopen", TLS_SO_FILENAME);
54 const int *(*ssl_list_ciphersuites)(void) =
55 dlsym(tls_so, "mbedtls_ssl_list_ciphersuites");
56 CHECK_DLERROR("dlsym", "mbedtls_ssl_list_ciphersuites");
57 const int *ciphersuites = ssl_list_ciphersuites();
58 for (n = 0; ciphersuites[n] != 0; n++) {/* nothing to do, we're just counting */
59 ;
60 }
61 mbedtls_printf("dlopen(%s): %u ciphersuites\n",
62 TLS_SO_FILENAME, n);
63 dlclose(tls_so);
64 CHECK_DLERROR("dlclose", TLS_SO_FILENAME);
Gilles Peskinee9433532021-11-04 12:45:19 +010065#endif /* MBEDTLS_SSL_TLS_C */
66
67#if defined(MBEDTLS_X509_CRT_PARSE_C)
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010068 void *x509_so = dlopen(X509_SO_FILENAME, RTLD_NOW);
69 CHECK_DLERROR("dlopen", X509_SO_FILENAME);
Gilles Peskinee9433532021-11-04 12:45:19 +010070 const mbedtls_x509_crt_profile *profile =
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010071 dlsym(x509_so, "mbedtls_x509_crt_profile_default");
72 CHECK_DLERROR("dlsym", "mbedtls_x509_crt_profile_default");
73 mbedtls_printf("dlopen(%s): Allowed md mask: %08x\n",
74 X509_SO_FILENAME, (unsigned) profile->allowed_mds);
75 dlclose(x509_so);
76 CHECK_DLERROR("dlclose", X509_SO_FILENAME);
Gilles Peskinee9433532021-11-04 12:45:19 +010077#endif /* MBEDTLS_X509_CRT_PARSE_C */
78
79#if defined(MBEDTLS_MD_C)
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010080 void *crypto_so = dlopen(CRYPTO_SO_FILENAME, RTLD_NOW);
81 CHECK_DLERROR("dlopen", CRYPTO_SO_FILENAME);
82 const int *(*md_list)(void) =
83 dlsym(crypto_so, "mbedtls_md_list");
84 CHECK_DLERROR("dlsym", "mbedtls_md_list");
85 const int *mds = md_list();
86 for (n = 0; mds[n] != 0; n++) {/* nothing to do, we're just counting */
87 ;
88 }
89 mbedtls_printf("dlopen(%s): %u hashes\n",
90 CRYPTO_SO_FILENAME, n);
91 dlclose(crypto_so);
92 CHECK_DLERROR("dlclose", CRYPTO_SO_FILENAME);
Gilles Peskinee9433532021-11-04 12:45:19 +010093#endif /* MBEDTLS_MD_C */
94
Gilles Peskine1b6c09a2023-01-11 14:52:35 +010095 return 0;
Gilles Peskinee9433532021-11-04 12:45:19 +010096}