summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authoriabdalkader <i.abdalkader@gmail.com>2021-08-29 18:58:31 +0200
committerDamien George <damien@micropython.org>2021-09-19 23:35:10 +1000
commit2c5e9bbdface4eb163b53f486359ca2208b7b0a5 (patch)
tree5b127dd4fd824111bde507c654e09d4054fe65af
parent38f8e852e04013e4616097320bf9cf75051a1b6b (diff)
extmod: Add platform module.
It contains the compiler version, and underlying system HAL/SDK version.
-rw-r--r--extmod/extmod.cmake1
-rw-r--r--extmod/moduplatform.c136
-rw-r--r--py/builtin.h1
-rw-r--r--py/objmodule.c3
-rw-r--r--py/py.mk1
5 files changed, 142 insertions, 0 deletions
diff --git a/extmod/extmod.cmake b/extmod/extmod.cmake
index 3353112ba..67f7d8fd3 100644
--- a/extmod/extmod.cmake
+++ b/extmod/extmod.cmake
@@ -25,6 +25,7 @@ set(MICROPY_SOURCE_EXTMOD
${MICROPY_EXTMOD_DIR}/moduhashlib.c
${MICROPY_EXTMOD_DIR}/moduheapq.c
${MICROPY_EXTMOD_DIR}/modujson.c
+ ${MICROPY_EXTMOD_DIR}/moduplatform.c
${MICROPY_EXTMOD_DIR}/modurandom.c
${MICROPY_EXTMOD_DIR}/modure.c
${MICROPY_EXTMOD_DIR}/moduselect.c
diff --git a/extmod/moduplatform.c b/extmod/moduplatform.c
new file mode 100644
index 000000000..06bb9d5ce
--- /dev/null
+++ b/extmod/moduplatform.c
@@ -0,0 +1,136 @@
+/*
+ * This file is part of the MicroPython project, http://micropython.org/
+ *
+ * The MIT License (MIT)
+ *
+ * Copyright (c) 2013-2021 Ibrahim Abdelkader <iabdalkader@openmv.io>
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
+ * of this software and associated documentation files (the "Software"), to deal
+ * in the Software without restriction, including without limitation the rights
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+ * copies of the Software, and to permit persons to whom the Software is
+ * furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+ * THE SOFTWARE.
+ *
+ */
+
+#include "py/runtime.h"
+#include "py/objtuple.h"
+#include "py/objstr.h"
+#include "py/mphal.h"
+#include "genhdr/mpversion.h"
+
+#if MICROPY_PY_UPLATFORM
+
+// platform - Access to underlying platform's identifying data
+
+// TODO: Add more architectures, compilers and libraries.
+// See: https://sourceforge.net/p/predef/wiki/Home/
+
+#if defined(__ARM_ARCH)
+#define PLATFORM_ARCH "arm"
+#elif defined(__x86_64__)
+#define PLATFORM_ARCH "x86_64"
+#else
+#define PLATFORM_ARCH ""
+#endif
+
+#if defined(__GNUC__)
+#define PLATFORM_COMPILER \
+ "GCC " \
+ MP_STRINGIFY(__GNUC__) "." \
+ MP_STRINGIFY(__GNUC_MINOR__) "." \
+ MP_STRINGIFY(__GNUC_PATCHLEVEL__)
+#elif defined(__ARMCC_VERSION)
+#define PLATFORM_COMPILER \
+ "ARMCC " \
+ MP_STRINGIFY((__ARMCC_VERSION / 1000000)) "." \
+ MP_STRINGIFY((__ARMCC_VERSION / 10000 % 100)) "." \
+ MP_STRINGIFY((__ARMCC_VERSION % 10000))
+#else
+#define PLATFORM_COMPILER ""
+#endif
+
+#if defined(__GLIBC__)
+#define PLATFORM_LIBC_LIB "glibc"
+#define PLATFORM_LIBC_VER \
+ MP_STRINGIFY(__GLIBC__) "." \
+ MP_STRINGIFY(__GLIBC_MINOR__)
+#elif defined(__NEWLIB__)
+#define PLATFORM_LIBC_LIB "newlib"
+#define PLATFORM_LIBC_VER _NEWLIB_VERSION
+#else
+#define PLATFORM_LIBC_LIB ""
+#define PLATFORM_LIBC_VER ""
+#endif
+
+#if defined(__linux)
+#define PLATFORM_SYSTEM "Linux"
+#elif defined(__unix__)
+#define PLATFORM_SYSTEM "Unix"
+#elif defined(__CYGWIN__)
+#define PLATFORM_SYSTEM "Cygwin"
+#elif defined(__WIN32__)
+#define PLATFORM_SYSTEM "Windows"
+#else
+#define PLATFORM_SYSTEM "MicroPython"
+#endif
+
+#ifndef MICROPY_HW_BOARD_NAME
+#define MICROPY_HW_BOARD_NAME PLATFORM_ARCH
+#endif
+
+#ifndef MICROPY_HW_MCU_NAME
+#define MICROPY_HW_MCU_NAME ""
+#endif
+
+STATIC const MP_DEFINE_STR_OBJ(info_platform_obj, PLATFORM_SYSTEM "-" MICROPY_VERSION_STRING "-HAL" \
+ MICROPY_HAL_VERSION "-" PLATFORM_ARCH "-with-" PLATFORM_LIBC_LIB "" PLATFORM_LIBC_VER);
+STATIC const MP_DEFINE_STR_OBJ(info_python_compiler_obj, PLATFORM_COMPILER);
+STATIC const MP_DEFINE_STR_OBJ(info_libc_lib_obj, PLATFORM_LIBC_LIB);
+STATIC const MP_DEFINE_STR_OBJ(info_libc_ver_obj, PLATFORM_LIBC_VER);
+STATIC const mp_rom_obj_tuple_t info_libc_tuple_obj = {
+ {&mp_type_tuple}, 2, {MP_ROM_PTR(&info_libc_lib_obj), MP_ROM_PTR(&info_libc_ver_obj)}
+};
+
+STATIC mp_obj_t platform_platform(size_t n_args, const mp_obj_t *pos_args, mp_map_t *kw_args) {
+ return MP_OBJ_FROM_PTR(&info_platform_obj);
+}
+STATIC MP_DEFINE_CONST_FUN_OBJ_KW(platform_platform_obj, 0, platform_platform);
+
+STATIC mp_obj_t platform_python_compiler(void) {
+ return MP_OBJ_FROM_PTR(&info_python_compiler_obj);
+}
+STATIC MP_DEFINE_CONST_FUN_OBJ_0(platform_python_compiler_obj, platform_python_compiler);
+
+STATIC mp_obj_t platform_libc_ver(size_t n_args, const mp_obj_t *pos_args, mp_map_t *kw_args) {
+ return MP_OBJ_FROM_PTR(&info_libc_tuple_obj);
+}
+STATIC MP_DEFINE_CONST_FUN_OBJ_KW(platform_libc_ver_obj, 0, platform_libc_ver);
+
+STATIC const mp_rom_map_elem_t modplatform_globals_table[] = {
+ { MP_ROM_QSTR(MP_QSTR___name__), MP_ROM_QSTR(MP_QSTR_uplatform) },
+ { MP_ROM_QSTR(MP_QSTR_platform), MP_ROM_PTR(&platform_platform_obj) },
+ { MP_ROM_QSTR(MP_QSTR_python_compiler), MP_ROM_PTR(&platform_python_compiler_obj) },
+ { MP_ROM_QSTR(MP_QSTR_libc_ver), MP_ROM_PTR(&platform_libc_ver_obj) },
+};
+
+STATIC MP_DEFINE_CONST_DICT(modplatform_globals, modplatform_globals_table);
+
+const mp_obj_module_t mp_module_uplatform = {
+ .base = { &mp_type_module },
+ .globals = (mp_obj_dict_t *)&modplatform_globals,
+};
+
+#endif // MICROPY_PY_UPLATFORM
diff --git a/py/builtin.h b/py/builtin.h
index 1e4769cd6..8639e978f 100644
--- a/py/builtin.h
+++ b/py/builtin.h
@@ -124,6 +124,7 @@ extern const mp_obj_module_t mp_module_webrepl;
extern const mp_obj_module_t mp_module_framebuf;
extern const mp_obj_module_t mp_module_btree;
extern const mp_obj_module_t mp_module_ubluetooth;
+extern const mp_obj_module_t mp_module_uplatform;
extern const char MICROPY_PY_BUILTINS_HELP_TEXT[];
diff --git a/py/objmodule.c b/py/objmodule.c
index a1f9d9d7f..d648f0f8c 100644
--- a/py/objmodule.c
+++ b/py/objmodule.c
@@ -230,6 +230,9 @@ STATIC const mp_rom_map_elem_t mp_builtin_module_table[] = {
#if MICROPY_PY_BLUETOOTH
{ MP_ROM_QSTR(MP_QSTR_ubluetooth), MP_ROM_PTR(&mp_module_ubluetooth) },
#endif
+ #if MICROPY_PY_UPLATFORM
+ { MP_ROM_QSTR(MP_QSTR_uplatform), MP_ROM_PTR(&mp_module_uplatform) },
+ #endif
// extra builtin modules as defined by a port
MICROPY_PORT_BUILTIN_MODULES
diff --git a/py/py.mk b/py/py.mk
index be8296e5e..8e1e23554 100644
--- a/py/py.mk
+++ b/py/py.mk
@@ -195,6 +195,7 @@ PY_EXTMOD_O_BASENAME = \
extmod/modbluetooth.o \
extmod/modussl_axtls.o \
extmod/modussl_mbedtls.o \
+ extmod/moduplatform.o\
extmod/modurandom.o \
extmod/moduselect.o \
extmod/moduwebsocket.o \