summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--extmod/misc.h1
-rw-r--r--extmod/moduos.c6
-rw-r--r--extmod/uos_dupterm.c4
-rw-r--r--ports/stm32/Makefile1
-rw-r--r--ports/stm32/modpyb.c2
-rw-r--r--ports/stm32/moduos.c144
-rw-r--r--ports/stm32/mpconfigport.h18
-rw-r--r--ports/stm32/portmodules.h4
8 files changed, 42 insertions, 138 deletions
diff --git a/extmod/misc.h b/extmod/misc.h
index 40b091e5f..a9392aa10 100644
--- a/extmod/misc.h
+++ b/extmod/misc.h
@@ -36,6 +36,7 @@ MP_DECLARE_CONST_FUN_OBJ_VAR_BETWEEN(mp_uos_dupterm_obj);
#if MICROPY_PY_OS_DUPTERM
bool mp_uos_dupterm_is_builtin_stream(mp_const_obj_t stream);
+void mp_uos_dupterm_stream_detached_attached(mp_obj_t stream_detached, mp_obj_t stream_attached);
uintptr_t mp_uos_dupterm_poll(uintptr_t poll_flags);
int mp_uos_dupterm_rx_chr(void);
void mp_uos_dupterm_tx_strn(const char *str, size_t len);
diff --git a/extmod/moduos.c b/extmod/moduos.c
index 0378d5030..28c482dd9 100644
--- a/extmod/moduos.c
+++ b/extmod/moduos.c
@@ -88,6 +88,12 @@ STATIC MP_DEFINE_CONST_FUN_OBJ_0(mp_uos_uname_obj, mp_uos_uname);
STATIC const mp_rom_map_elem_t os_module_globals_table[] = {
{ MP_ROM_QSTR(MP_QSTR___name__), MP_ROM_QSTR(MP_QSTR_uos) },
+ #if MICROPY_PY_UOS_SEP
+ { MP_ROM_QSTR(MP_QSTR_sep), MP_ROM_QSTR(MP_QSTR__slash_) },
+ #endif
+ #if MICROPY_PY_UOS_SYNC
+ { MP_ROM_QSTR(MP_QSTR_sync), MP_ROM_PTR(&mp_uos_sync_obj) },
+ #endif
#if MICROPY_PY_UOS_UNAME
{ MP_ROM_QSTR(MP_QSTR_uname), MP_ROM_PTR(&mp_uos_uname_obj) },
#endif
diff --git a/extmod/uos_dupterm.c b/extmod/uos_dupterm.c
index d55767de2..e18d133b9 100644
--- a/extmod/uos_dupterm.c
+++ b/extmod/uos_dupterm.c
@@ -193,6 +193,10 @@ STATIC mp_obj_t mp_uos_dupterm(size_t n_args, const mp_obj_t *args) {
MP_STATE_VM(dupterm_objs[idx]) = args[0];
}
+ #if MICROPY_PY_UOS_DUPTERM_STREAM_DETACHED_ATTACHED
+ mp_uos_dupterm_stream_detached_attached(previous_obj, args[0]);
+ #endif
+
return previous_obj;
}
MP_DEFINE_CONST_FUN_OBJ_VAR_BETWEEN(mp_uos_dupterm_obj, 1, 2, mp_uos_dupterm);
diff --git a/ports/stm32/Makefile b/ports/stm32/Makefile
index dd86f1e3f..3083c9957 100644
--- a/ports/stm32/Makefile
+++ b/ports/stm32/Makefile
@@ -297,7 +297,6 @@ SRC_C += \
modmachine.c \
modpyb.c \
modstm.c \
- moduos.c \
modutime.c \
network_lan.c \
extint.c \
diff --git a/ports/stm32/modpyb.c b/ports/stm32/modpyb.c
index b9e2bac03..a44465488 100644
--- a/ports/stm32/modpyb.c
+++ b/ports/stm32/modpyb.c
@@ -185,7 +185,7 @@ STATIC const mp_rom_map_elem_t pyb_module_globals_table[] = {
{ MP_ROM_QSTR(MP_QSTR_elapsed_micros), MP_ROM_PTR(&pyb_elapsed_micros_obj) },
{ MP_ROM_QSTR(MP_QSTR_delay), MP_ROM_PTR(&mp_utime_sleep_ms_obj) },
{ MP_ROM_QSTR(MP_QSTR_udelay), MP_ROM_PTR(&mp_utime_sleep_us_obj) },
- { MP_ROM_QSTR(MP_QSTR_sync), MP_ROM_PTR(&mod_os_sync_obj) },
+ { MP_ROM_QSTR(MP_QSTR_sync), MP_ROM_PTR(&mp_uos_sync_obj) },
{ MP_ROM_QSTR(MP_QSTR_mount), MP_ROM_PTR(&mp_vfs_mount_obj) },
#endif
diff --git a/ports/stm32/moduos.c b/ports/stm32/moduos.c
index 5b2335272..1862564b6 100644
--- a/ports/stm32/moduos.c
+++ b/ports/stm32/moduos.c
@@ -24,66 +24,19 @@
* THE SOFTWARE.
*/
-#include <stdint.h>
-#include <string.h>
-
#include "py/runtime.h"
-#include "py/objtuple.h"
-#include "py/objstr.h"
-#include "shared/timeutils/timeutils.h"
-#include "lib/oofatfs/ff.h"
-#include "lib/oofatfs/diskio.h"
-#include "extmod/misc.h"
-#include "extmod/vfs.h"
-#include "extmod/vfs_fat.h"
-#include "extmod/vfs_lfs.h"
-#include "genhdr/mpversion.h"
#include "rng.h"
#include "usb.h"
#include "uart.h"
-#include "portmodules.h"
-/// \module os - basic "operating system" services
-///
-/// The `os` module contains functions for filesystem access and `urandom`.
-///
-/// The filesystem has `/` as the root directory, and the available physical
-/// drives are accessible from here. They are currently:
-///
-/// /flash -- the internal flash filesystem
-/// /sd -- the SD card (if it exists)
-///
-/// On boot up, the current directory is `/flash` if no SD card is inserted,
-/// otherwise it is `/sd`.
-
-STATIC const qstr os_uname_info_fields[] = {
- MP_QSTR_sysname, MP_QSTR_nodename,
- MP_QSTR_release, MP_QSTR_version, MP_QSTR_machine
-};
-STATIC const MP_DEFINE_STR_OBJ(os_uname_info_sysname_obj, "pyboard");
-STATIC const MP_DEFINE_STR_OBJ(os_uname_info_nodename_obj, "pyboard");
-STATIC const MP_DEFINE_STR_OBJ(os_uname_info_release_obj, MICROPY_VERSION_STRING);
-STATIC const MP_DEFINE_STR_OBJ(os_uname_info_version_obj, MICROPY_GIT_TAG " on " MICROPY_BUILD_DATE);
-STATIC const MP_DEFINE_STR_OBJ(os_uname_info_machine_obj, MICROPY_HW_BOARD_NAME " with " MICROPY_HW_MCU_NAME);
-STATIC MP_DEFINE_ATTRTUPLE(
- os_uname_info_obj,
- os_uname_info_fields,
- 5,
- MP_ROM_PTR(&os_uname_info_sysname_obj),
- MP_ROM_PTR(&os_uname_info_nodename_obj),
- MP_ROM_PTR(&os_uname_info_release_obj),
- MP_ROM_PTR(&os_uname_info_version_obj),
- MP_ROM_PTR(&os_uname_info_machine_obj)
- );
-
-STATIC mp_obj_t os_uname(void) {
- return MP_OBJ_FROM_PTR(&os_uname_info_obj);
-}
-STATIC MP_DEFINE_CONST_FUN_OBJ_0(os_uname_obj, os_uname);
+#if MICROPY_VFS_FAT
+#include "lib/oofatfs/ff.h"
+#include "lib/oofatfs/diskio.h"
+#endif
-/// \function sync()
-/// Sync all filesystems.
-STATIC mp_obj_t os_sync(void) {
+// sync()
+// Sync all filesystems.
+STATIC mp_obj_t mp_uos_sync(void) {
#if MICROPY_VFS_FAT
for (mp_vfs_mount_t *vfs = MP_STATE_VM(vfs_mount_table); vfs != NULL; vfs = vfs->next) {
// this assumes that vfs->obj is fs_user_mount_t with block device functions
@@ -92,13 +45,13 @@ STATIC mp_obj_t os_sync(void) {
#endif
return mp_const_none;
}
-MP_DEFINE_CONST_FUN_OBJ_0(mod_os_sync_obj, os_sync);
+MP_DEFINE_CONST_FUN_OBJ_0(mp_uos_sync_obj, mp_uos_sync);
-#if MICROPY_HW_ENABLE_RNG
-/// \function urandom(n)
-/// Return a bytes object with n random bytes, generated by the hardware
-/// random number generator.
-STATIC mp_obj_t os_urandom(mp_obj_t num) {
+#if MICROPY_PY_UOS_URANDOM
+// urandom(n)
+// Return a bytes object with n random bytes, generated by the hardware
+// random number generator.
+STATIC mp_obj_t mp_uos_urandom(mp_obj_t num) {
mp_int_t n = mp_obj_get_int(num);
vstr_t vstr;
vstr_init_len(&vstr, n);
@@ -107,7 +60,7 @@ STATIC mp_obj_t os_urandom(mp_obj_t num) {
}
return mp_obj_new_str_from_vstr(&mp_type_bytes, &vstr);
}
-STATIC MP_DEFINE_CONST_FUN_OBJ_1(os_urandom_obj, os_urandom);
+STATIC MP_DEFINE_CONST_FUN_OBJ_1(mp_uos_urandom_obj, mp_uos_urandom);
#endif
bool mp_uos_dupterm_is_builtin_stream(mp_const_obj_t stream) {
@@ -119,73 +72,22 @@ bool mp_uos_dupterm_is_builtin_stream(mp_const_obj_t stream) {
;
}
-STATIC mp_obj_t uos_dupterm(size_t n_args, const mp_obj_t *args) {
- mp_obj_t prev_obj = mp_uos_dupterm_obj.fun.var(n_args, args);
- if (mp_obj_get_type(prev_obj) == &pyb_uart_type) {
- uart_attach_to_repl(MP_OBJ_TO_PTR(prev_obj), false);
+void mp_uos_dupterm_stream_detached_attached(mp_obj_t stream_detached, mp_obj_t stream_attached) {
+ if (mp_obj_get_type(stream_detached) == &pyb_uart_type) {
+ uart_attach_to_repl(MP_OBJ_TO_PTR(stream_detached), false);
}
#if MICROPY_HW_ENABLE_USB
- if (mp_obj_get_type(prev_obj) == &pyb_usb_vcp_type) {
- usb_vcp_attach_to_repl(MP_OBJ_TO_PTR(prev_obj), false);
+ if (mp_obj_get_type(stream_detached) == &pyb_usb_vcp_type) {
+ usb_vcp_attach_to_repl(MP_OBJ_TO_PTR(stream_detached), false);
}
#endif
- if (mp_obj_get_type(args[0]) == &pyb_uart_type) {
- uart_attach_to_repl(MP_OBJ_TO_PTR(args[0]), true);
+ if (mp_obj_get_type(stream_attached) == &pyb_uart_type) {
+ uart_attach_to_repl(MP_OBJ_TO_PTR(stream_attached), true);
}
#if MICROPY_HW_ENABLE_USB
- if (mp_obj_get_type(args[0]) == &pyb_usb_vcp_type) {
- usb_vcp_attach_to_repl(MP_OBJ_TO_PTR(args[0]), true);
+ if (mp_obj_get_type(stream_attached) == &pyb_usb_vcp_type) {
+ usb_vcp_attach_to_repl(MP_OBJ_TO_PTR(stream_attached), true);
}
#endif
- return prev_obj;
}
-MP_DEFINE_CONST_FUN_OBJ_VAR_BETWEEN(uos_dupterm_obj, 1, 2, uos_dupterm);
-
-STATIC const mp_rom_map_elem_t os_module_globals_table[] = {
- { MP_ROM_QSTR(MP_QSTR___name__), MP_ROM_QSTR(MP_QSTR_uos) },
-
- { MP_ROM_QSTR(MP_QSTR_uname), MP_ROM_PTR(&os_uname_obj) },
-
- { MP_ROM_QSTR(MP_QSTR_chdir), MP_ROM_PTR(&mp_vfs_chdir_obj) },
- { MP_ROM_QSTR(MP_QSTR_getcwd), MP_ROM_PTR(&mp_vfs_getcwd_obj) },
- { MP_ROM_QSTR(MP_QSTR_ilistdir), MP_ROM_PTR(&mp_vfs_ilistdir_obj) },
- { MP_ROM_QSTR(MP_QSTR_listdir), MP_ROM_PTR(&mp_vfs_listdir_obj) },
- { MP_ROM_QSTR(MP_QSTR_mkdir), MP_ROM_PTR(&mp_vfs_mkdir_obj) },
- { MP_ROM_QSTR(MP_QSTR_remove), MP_ROM_PTR(&mp_vfs_remove_obj) },
- { MP_ROM_QSTR(MP_QSTR_rename),MP_ROM_PTR(&mp_vfs_rename_obj)},
- { MP_ROM_QSTR(MP_QSTR_rmdir), MP_ROM_PTR(&mp_vfs_rmdir_obj) },
- { MP_ROM_QSTR(MP_QSTR_stat), MP_ROM_PTR(&mp_vfs_stat_obj) },
- { MP_ROM_QSTR(MP_QSTR_statvfs), MP_ROM_PTR(&mp_vfs_statvfs_obj) },
- { MP_ROM_QSTR(MP_QSTR_unlink), MP_ROM_PTR(&mp_vfs_remove_obj) }, // unlink aliases to remove
-
- { MP_ROM_QSTR(MP_QSTR_sync), MP_ROM_PTR(&mod_os_sync_obj) },
-
- /// \constant sep - separation character used in paths
- { MP_ROM_QSTR(MP_QSTR_sep), MP_ROM_QSTR(MP_QSTR__slash_) },
-
- #if MICROPY_HW_ENABLE_RNG
- { MP_ROM_QSTR(MP_QSTR_urandom), MP_ROM_PTR(&os_urandom_obj) },
- #endif
-
- // these are MicroPython extensions
- { MP_ROM_QSTR(MP_QSTR_dupterm), MP_ROM_PTR(&uos_dupterm_obj) },
- { MP_ROM_QSTR(MP_QSTR_mount), MP_ROM_PTR(&mp_vfs_mount_obj) },
- { MP_ROM_QSTR(MP_QSTR_umount), MP_ROM_PTR(&mp_vfs_umount_obj) },
- #if MICROPY_VFS_FAT
- { MP_ROM_QSTR(MP_QSTR_VfsFat), MP_ROM_PTR(&mp_fat_vfs_type) },
- #endif
- #if MICROPY_VFS_LFS1
- { MP_ROM_QSTR(MP_QSTR_VfsLfs1), MP_ROM_PTR(&mp_type_vfs_lfs1) },
- #endif
- #if MICROPY_VFS_LFS2
- { MP_ROM_QSTR(MP_QSTR_VfsLfs2), MP_ROM_PTR(&mp_type_vfs_lfs2) },
- #endif
-};
-
-STATIC MP_DEFINE_CONST_DICT(os_module_globals, os_module_globals_table);
-
-const mp_obj_module_t mp_module_uos = {
- .base = { &mp_type_module },
- .globals = (mp_obj_dict_t *)&os_module_globals,
-};
diff --git a/ports/stm32/mpconfigport.h b/ports/stm32/mpconfigport.h
index 98e5f2f36..60f6d45fc 100644
--- a/ports/stm32/mpconfigport.h
+++ b/ports/stm32/mpconfigport.h
@@ -95,12 +95,14 @@
#define MICROPY_PY_UHASHLIB_MD5 (MICROPY_PY_USSL)
#define MICROPY_PY_UHASHLIB_SHA1 (MICROPY_PY_USSL)
#define MICROPY_PY_UCRYPTOLIB (MICROPY_PY_USSL)
-#define MICROPY_PY_UOS (0)
-#ifndef MICROPY_PY_UOS_STM32
-#define MICROPY_PY_UOS_STM32 (1)
-#endif
+#define MICROPY_PY_UOS_INCLUDEFILE "ports/stm32/moduos.c"
#define MICROPY_PY_OS_DUPTERM (3)
#define MICROPY_PY_UOS_DUPTERM_BUILTIN_STREAM (1)
+#define MICROPY_PY_UOS_DUPTERM_STREAM_DETACHED_ATTACHED (1)
+#define MICROPY_PY_UOS_SEP (1)
+#define MICROPY_PY_UOS_SYNC (1)
+#define MICROPY_PY_UOS_UNAME (1)
+#define MICROPY_PY_UOS_URANDOM (MICROPY_HW_ENABLE_RNG)
#define MICROPY_PY_URANDOM_SEED_INIT_FUNC (rng_get())
#ifndef MICROPY_PY_UTIME
#define MICROPY_PY_UTIME (1)
@@ -178,7 +180,6 @@ extern const struct _mp_obj_module_t mp_module_uzlib;
extern const struct _mp_obj_module_t mp_module_ujson;
extern const struct _mp_obj_module_t mp_module_uheapq;
extern const struct _mp_obj_module_t mp_module_uhashlib;
-extern const struct _mp_obj_module_t mp_module_uos;
extern const struct _mp_obj_module_t mp_module_utime;
extern const struct _mp_obj_module_t mp_module_usocket;
extern const struct _mp_obj_module_t mp_module_network;
@@ -204,12 +205,6 @@ extern const struct _mp_obj_module_t mp_module_onewire;
#define MACHINE_BUILTIN_MODULE_CONSTANTS
#endif
-#if MICROPY_PY_UOS_STM32
-#define UOS_BUILTIN_MODULE { MP_ROM_QSTR(MP_QSTR_uos), MP_ROM_PTR(&mp_module_uos) },
-#else
-#define UOS_BUILTIN_MODULE
-#endif
-
#if MICROPY_PY_UTIME
#define UTIME_BUILTIN_MODULE { MP_ROM_QSTR(MP_QSTR_utime), MP_ROM_PTR(&mp_module_utime) },
#else
@@ -274,7 +269,6 @@ extern const struct _mod_network_nic_type_t mod_network_nic_type_cc3k;
#define MICROPY_PORT_BUILTIN_MODULES \
PYB_BUILTIN_MODULE \
STM_BUILTIN_MODULE \
- UOS_BUILTIN_MODULE \
UTIME_BUILTIN_MODULE \
SOCKET_BUILTIN_MODULE \
NETWORK_BUILTIN_MODULE \
diff --git a/ports/stm32/portmodules.h b/ports/stm32/portmodules.h
index 81cb7fd04..f80b4fdf8 100644
--- a/ports/stm32/portmodules.h
+++ b/ports/stm32/portmodules.h
@@ -28,7 +28,6 @@
extern const mp_obj_module_t pyb_module;
extern const mp_obj_module_t stm_module;
-extern const mp_obj_module_t mp_module_uos;
extern const mp_obj_module_t mp_module_utime;
extern const mp_obj_module_t mp_module_usocket;
@@ -37,7 +36,6 @@ extern const mp_obj_module_t mp_module_usocket;
MP_DECLARE_CONST_FUN_OBJ_1(time_sleep_ms_obj);
MP_DECLARE_CONST_FUN_OBJ_1(time_sleep_us_obj);
-MP_DECLARE_CONST_FUN_OBJ_0(mod_os_sync_obj);
-MP_DECLARE_CONST_FUN_OBJ_VAR_BETWEEN(mod_os_dupterm_obj);
+MP_DECLARE_CONST_FUN_OBJ_0(mp_uos_sync_obj);
#endif // MICROPY_INCLUDED_STM32_PORTMODULES_H