File platform.h
This file contains the definitions and functions of the Mbed TLS platform abstraction layer.
The platform abstraction layer removes the need for the library to directly link to standard C library functions or operating system services, making the library easier to port and embed. Application developers and users of the library can provide their own implementations of these functions, or implementations specific to their platform, which can be statically linked to the library or dynamically configured at runtime.
When all compilation options related to platform abstraction are disabled, this header just defines mbedtls_xxx
function names as aliases to the standard xxx
function.
Most modules in the library and example programs are expected to include this header.
Functions
-
int mbedtls_platform_set_fprintf(int (*fprintf_func)(FILE *stream, const char*, ...))
This function dynamically configures the fprintf function that is called when the mbedtls_fprintf() function is invoked by the library.
- Parameters:
fprintf_func – The
fprintf
function implementation.- Returns:
0
.
-
int mbedtls_platform_set_printf(int (*printf_func)(const char*, ...))
This function dynamically configures the snprintf function that is called when the mbedtls_snprintf() function is invoked by the library.
- Parameters:
printf_func – The
printf
function implementation.- Returns:
0
on success.
-
int mbedtls_platform_set_snprintf(int (*snprintf_func)(char *s, size_t n, const char *format, ...))
This function allows configuring a custom
snprintf
function pointer.- Parameters:
snprintf_func – The
snprintf
function implementation.- Returns:
0
on success.
-
int mbedtls_platform_set_vsnprintf(int (*vsnprintf_func)(char *s, size_t n, const char *format, va_list arg))
Set your own snprintf function pointer.
- Parameters:
vsnprintf_func – The
vsnprintf
function implementation- Returns:
0
-
int mbedtls_platform_set_setbuf(void (*setbuf_func)(FILE *stream, char *buf))
Dynamically configure the function that is called when the mbedtls_setbuf() function is called by the library.
- Parameters:
setbuf_func – The
setbuf
function implementation- Returns:
0
-
int mbedtls_platform_set_exit(void (*exit_func)(int status))
This function dynamically configures the exit function that is called when the mbedtls_exit() function is invoked by the library.
- Parameters:
exit_func – The
exit
function implementation.- Returns:
0
on success.
-
int mbedtls_platform_set_nv_seed(int (*nv_seed_read_func)(unsigned char *buf, size_t buf_len), int (*nv_seed_write_func)(unsigned char *buf, size_t buf_len))
This function allows configuring custom seed file writing and reading functions.
- Parameters:
nv_seed_read_func – The seed reading function implementation.
nv_seed_write_func – The seed writing function implementation.
- Returns:
0
on success.
-
int mbedtls_platform_setup(mbedtls_platform_context *ctx)
This function performs any platform-specific initialization operations.
Note
This function should be called before any other library functions.
Its implementation is platform-specific, and unless platform-specific code is provided, it does nothing.
Note
The usage and necessity of this function is dependent on the platform.
- Parameters:
ctx – The platform context.
- Returns:
0
on success.
-
void mbedtls_platform_teardown(mbedtls_platform_context *ctx)
This function performs any platform teardown operations.
Its implementation is platform-specific, and unless platform-specific code is provided, it does nothing.
Note
This function should be called after every other Mbed TLS module has been correctly freed using the appropriate free function.
Note
The usage and necessity of this function is dependent on the platform.
- Parameters:
ctx – The platform context.
Variables
-
int (*mbedtls_fprintf)(FILE *stream, const char *format, ...)
-
int (*mbedtls_printf)(const char *format, ...)
-
int (*mbedtls_snprintf)(char *s, size_t n, const char *format, ...)
-
int (*mbedtls_vsnprintf)(char *s, size_t n, const char *format, va_list arg)
-
void (*mbedtls_setbuf)(FILE *stream, char *buf)
Function pointer to call for
setbuf()
functionality (changing the internal buffering on stdio calls).The library always calls this function with
buf
equal toNULL
.Note
The library calls this function to disable buffering when reading or writing sensitive data, to avoid having extra copies of sensitive data remaining in stdio buffers after the file is closed. If this is not a concern, for example if your platform’s stdio doesn’t have any buffering, you can set mbedtls_setbuf to a function that does nothing.
-
void (*mbedtls_exit)(int status)
-
int (*mbedtls_nv_seed_read)(unsigned char *buf, size_t buf_len)
-
int (*mbedtls_nv_seed_write)(unsigned char *buf, size_t buf_len)