| Andres Amaya Garcia | 904e1ef | 2018-04-17 09:16:30 -0500 | [diff] [blame] | 1 | /** | 
|  | 2 | * \file platform_util.h | 
|  | 3 | * | 
|  | 4 | * \brief Common and shared functions used by multiple modules in the Mbed TLS | 
|  | 5 | *        library. | 
|  | 6 | */ | 
|  | 7 | /* | 
|  | 8 | *  Copyright (C) 2018, Arm Limited, All Rights Reserved | 
|  | 9 | *  SPDX-License-Identifier: Apache-2.0 | 
|  | 10 | * | 
|  | 11 | *  Licensed under the Apache License, Version 2.0 (the "License"); you may | 
|  | 12 | *  not use this file except in compliance with the License. | 
|  | 13 | *  You may obtain a copy of the License at | 
|  | 14 | * | 
|  | 15 | *  http://www.apache.org/licenses/LICENSE-2.0 | 
|  | 16 | * | 
|  | 17 | *  Unless required by applicable law or agreed to in writing, software | 
|  | 18 | *  distributed under the License is distributed on an "AS IS" BASIS, WITHOUT | 
|  | 19 | *  WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
|  | 20 | *  See the License for the specific language governing permissions and | 
|  | 21 | *  limitations under the License. | 
|  | 22 | * | 
|  | 23 | *  This file is part of Mbed TLS (https://tls.mbed.org) | 
|  | 24 | */ | 
|  | 25 | #ifndef MBEDTLS_PLATFORM_UTIL_H | 
|  | 26 | #define MBEDTLS_PLATFORM_UTIL_H | 
|  | 27 |  | 
| Andres Amaya Garcia | 1abb368 | 2018-08-16 21:42:09 +0100 | [diff] [blame] | 28 | #if !defined(MBEDTLS_CONFIG_FILE) | 
| GuHaijun | 983acb7 | 2018-12-28 11:11:10 +0800 | [diff] [blame] | 29 | #include "config.h" | 
| Andres Amaya Garcia | 1abb368 | 2018-08-16 21:42:09 +0100 | [diff] [blame] | 30 | #else | 
|  | 31 | #include MBEDTLS_CONFIG_FILE | 
|  | 32 | #endif | 
| Arto Kinnunen | ee9bfca | 2019-09-06 16:59:00 +0300 | [diff] [blame] | 33 | #include <stdint.h> | 
| Andres Amaya Garcia | 904e1ef | 2018-04-17 09:16:30 -0500 | [diff] [blame] | 34 | #include <stddef.h> | 
| Andres Amaya Garcia | 1abb368 | 2018-08-16 21:42:09 +0100 | [diff] [blame] | 35 | #if defined(MBEDTLS_HAVE_TIME_DATE) | 
| GuHaijun | 983acb7 | 2018-12-28 11:11:10 +0800 | [diff] [blame] | 36 | #include "platform_time.h" | 
| Andres Amaya Garcia | 1abb368 | 2018-08-16 21:42:09 +0100 | [diff] [blame] | 37 | #include <time.h> | 
|  | 38 | #endif /* MBEDTLS_HAVE_TIME_DATE */ | 
| Andres Amaya Garcia | 904e1ef | 2018-04-17 09:16:30 -0500 | [diff] [blame] | 39 |  | 
|  | 40 | #ifdef __cplusplus | 
|  | 41 | extern "C" { | 
|  | 42 | #endif | 
|  | 43 |  | 
| Manuel Pégourié-Gonnard | 9b8ea89 | 2018-12-11 10:56:56 +0100 | [diff] [blame] | 44 | #if defined(MBEDTLS_CHECK_PARAMS) | 
| Manuel Pégourié-Gonnard | a2b0e27 | 2018-12-10 15:23:58 +0100 | [diff] [blame] | 45 |  | 
| Gilles Peskine | 30346f6 | 2019-06-13 16:44:19 +0200 | [diff] [blame] | 46 | #if defined(MBEDTLS_CHECK_PARAMS_ASSERT) | 
|  | 47 | /* Allow the user to define MBEDTLS_PARAM_FAILED to something like assert | 
|  | 48 | * (which is what our config.h suggests). */ | 
|  | 49 | #include <assert.h> | 
|  | 50 | #endif /* MBEDTLS_CHECK_PARAMS_ASSERT */ | 
|  | 51 |  | 
| Manuel Pégourié-Gonnard | a2b0e27 | 2018-12-10 15:23:58 +0100 | [diff] [blame] | 52 | #if defined(MBEDTLS_PARAM_FAILED) | 
|  | 53 | /** An alternative definition of MBEDTLS_PARAM_FAILED has been set in config.h. | 
|  | 54 | * | 
|  | 55 | * This flag can be used to check whether it is safe to assume that | 
|  | 56 | * MBEDTLS_PARAM_FAILED() will expand to a call to mbedtls_param_failed(). | 
|  | 57 | */ | 
|  | 58 | #define MBEDTLS_PARAM_FAILED_ALT | 
| Gilles Peskine | 30346f6 | 2019-06-13 16:44:19 +0200 | [diff] [blame] | 59 |  | 
|  | 60 | #elif defined(MBEDTLS_CHECK_PARAMS_ASSERT) | 
|  | 61 | #define MBEDTLS_PARAM_FAILED( cond ) assert( cond ) | 
|  | 62 | #define MBEDTLS_PARAM_FAILED_ALT | 
|  | 63 |  | 
| Manuel Pégourié-Gonnard | 9b8ea89 | 2018-12-11 10:56:56 +0100 | [diff] [blame] | 64 | #else /* MBEDTLS_PARAM_FAILED */ | 
| Manuel Pégourié-Gonnard | 8e661bf | 2018-12-10 12:41:46 +0100 | [diff] [blame] | 65 | #define MBEDTLS_PARAM_FAILED( cond ) \ | 
| Manuel Pégourié-Gonnard | ab58852 | 2018-12-10 16:04:46 +0100 | [diff] [blame] | 66 | mbedtls_param_failed( #cond, __FILE__, __LINE__ ) | 
| Simon Butcher | b486803 | 2018-12-06 17:36:34 +0000 | [diff] [blame] | 67 |  | 
|  | 68 | /** | 
|  | 69 | * \brief       User supplied callback function for parameter validation failure. | 
| Manuel Pégourié-Gonnard | 35acb09 | 2018-12-11 12:26:49 +0100 | [diff] [blame] | 70 | *              See #MBEDTLS_CHECK_PARAMS for context. | 
| Simon Butcher | b486803 | 2018-12-06 17:36:34 +0000 | [diff] [blame] | 71 | * | 
| Manuel Pégourié-Gonnard | ab58852 | 2018-12-10 16:04:46 +0100 | [diff] [blame] | 72 | *              This function will be called unless an alternative treatement | 
| Manuel Pégourié-Gonnard | 35acb09 | 2018-12-11 12:26:49 +0100 | [diff] [blame] | 73 | *              is defined through the #MBEDTLS_PARAM_FAILED macro. | 
| Simon Butcher | b486803 | 2018-12-06 17:36:34 +0000 | [diff] [blame] | 74 | * | 
|  | 75 | *              This function can return, and the operation will be aborted, or | 
|  | 76 | *              alternatively, through use of setjmp()/longjmp() can resume | 
|  | 77 | *              execution in the application code. | 
| Manuel Pégourié-Gonnard | ab58852 | 2018-12-10 16:04:46 +0100 | [diff] [blame] | 78 | * | 
|  | 79 | * \param failure_condition The assertion that didn't hold. | 
|  | 80 | * \param file  The file where the assertion failed. | 
|  | 81 | * \param line  The line in the file where the assertion failed. | 
| Simon Butcher | b486803 | 2018-12-06 17:36:34 +0000 | [diff] [blame] | 82 | */ | 
| Manuel Pégourié-Gonnard | ab58852 | 2018-12-10 16:04:46 +0100 | [diff] [blame] | 83 | void mbedtls_param_failed( const char *failure_condition, | 
|  | 84 | const char *file, | 
| Manuel Pégourié-Gonnard | 3ef6a6d | 2018-12-10 14:31:45 +0100 | [diff] [blame] | 85 | int line ); | 
| Manuel Pégourié-Gonnard | a2b0e27 | 2018-12-10 15:23:58 +0100 | [diff] [blame] | 86 | #endif /* MBEDTLS_PARAM_FAILED */ | 
| Manuel Pégourié-Gonnard | 0e9cddb | 2018-12-10 16:37:51 +0100 | [diff] [blame] | 87 |  | 
|  | 88 | /* Internal macro meant to be called only from within the library. */ | 
|  | 89 | #define MBEDTLS_INTERNAL_VALIDATE_RET( cond, ret )  \ | 
|  | 90 | do {                                            \ | 
|  | 91 | if( !(cond) )                               \ | 
|  | 92 | {                                           \ | 
| Manuel Pégourié-Gonnard | 0e17cc9 | 2018-12-11 09:26:54 +0100 | [diff] [blame] | 93 | MBEDTLS_PARAM_FAILED( cond );           \ | 
| Manuel Pégourié-Gonnard | 0e9cddb | 2018-12-10 16:37:51 +0100 | [diff] [blame] | 94 | return( ret );                          \ | 
|  | 95 | }                                           \ | 
|  | 96 | } while( 0 ) | 
|  | 97 |  | 
|  | 98 | /* Internal macro meant to be called only from within the library. */ | 
|  | 99 | #define MBEDTLS_INTERNAL_VALIDATE( cond )           \ | 
|  | 100 | do {                                            \ | 
|  | 101 | if( !(cond) )                               \ | 
|  | 102 | {                                           \ | 
| Manuel Pégourié-Gonnard | 0e17cc9 | 2018-12-11 09:26:54 +0100 | [diff] [blame] | 103 | MBEDTLS_PARAM_FAILED( cond );           \ | 
| Manuel Pégourié-Gonnard | 0e9cddb | 2018-12-10 16:37:51 +0100 | [diff] [blame] | 104 | return;                                 \ | 
|  | 105 | }                                           \ | 
|  | 106 | } while( 0 ) | 
|  | 107 |  | 
|  | 108 | #else /* MBEDTLS_CHECK_PARAMS */ | 
|  | 109 |  | 
|  | 110 | /* Internal macros meant to be called only from within the library. */ | 
|  | 111 | #define MBEDTLS_INTERNAL_VALIDATE_RET( cond, ret )  do { } while( 0 ) | 
|  | 112 | #define MBEDTLS_INTERNAL_VALIDATE( cond )           do { } while( 0 ) | 
|  | 113 |  | 
| Manuel Pégourié-Gonnard | a2b0e27 | 2018-12-10 15:23:58 +0100 | [diff] [blame] | 114 | #endif /* MBEDTLS_CHECK_PARAMS */ | 
| Simon Butcher | b486803 | 2018-12-06 17:36:34 +0000 | [diff] [blame] | 115 |  | 
| Hanno Becker | 7bcf2b5 | 2019-07-26 09:02:40 +0100 | [diff] [blame] | 116 | #if defined(__GNUC__) || defined(__arm__) | 
|  | 117 | #define MBEDTLS_ALWAYS_INLINE __attribute__((always_inline)) | 
|  | 118 | #else | 
|  | 119 | #define MBEDTLS_ALWAYS_INLINE | 
|  | 120 | #endif | 
|  | 121 |  | 
| Hanno Becker | 6d0816a | 2018-12-17 11:30:27 +0000 | [diff] [blame] | 122 | /* Internal helper macros for deprecating API constants. */ | 
|  | 123 | #if !defined(MBEDTLS_DEPRECATED_REMOVED) | 
|  | 124 | #if defined(MBEDTLS_DEPRECATED_WARNING) | 
| Hanno Becker | 9dbefa1 | 2018-12-17 22:49:13 +0000 | [diff] [blame] | 125 | /* Deliberately don't (yet) export MBEDTLS_DEPRECATED here | 
|  | 126 | * to avoid conflict with other headers which define and use | 
|  | 127 | * it, too. We might want to move all these definitions here at | 
|  | 128 | * some point for uniformity. */ | 
|  | 129 | #define MBEDTLS_DEPRECATED __attribute__((deprecated)) | 
|  | 130 | MBEDTLS_DEPRECATED typedef char const * mbedtls_deprecated_string_constant_t; | 
| Hanno Becker | 6d0816a | 2018-12-17 11:30:27 +0000 | [diff] [blame] | 131 | #define MBEDTLS_DEPRECATED_STRING_CONSTANT( VAL )       \ | 
|  | 132 | ( (mbedtls_deprecated_string_constant_t) ( VAL ) ) | 
| Hanno Becker | 9dbefa1 | 2018-12-17 22:49:13 +0000 | [diff] [blame] | 133 | MBEDTLS_DEPRECATED typedef int mbedtls_deprecated_numeric_constant_t; | 
| Hanno Becker | 6d0816a | 2018-12-17 11:30:27 +0000 | [diff] [blame] | 134 | #define MBEDTLS_DEPRECATED_NUMERIC_CONSTANT( VAL )       \ | 
|  | 135 | ( (mbedtls_deprecated_numeric_constant_t) ( VAL ) ) | 
| Hanno Becker | 9dbefa1 | 2018-12-17 22:49:13 +0000 | [diff] [blame] | 136 | #undef MBEDTLS_DEPRECATED | 
| Hanno Becker | 6d0816a | 2018-12-17 11:30:27 +0000 | [diff] [blame] | 137 | #else /* MBEDTLS_DEPRECATED_WARNING */ | 
|  | 138 | #define MBEDTLS_DEPRECATED_STRING_CONSTANT( VAL ) VAL | 
|  | 139 | #define MBEDTLS_DEPRECATED_NUMERIC_CONSTANT( VAL ) VAL | 
|  | 140 | #endif /* MBEDTLS_DEPRECATED_WARNING */ | 
|  | 141 | #endif /* MBEDTLS_DEPRECATED_REMOVED */ | 
|  | 142 |  | 
| Andres Amaya Garcia | 904e1ef | 2018-04-17 09:16:30 -0500 | [diff] [blame] | 143 | /** | 
|  | 144 | * \brief       Securely zeroize a buffer | 
|  | 145 | * | 
| Andres Amaya Garcia | 56e06db | 2018-04-24 08:37:52 -0500 | [diff] [blame] | 146 | *              The function is meant to wipe the data contained in a buffer so | 
|  | 147 | *              that it can no longer be recovered even if the program memory | 
|  | 148 | *              is later compromised. Call this function on sensitive data | 
|  | 149 | *              stored on the stack before returning from a function, and on | 
|  | 150 | *              sensitive data stored on the heap before freeing the heap | 
|  | 151 | *              object. | 
| Andres Amaya Garcia | 904e1ef | 2018-04-17 09:16:30 -0500 | [diff] [blame] | 152 | * | 
| Andres Amaya Garcia | 56e06db | 2018-04-24 08:37:52 -0500 | [diff] [blame] | 153 | *              It is extremely difficult to guarantee that calls to | 
| Andres Amaya Garcia | 904e1ef | 2018-04-17 09:16:30 -0500 | [diff] [blame] | 154 | *              mbedtls_platform_zeroize() are not removed by aggressive | 
|  | 155 | *              compiler optimizations in a portable way. For this reason, Mbed | 
|  | 156 | *              TLS provides the configuration option | 
|  | 157 | *              MBEDTLS_PLATFORM_ZEROIZE_ALT, which allows users to configure | 
|  | 158 | *              mbedtls_platform_zeroize() to use a suitable implementation for | 
|  | 159 | *              their platform and needs | 
| Andres Amaya Garcia | 56e06db | 2018-04-24 08:37:52 -0500 | [diff] [blame] | 160 | * | 
|  | 161 | * \param buf   Buffer to be zeroized | 
|  | 162 | * \param len   Length of the buffer in bytes | 
|  | 163 | * | 
| Andres Amaya Garcia | 904e1ef | 2018-04-17 09:16:30 -0500 | [diff] [blame] | 164 | */ | 
|  | 165 | void mbedtls_platform_zeroize( void *buf, size_t len ); | 
|  | 166 |  | 
| Jarno Lamsa | 7d28155 | 2019-10-01 15:56:17 +0300 | [diff] [blame] | 167 | /** | 
|  | 168 | * \brief       Secure memset | 
|  | 169 | * | 
| Jarno Lamsa | c4315e6 | 2019-10-04 15:42:39 +0300 | [diff] [blame] | 170 | *              This is a constant-time version of memset(). If | 
|  | 171 | *              MBEDTLS_ENTROPY_HARDWARE_ALT is defined, the buffer is | 
|  | 172 | *              initialised with random data and the order is also | 
|  | 173 | *              randomised using the hardware RNG in order to further harden | 
|  | 174 | *              against side-channel attacks. | 
| Jarno Lamsa | 7d28155 | 2019-10-01 15:56:17 +0300 | [diff] [blame] | 175 | * | 
|  | 176 | * \param ptr   Buffer to be set. | 
|  | 177 | * \param value Value to be used when setting the buffer. | 
|  | 178 | * \param num   The length of the buffer in bytes. | 
| Jarno Lamsa | 0ff7109 | 2019-10-02 08:18:29 +0300 | [diff] [blame] | 179 | * | 
| Manuel Pégourié-Gonnard | 51f65e4 | 2019-10-02 16:01:14 +0200 | [diff] [blame] | 180 | * \return      The value of \p ptr. | 
| Jarno Lamsa | 7d28155 | 2019-10-01 15:56:17 +0300 | [diff] [blame] | 181 | */ | 
| Manuel Pégourié-Gonnard | 51f65e4 | 2019-10-02 16:01:14 +0200 | [diff] [blame] | 182 | void *mbedtls_platform_memset( void *ptr, int value, size_t num ); | 
| Jarno Lamsa | 0736325 | 2019-09-27 16:20:11 +0300 | [diff] [blame] | 183 |  | 
| Jarno Lamsa | 7d28155 | 2019-10-01 15:56:17 +0300 | [diff] [blame] | 184 | /** | 
|  | 185 | * \brief       Secure memcpy | 
|  | 186 | * | 
| Jarno Lamsa | c4315e6 | 2019-10-04 15:42:39 +0300 | [diff] [blame] | 187 | *              This is a constant-time version of memcpy(). If | 
|  | 188 | *              MBEDTLS_ENTROPY_HARDWARE_ALT is defined, the buffer is | 
|  | 189 | *              initialised with random data and the order is also | 
|  | 190 | *              randomised using the hardware RNG in order to further harden | 
|  | 191 | *              against side-channel attacks. | 
| Jarno Lamsa | 7d28155 | 2019-10-01 15:56:17 +0300 | [diff] [blame] | 192 | * | 
|  | 193 | * \param dst   Destination buffer where the data is being copied to. | 
|  | 194 | * \param src   Source buffer where the data is being copied from. | 
|  | 195 | * \param num   The length of the buffers in bytes. | 
|  | 196 | * | 
| Manuel Pégourié-Gonnard | 51f65e4 | 2019-10-02 16:01:14 +0200 | [diff] [blame] | 197 | * \return      The value of \p dst. | 
| Jarno Lamsa | 7d28155 | 2019-10-01 15:56:17 +0300 | [diff] [blame] | 198 | */ | 
| Manuel Pégourié-Gonnard | 51f65e4 | 2019-10-02 16:01:14 +0200 | [diff] [blame] | 199 | void *mbedtls_platform_memcpy( void *dst, const void *src, size_t num ); | 
| Jarno Lamsa | 0736325 | 2019-09-27 16:20:11 +0300 | [diff] [blame] | 200 |  | 
| Jarno Lamsa | 7d28155 | 2019-10-01 15:56:17 +0300 | [diff] [blame] | 201 | /** | 
|  | 202 | * \brief       Secure memcmp | 
|  | 203 | * | 
| Jarno Lamsa | c4315e6 | 2019-10-04 15:42:39 +0300 | [diff] [blame] | 204 | *              This is a constant-time version of memcmp(). If | 
|  | 205 | *              MBEDTLS_ENTROPY_HARDWARE_ALT is defined, the order is also | 
|  | 206 | *              randomised using the hardware RNG in order to further harden | 
|  | 207 | *              against side-channel attacks. | 
| Jarno Lamsa | 7d28155 | 2019-10-01 15:56:17 +0300 | [diff] [blame] | 208 | * | 
|  | 209 | * \param buf1  First buffer to compare. | 
|  | 210 | * \param buf2  Second buffer to compare against. | 
|  | 211 | * \param num   The length of the buffers in bytes. | 
|  | 212 | * | 
| Jarno Lamsa | c4315e6 | 2019-10-04 15:42:39 +0300 | [diff] [blame] | 213 | * \return      0 if the buffers were equal or an unspecified non-zero value | 
|  | 214 | *              otherwise. | 
| Jarno Lamsa | 7d28155 | 2019-10-01 15:56:17 +0300 | [diff] [blame] | 215 | */ | 
| Jarno Lamsa | 0736325 | 2019-09-27 16:20:11 +0300 | [diff] [blame] | 216 | int mbedtls_platform_memcmp( const void *buf1, const void *buf2, size_t num ); | 
|  | 217 |  | 
| Jarno Lamsa | 7d28155 | 2019-10-01 15:56:17 +0300 | [diff] [blame] | 218 | /** | 
| Jarno Lamsa | 39a9d40 | 2019-10-03 13:36:06 +0300 | [diff] [blame] | 219 | * \brief       RNG-function for getting a random in given range. | 
| Jarno Lamsa | 7d28155 | 2019-10-01 15:56:17 +0300 | [diff] [blame] | 220 | * | 
|  | 221 | *              This function is meant to provide a global RNG to be used | 
|  | 222 | *              throughout Mbed TLS for hardening the library. It is used | 
|  | 223 | *              for generating a random delay, random data or random offset | 
|  | 224 | *              for utility functions. It is not meant to be a | 
|  | 225 | *              cryptographically secure RNG, but provide an RNG for utility | 
|  | 226 | *              functions. | 
|  | 227 | * | 
| Jarno Lamsa | 39a9d40 | 2019-10-03 13:36:06 +0300 | [diff] [blame] | 228 | * \note        Currently the function is dependent of hardware providing an | 
|  | 229 | *              rng with MBEDTLS_ENTROPY_HARDWARE_ALT. By default, 0 is | 
|  | 230 | *              returned. | 
|  | 231 | * | 
|  | 232 | * \note        If the given range is [0, 0), 0 is returned. | 
|  | 233 | * | 
| Jarno Lamsa | f5ebe2a | 2019-10-02 08:23:11 +0300 | [diff] [blame] | 234 | * \param num   Max-value for the generated random number, exclusive. | 
|  | 235 | *              The generated number will be on range [0, num). | 
| Jarno Lamsa | 77a0e07 | 2019-10-02 08:39:32 +0300 | [diff] [blame] | 236 | * | 
| Jarno Lamsa | f5ebe2a | 2019-10-02 08:23:11 +0300 | [diff] [blame] | 237 | * \return      The generated random number. | 
| Jarno Lamsa | a1e5054 | 2019-10-02 12:44:36 +0300 | [diff] [blame] | 238 | */ | 
| Jarno Lamsa | f65e9de | 2019-10-01 16:09:35 +0300 | [diff] [blame] | 239 | uint32_t mbedtls_platform_random_in_range( size_t num ); | 
| Jarno Lamsa | 0736325 | 2019-09-27 16:20:11 +0300 | [diff] [blame] | 240 |  | 
| Andres Amaya Garcia | 1abb368 | 2018-08-16 21:42:09 +0100 | [diff] [blame] | 241 | #if defined(MBEDTLS_HAVE_TIME_DATE) | 
|  | 242 | /** | 
| Hanno Becker | c52ef40 | 2018-09-05 16:28:59 +0100 | [diff] [blame] | 243 | * \brief      Platform-specific implementation of gmtime_r() | 
| Andres Amaya Garcia | 1abb368 | 2018-08-16 21:42:09 +0100 | [diff] [blame] | 244 | * | 
| Hanno Becker | c52ef40 | 2018-09-05 16:28:59 +0100 | [diff] [blame] | 245 | *             The function is a thread-safe abstraction that behaves | 
| Hanno Becker | 03b2bd4 | 2018-09-06 09:08:55 +0100 | [diff] [blame] | 246 | *             similarly to the gmtime_r() function from Unix/POSIX. | 
| Andres Amaya Garcia | 1abb368 | 2018-08-16 21:42:09 +0100 | [diff] [blame] | 247 | * | 
| Hanno Becker | 6a73978 | 2018-09-05 15:06:19 +0100 | [diff] [blame] | 248 | *             Mbed TLS will try to identify the underlying platform and | 
| Hanno Becker | c52ef40 | 2018-09-05 16:28:59 +0100 | [diff] [blame] | 249 | *             make use of an appropriate underlying implementation (e.g. | 
| Hanno Becker | 6a73978 | 2018-09-05 15:06:19 +0100 | [diff] [blame] | 250 | *             gmtime_r() for POSIX and gmtime_s() for Windows). If this is | 
|  | 251 | *             not possible, then gmtime() will be used. In this case, calls | 
|  | 252 | *             from the library to gmtime() will be guarded by the mutex | 
|  | 253 | *             mbedtls_threading_gmtime_mutex if MBEDTLS_THREADING_C is | 
|  | 254 | *             enabled. It is recommended that calls from outside the library | 
|  | 255 | *             are also guarded by this mutex. | 
| Andres Amaya Garcia | 1abb368 | 2018-08-16 21:42:09 +0100 | [diff] [blame] | 256 | * | 
| Hanno Becker | 6a73978 | 2018-09-05 15:06:19 +0100 | [diff] [blame] | 257 | *             If MBEDTLS_PLATFORM_GMTIME_R_ALT is defined, then Mbed TLS will | 
|  | 258 | *             unconditionally use the alternative implementation for | 
|  | 259 | *             mbedtls_platform_gmtime_r() supplied by the user at compile time. | 
| Andres Amaya Garcia | 1abb368 | 2018-08-16 21:42:09 +0100 | [diff] [blame] | 260 | * | 
| Hanno Becker | 272675f | 2018-09-05 14:03:02 +0100 | [diff] [blame] | 261 | * \param tt     Pointer to an object containing time (in seconds) since the | 
| Hanno Becker | 48a816f | 2018-09-05 15:22:22 +0100 | [diff] [blame] | 262 | *               epoch to be converted | 
| Hanno Becker | 272675f | 2018-09-05 14:03:02 +0100 | [diff] [blame] | 263 | * \param tm_buf Pointer to an object where the results will be stored | 
| Andres Amaya Garcia | 1abb368 | 2018-08-16 21:42:09 +0100 | [diff] [blame] | 264 | * | 
|  | 265 | * \return      Pointer to an object of type struct tm on success, otherwise | 
|  | 266 | *              NULL | 
|  | 267 | */ | 
| Hanno Becker | 6a73978 | 2018-09-05 15:06:19 +0100 | [diff] [blame] | 268 | struct tm *mbedtls_platform_gmtime_r( const mbedtls_time_t *tt, | 
|  | 269 | struct tm *tm_buf ); | 
| Andres Amaya Garcia | 1abb368 | 2018-08-16 21:42:09 +0100 | [diff] [blame] | 270 | #endif /* MBEDTLS_HAVE_TIME_DATE */ | 
|  | 271 |  | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 272 | /** | 
| Arto Kinnunen | 9b3b194 | 2019-09-09 17:02:35 +0300 | [diff] [blame] | 273 | * \brief      Convert a 32-bit number to the big endian format and write it to | 
|  | 274 | *             the given buffer. | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 275 | * | 
| Arto Kinnunen | 9b3b194 | 2019-09-09 17:02:35 +0300 | [diff] [blame] | 276 | * \param buf  Address where the converted number is written. | 
|  | 277 | * \param num  A number that needs to be converted to the big endian format. | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 278 | * | 
| Arto Kinnunen | 9b3b194 | 2019-09-09 17:02:35 +0300 | [diff] [blame] | 279 | * \return     Address to the end of buffer where the converted number is | 
|  | 280 | *             written. | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 281 | */ | 
| Arto Kinnunen | ee9bfca | 2019-09-06 16:59:00 +0300 | [diff] [blame] | 282 | unsigned char* mbedtls_platform_put_uint32_be( unsigned char *buf, | 
| Arto Kinnunen | 4f4849a | 2019-09-09 10:21:18 +0300 | [diff] [blame] | 283 | size_t num ); | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 284 |  | 
|  | 285 | /** | 
| Arto Kinnunen | 9b3b194 | 2019-09-09 17:02:35 +0300 | [diff] [blame] | 286 | * \brief      Convert a 24-bit number to the big endian format and write it to | 
|  | 287 | *             the given buffer. | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 288 | * | 
| Arto Kinnunen | 9b3b194 | 2019-09-09 17:02:35 +0300 | [diff] [blame] | 289 | * \param buf  Address where the converted number is written. | 
|  | 290 | * \param num  A number that needs to be converted to the big endian format. | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 291 | * | 
| Arto Kinnunen | 9b3b194 | 2019-09-09 17:02:35 +0300 | [diff] [blame] | 292 | * \return     Address to the end of buffer where the converted number is | 
|  | 293 | *             written. | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 294 | */ | 
| Arto Kinnunen | ee9bfca | 2019-09-06 16:59:00 +0300 | [diff] [blame] | 295 | unsigned char* mbedtls_platform_put_uint24_be( unsigned char *buf, | 
| Arto Kinnunen | 4f4849a | 2019-09-09 10:21:18 +0300 | [diff] [blame] | 296 | size_t num ); | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 297 |  | 
|  | 298 | /** | 
| Arto Kinnunen | 9b3b194 | 2019-09-09 17:02:35 +0300 | [diff] [blame] | 299 | * \brief      Convert a 16-bit number to the big endian format and write it to | 
|  | 300 | *             the given buffer. | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 301 | * | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 302 | * | 
| Arto Kinnunen | 9b3b194 | 2019-09-09 17:02:35 +0300 | [diff] [blame] | 303 | * \param buf  Address where the converted number is written. | 
|  | 304 | * \param num  A number that needs to be converted to the big endian format. | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 305 | * | 
| Arto Kinnunen | 9b3b194 | 2019-09-09 17:02:35 +0300 | [diff] [blame] | 306 | * \return     Address to the end of buffer where the converted number is | 
|  | 307 | *             written. | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 308 | */ | 
| Arto Kinnunen | ee9bfca | 2019-09-06 16:59:00 +0300 | [diff] [blame] | 309 | unsigned char* mbedtls_platform_put_uint16_be( unsigned char *buf, | 
| Arto Kinnunen | 4f4849a | 2019-09-09 10:21:18 +0300 | [diff] [blame] | 310 | size_t num ); | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 311 |  | 
|  | 312 | /** | 
| Arto Kinnunen | 9b3b194 | 2019-09-09 17:02:35 +0300 | [diff] [blame] | 313 | * \brief      Convert a 32-bit number from the big endian format. | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 314 | * | 
| Arto Kinnunen | 9b3b194 | 2019-09-09 17:02:35 +0300 | [diff] [blame] | 315 | *             The function reads a 32-bit number from the given buffer in the | 
|  | 316 | *             big endian format and returns it to the caller. | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 317 | * | 
| Arto Kinnunen | 9b3b194 | 2019-09-09 17:02:35 +0300 | [diff] [blame] | 318 | * \param buf  Buffer where the 32-bit number locates. | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 319 | * | 
|  | 320 | * \return     Converted number. | 
|  | 321 | */ | 
| Arto Kinnunen | 4f4849a | 2019-09-09 10:21:18 +0300 | [diff] [blame] | 322 | size_t mbedtls_platform_get_uint32_be( const unsigned char *buf ); | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 323 |  | 
|  | 324 | /** | 
| Arto Kinnunen | 9b3b194 | 2019-09-09 17:02:35 +0300 | [diff] [blame] | 325 | * \brief      Convert a 24-bit number from the big endian format. | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 326 | * | 
| Arto Kinnunen | 9b3b194 | 2019-09-09 17:02:35 +0300 | [diff] [blame] | 327 | *             The function reads a 14-bit number from the given buffer in the | 
|  | 328 | *             big endian format and returns it to the caller. | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 329 | * | 
| Arto Kinnunen | 9b3b194 | 2019-09-09 17:02:35 +0300 | [diff] [blame] | 330 | * \param buf  Buffer where the 24-bit number locates. | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 331 | * | 
|  | 332 | * \return     Converted number. | 
|  | 333 | */ | 
| Arto Kinnunen | 4f4849a | 2019-09-09 10:21:18 +0300 | [diff] [blame] | 334 | size_t mbedtls_platform_get_uint24_be( const unsigned char *buf ); | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 335 |  | 
|  | 336 | /** | 
| Arto Kinnunen | 9b3b194 | 2019-09-09 17:02:35 +0300 | [diff] [blame] | 337 | * \brief      Convert a 16-bit number from the big endian format. | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 338 | * | 
| Arto Kinnunen | 9b3b194 | 2019-09-09 17:02:35 +0300 | [diff] [blame] | 339 | *             The function reads a 16-bit number from the given buffer in the | 
|  | 340 | *             big endian format and returns it to the caller. | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 341 | * | 
| Arto Kinnunen | 9b3b194 | 2019-09-09 17:02:35 +0300 | [diff] [blame] | 342 | * \param buf  Buffer where the 16-bit number locates. | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 343 | * | 
|  | 344 | * \return     Converted number. | 
|  | 345 | */ | 
| Arto Kinnunen | 4f4849a | 2019-09-09 10:21:18 +0300 | [diff] [blame] | 346 | size_t mbedtls_platform_get_uint16_be( const unsigned char *buf ); | 
| Arto Kinnunen | 0b62ce8 | 2019-09-04 14:04:57 +0300 | [diff] [blame] | 347 |  | 
| Andres Amaya Garcia | 904e1ef | 2018-04-17 09:16:30 -0500 | [diff] [blame] | 348 | #ifdef __cplusplus | 
|  | 349 | } | 
|  | 350 | #endif | 
|  | 351 |  | 
|  | 352 | #endif /* MBEDTLS_PLATFORM_UTIL_H */ |