Commit 52e3da0a authored by iabdalkader's avatar iabdalkader Committed by Damien George

mimxrt/mbedtls: Enable certificate validity time validation.

Signed-off-by: default avatariabdalkader <i.abdalkader@gmail.com>
parent 361ca7d5
...@@ -26,6 +26,15 @@ ...@@ -26,6 +26,15 @@
#ifndef MICROPY_INCLUDED_MBEDTLS_CONFIG_H #ifndef MICROPY_INCLUDED_MBEDTLS_CONFIG_H
#define MICROPY_INCLUDED_MBEDTLS_CONFIG_H #define MICROPY_INCLUDED_MBEDTLS_CONFIG_H
// Enable mbedtls modules.
#define MBEDTLS_HAVE_TIME
#define MBEDTLS_HAVE_TIME_DATE
// Time hook.
#include <time.h>
extern time_t mimxrt_rtctime_seconds(time_t *timer);
#define MBEDTLS_PLATFORM_TIME_MACRO mimxrt_rtctime_seconds
// Set MicroPython-specific options. // Set MicroPython-specific options.
#define MICROPY_MBEDTLS_CONFIG_BARE_METAL (1) #define MICROPY_MBEDTLS_CONFIG_BARE_METAL (1)
......
...@@ -24,9 +24,16 @@ ...@@ -24,9 +24,16 @@
* THE SOFTWARE. * THE SOFTWARE.
*/ */
#include "py/runtime.h"
#ifdef MICROPY_SSL_MBEDTLS #ifdef MICROPY_SSL_MBEDTLS
#include "mbedtls_config.h" #include "mbedtls_config.h"
#if defined(MBEDTLS_HAVE_TIME) || defined(MBEDTLS_HAVE_TIME_DATE)
#include "fsl_snvs_lp.h"
#include "shared/timeutils/timeutils.h"
#endif
void trng_random_data(unsigned char *output, size_t len); void trng_random_data(unsigned char *output, size_t len);
int mbedtls_hardware_poll(void *data, unsigned char *output, size_t len, size_t *olen) { int mbedtls_hardware_poll(void *data, unsigned char *output, size_t len, size_t *olen) {
...@@ -38,4 +45,33 @@ int mbedtls_hardware_poll(void *data, unsigned char *output, size_t len, size_t ...@@ -38,4 +45,33 @@ int mbedtls_hardware_poll(void *data, unsigned char *output, size_t len, size_t
return 0; return 0;
} }
#if defined(MBEDTLS_HAVE_TIME)
time_t mimxrt_rtctime_seconds(time_t *timer) {
// Get date and date in CPython order.
snvs_lp_srtc_datetime_t date;
SNVS_LP_SRTC_GetDatetime(SNVS, &date);
return timeutils_seconds_since_epoch(date.year, date.month, date.day, date.hour, date.minute, date.second);
}
#endif
#if defined(MBEDTLS_HAVE_TIME_DATE)
struct tm *gmtime(const time_t *timep) {
static struct tm tm;
timeutils_struct_time_t tm_buf = {0};
timeutils_seconds_since_epoch_to_struct_time(*timep, &tm_buf);
tm.tm_sec = tm_buf.tm_sec;
tm.tm_min = tm_buf.tm_min;
tm.tm_hour = tm_buf.tm_hour;
tm.tm_mday = tm_buf.tm_mday;
tm.tm_mon = tm_buf.tm_mon - 1;
tm.tm_year = tm_buf.tm_year - 1900;
tm.tm_wday = tm_buf.tm_wday;
tm.tm_yday = tm_buf.tm_yday;
tm.tm_isdst = -1;
return &tm;
}
#endif
#endif #endif
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment