fix(linux): fixed build errors on MacOS

This commit is contained in:
Jakob Hasse 2024-04-26 16:29:59 +02:00
parent 7f056333ae
commit 2f0ef33f9d
2 changed files with 22 additions and 0 deletions

View File

@ -6,7 +6,13 @@
#include <stddef.h> #include <stddef.h>
#include <stdint.h> #include <stdint.h>
#include <assert.h> #include <assert.h>
// getentropy live in different header files on Mac and Linux
#if (defined(__APPLE__) && defined(__MACH__))
#include <sys/random.h>
#else
#include <unistd.h> #include <unistd.h>
#endif
#include "esp_log.h" #include "esp_log.h"

View File

@ -12,6 +12,20 @@
#pragma once #pragma once
#if (defined(__APPLE__) && defined(__MACH__))
// MacOS
#if !defined(__containerof)
#define __containerof(ptr, type, member) ({ \
const typeof( ((type *)0)->member ) *__mptr = (ptr); \
(type *)( (char *)__mptr - offsetof(type,member) );})
#endif
#include_next <sys/cdefs.h> // include the actual cdefs.h (which does not contain containerof)
#else
// Linux
#include <stdint.h> #include <stdint.h>
// We need a define. We can't typedef here since, depending on the include order, // We need a define. We can't typedef here since, depending on the include order,
@ -20,3 +34,5 @@
#include_next <sys/cdefs.h> #include_next <sys/cdefs.h>
#include <bsd/sys/cdefs.h> #include <bsd/sys/cdefs.h>
#endif