Mbed OS Reference
Loading...
Searching...
No Matches
version.h
Go to the documentation of this file.
1/**
2 * \file version.h
3 *
4 * \brief Run-time version information
5 */
6/*
7 * Copyright The Mbed TLS Contributors
8 * SPDX-License-Identifier: Apache-2.0
9 *
10 * Licensed under the Apache License, Version 2.0 (the "License"); you may
11 * not use this file except in compliance with the License.
12 * You may obtain a copy of the License at
13 *
14 * http://www.apache.org/licenses/LICENSE-2.0
15 *
16 * Unless required by applicable law or agreed to in writing, software
17 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
18 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
19 * See the License for the specific language governing permissions and
20 * limitations under the License.
21 */
22/*
23 * This set of compile-time defines and run-time variables can be used to
24 * determine the version number of the mbed TLS library used.
25 */
26#ifndef MBEDTLS_VERSION_H
27#define MBEDTLS_VERSION_H
28
29#if !defined(MBEDTLS_CONFIG_FILE)
30#include "mbedtls/config.h"
31#else
32#include MBEDTLS_CONFIG_FILE
33#endif
34
35/**
36 * \addtogroup mbedtls
37 * \{
38 * \defgroup mbedtls_version_module Versioning
39 * \{
40 */
41
42
43/*
44 * The version number x.y.z is split into three parts.
45 * Major, Minor, Patchlevel
46 */
47#define MBEDTLS_VERSION_MAJOR 2 ///< Major Mbed TLS version
48#define MBEDTLS_VERSION_MINOR 25 ///< Minor Mbed TLS version
49#define MBEDTLS_VERSION_PATCH 0 ///< Patch Mbed TLS version
50
51/**
52 * The single version number has the following structure:
53 * MMNNPP00
54 * Major version | Minor version | Patch version
55 */
56#define MBEDTLS_VERSION_NUMBER 0x02190000
57
58/**
59 * String constant containing the version number in the form "xx.yy.zz"
60 */
61#define MBEDTLS_VERSION_STRING "2.25.0"
62
63/**
64 * String constant containing the library name and version, in the form "mbed TLS xx.yy.zz"
65 */
66#define MBEDTLS_VERSION_STRING_FULL "mbed TLS 2.25.0"
67
68#if defined(MBEDTLS_VERSION_C)
69
70#ifdef __cplusplus
71extern "C" {
72#endif
73
74/**
75 * Get the version number.
76 *
77 * \return The constructed version number in the format
78 * MMNNPP00 (Major, Minor, Patch).
79 */
80unsigned int mbedtls_version_get_number( void );
81
82/**
83 * Get the version string ("x.y.z").
84 *
85 * \param string The string that will receive the value.
86 * (Should be at least 9 bytes in size)
87 */
88void mbedtls_version_get_string( char *string );
89
90/**
91 * Get the full version string ("mbed TLS x.y.z").
92 *
93 * \param string The string that will receive the value. The mbed TLS version
94 * string will use 18 bytes AT MOST including a terminating
95 * null byte.
96 * (So the buffer should be at least 18 bytes to receive this
97 * version string).
98 */
100
101/**
102 * \brief Check if support for a feature was compiled into this
103 * mbed TLS binary. This allows you to see at runtime if the
104 * library was for instance compiled with or without
105 * Multi-threading support.
106 *
107 * \note only checks against defines in the sections "System
108 * support", "mbed TLS modules" and "mbed TLS feature
109 * support" in config.h
110 *
111 * \param feature The string for the define to check (e.g. "MBEDTLS_AES_C")
112 *
113 * \return 0 if the feature is present,
114 * -1 if the feature is not present and
115 * -2 if support for feature checking as a whole was not
116 * compiled in.
117 */
118int mbedtls_version_check_feature( const char *feature );
119
120#ifdef __cplusplus
121}
122#endif
123
124#endif /* MBEDTLS_VERSION_C */
125
126/// \}
127/// \}
128
129#endif /* version.h */
Configuration options (set of defines)
unsigned int mbedtls_version_get_number(void)
Get the version number.
void mbedtls_version_get_string_full(char *string)
Get the full version string ("mbed TLS x.y.z").
void mbedtls_version_get_string(char *string)
Get the version string ("x.y.z").
int mbedtls_version_check_feature(const char *feature)
Check if support for a feature was compiled into this mbed TLS binary.