modmicropython.c 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  1. /*
  2. * This file is part of the MicroPython project, http://micropython.org/
  3. *
  4. * The MIT License (MIT)
  5. *
  6. * Copyright (c) 2013, 2014 Damien P. George
  7. *
  8. * Permission is hereby granted, free of charge, to any person obtaining a copy
  9. * of this software and associated documentation files (the "Software"), to deal
  10. * in the Software without restriction, including without limitation the rights
  11. * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  12. * copies of the Software, and to permit persons to whom the Software is
  13. * furnished to do so, subject to the following conditions:
  14. *
  15. * The above copyright notice and this permission notice shall be included in
  16. * all copies or substantial portions of the Software.
  17. *
  18. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  19. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  20. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  21. * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  22. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  23. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  24. * THE SOFTWARE.
  25. */
  26. #include <stdio.h>
  27. #include "py/builtin.h"
  28. #include "py/stackctrl.h"
  29. #include "py/runtime.h"
  30. #include "py/gc.h"
  31. #include "py/mphal.h"
  32. #if MICROPY_PY_MICROPYTHON
  33. // Various builtins specific to MicroPython runtime,
  34. // living in micropython module
  35. #if MICROPY_ENABLE_COMPILER
  36. static mp_obj_t mp_micropython_opt_level(size_t n_args, const mp_obj_t *args) {
  37. if (n_args == 0) {
  38. return MP_OBJ_NEW_SMALL_INT(MP_STATE_VM(mp_optimise_value));
  39. } else {
  40. MP_STATE_VM(mp_optimise_value) = mp_obj_get_int(args[0]);
  41. return mp_const_none;
  42. }
  43. }
  44. static MP_DEFINE_CONST_FUN_OBJ_VAR_BETWEEN(mp_micropython_opt_level_obj, 0, 1, mp_micropython_opt_level);
  45. #endif
  46. #if MICROPY_PY_MICROPYTHON_MEM_INFO
  47. #if MICROPY_MEM_STATS
  48. static mp_obj_t mp_micropython_mem_total(void) {
  49. return MP_OBJ_NEW_SMALL_INT(m_get_total_bytes_allocated());
  50. }
  51. static MP_DEFINE_CONST_FUN_OBJ_0(mp_micropython_mem_total_obj, mp_micropython_mem_total);
  52. static mp_obj_t mp_micropython_mem_current(void) {
  53. return MP_OBJ_NEW_SMALL_INT(m_get_current_bytes_allocated());
  54. }
  55. static MP_DEFINE_CONST_FUN_OBJ_0(mp_micropython_mem_current_obj, mp_micropython_mem_current);
  56. static mp_obj_t mp_micropython_mem_peak(void) {
  57. return MP_OBJ_NEW_SMALL_INT(m_get_peak_bytes_allocated());
  58. }
  59. static MP_DEFINE_CONST_FUN_OBJ_0(mp_micropython_mem_peak_obj, mp_micropython_mem_peak);
  60. #endif
  61. mp_obj_t mp_micropython_mem_info(size_t n_args, const mp_obj_t *args) {
  62. (void)args;
  63. #if MICROPY_MEM_STATS
  64. mp_printf(&mp_plat_print, "mem: total=" UINT_FMT ", current=" UINT_FMT ", peak=" UINT_FMT "\n",
  65. (mp_uint_t)m_get_total_bytes_allocated(), (mp_uint_t)m_get_current_bytes_allocated(), (mp_uint_t)m_get_peak_bytes_allocated());
  66. #endif
  67. #if MICROPY_STACK_CHECK
  68. mp_printf(&mp_plat_print, "stack: " UINT_FMT " out of " UINT_FMT "\n",
  69. mp_stack_usage(), (mp_uint_t)MP_STATE_THREAD(stack_limit));
  70. #else
  71. mp_printf(&mp_plat_print, "stack: " UINT_FMT "\n", mp_stack_usage());
  72. #endif
  73. #if MICROPY_ENABLE_GC
  74. gc_dump_info(&mp_plat_print);
  75. if (n_args == 1) {
  76. // arg given means dump gc allocation table
  77. gc_dump_alloc_table(&mp_plat_print);
  78. }
  79. #else
  80. (void)n_args;
  81. #endif
  82. return mp_const_none;
  83. }
  84. static MP_DEFINE_CONST_FUN_OBJ_VAR_BETWEEN(mp_micropython_mem_info_obj, 0, 1, mp_micropython_mem_info);
  85. static mp_obj_t mp_micropython_qstr_info(size_t n_args, const mp_obj_t *args) {
  86. (void)args;
  87. size_t n_pool, n_qstr, n_str_data_bytes, n_total_bytes;
  88. qstr_pool_info(&n_pool, &n_qstr, &n_str_data_bytes, &n_total_bytes);
  89. mp_printf(&mp_plat_print, "qstr pool: n_pool=%u, n_qstr=%u, n_str_data_bytes=%u, n_total_bytes=%u\n",
  90. n_pool, n_qstr, n_str_data_bytes, n_total_bytes);
  91. if (n_args == 1) {
  92. // arg given means dump qstr data
  93. qstr_dump_data();
  94. }
  95. return mp_const_none;
  96. }
  97. static MP_DEFINE_CONST_FUN_OBJ_VAR_BETWEEN(mp_micropython_qstr_info_obj, 0, 1, mp_micropython_qstr_info);
  98. #endif // MICROPY_PY_MICROPYTHON_MEM_INFO
  99. #if MICROPY_PY_MICROPYTHON_STACK_USE
  100. static mp_obj_t mp_micropython_stack_use(void) {
  101. return MP_OBJ_NEW_SMALL_INT(mp_stack_usage());
  102. }
  103. static MP_DEFINE_CONST_FUN_OBJ_0(mp_micropython_stack_use_obj, mp_micropython_stack_use);
  104. #endif
  105. #if MICROPY_ENABLE_PYSTACK
  106. static mp_obj_t mp_micropython_pystack_use(void) {
  107. return MP_OBJ_NEW_SMALL_INT(mp_pystack_usage());
  108. }
  109. static MP_DEFINE_CONST_FUN_OBJ_0(mp_micropython_pystack_use_obj, mp_micropython_pystack_use);
  110. #endif
  111. #if MICROPY_ENABLE_GC
  112. static mp_obj_t mp_micropython_heap_lock(void) {
  113. gc_lock();
  114. return mp_const_none;
  115. }
  116. static MP_DEFINE_CONST_FUN_OBJ_0(mp_micropython_heap_lock_obj, mp_micropython_heap_lock);
  117. static mp_obj_t mp_micropython_heap_unlock(void) {
  118. gc_unlock();
  119. return MP_OBJ_NEW_SMALL_INT(MP_STATE_THREAD(gc_lock_depth));
  120. }
  121. static MP_DEFINE_CONST_FUN_OBJ_0(mp_micropython_heap_unlock_obj, mp_micropython_heap_unlock);
  122. #if MICROPY_PY_MICROPYTHON_HEAP_LOCKED
  123. static mp_obj_t mp_micropython_heap_locked(void) {
  124. return MP_OBJ_NEW_SMALL_INT(MP_STATE_THREAD(gc_lock_depth));
  125. }
  126. static MP_DEFINE_CONST_FUN_OBJ_0(mp_micropython_heap_locked_obj, mp_micropython_heap_locked);
  127. #endif
  128. #endif
  129. #if MICROPY_ENABLE_EMERGENCY_EXCEPTION_BUF && (MICROPY_EMERGENCY_EXCEPTION_BUF_SIZE == 0)
  130. static MP_DEFINE_CONST_FUN_OBJ_1(mp_alloc_emergency_exception_buf_obj, mp_alloc_emergency_exception_buf);
  131. #endif
  132. #if MICROPY_KBD_EXCEPTION
  133. static mp_obj_t mp_micropython_kbd_intr(mp_obj_t int_chr_in) {
  134. mp_hal_set_interrupt_char(mp_obj_get_int(int_chr_in));
  135. return mp_const_none;
  136. }
  137. static MP_DEFINE_CONST_FUN_OBJ_1(mp_micropython_kbd_intr_obj, mp_micropython_kbd_intr);
  138. #endif
  139. #if MICROPY_ENABLE_SCHEDULER
  140. static mp_obj_t mp_micropython_schedule(mp_obj_t function, mp_obj_t arg) {
  141. if (!mp_sched_schedule(function, arg)) {
  142. mp_raise_msg(&mp_type_RuntimeError, MP_ERROR_TEXT("schedule queue full"));
  143. }
  144. return mp_const_none;
  145. }
  146. static MP_DEFINE_CONST_FUN_OBJ_2(mp_micropython_schedule_obj, mp_micropython_schedule);
  147. #endif
  148. static const mp_rom_map_elem_t mp_module_micropython_globals_table[] = {
  149. { MP_ROM_QSTR(MP_QSTR___name__), MP_ROM_QSTR(MP_QSTR_micropython) },
  150. { MP_ROM_QSTR(MP_QSTR_const), MP_ROM_PTR(&mp_identity_obj) },
  151. #if MICROPY_ENABLE_COMPILER
  152. { MP_ROM_QSTR(MP_QSTR_opt_level), MP_ROM_PTR(&mp_micropython_opt_level_obj) },
  153. #endif
  154. #if MICROPY_PY_MICROPYTHON_MEM_INFO
  155. #if MICROPY_MEM_STATS
  156. { MP_ROM_QSTR(MP_QSTR_mem_total), MP_ROM_PTR(&mp_micropython_mem_total_obj) },
  157. { MP_ROM_QSTR(MP_QSTR_mem_current), MP_ROM_PTR(&mp_micropython_mem_current_obj) },
  158. { MP_ROM_QSTR(MP_QSTR_mem_peak), MP_ROM_PTR(&mp_micropython_mem_peak_obj) },
  159. #endif
  160. { MP_ROM_QSTR(MP_QSTR_mem_info), MP_ROM_PTR(&mp_micropython_mem_info_obj) },
  161. { MP_ROM_QSTR(MP_QSTR_qstr_info), MP_ROM_PTR(&mp_micropython_qstr_info_obj) },
  162. #endif
  163. #if MICROPY_PY_MICROPYTHON_STACK_USE
  164. { MP_ROM_QSTR(MP_QSTR_stack_use), MP_ROM_PTR(&mp_micropython_stack_use_obj) },
  165. #endif
  166. #if MICROPY_ENABLE_EMERGENCY_EXCEPTION_BUF && (MICROPY_EMERGENCY_EXCEPTION_BUF_SIZE == 0)
  167. { MP_ROM_QSTR(MP_QSTR_alloc_emergency_exception_buf), MP_ROM_PTR(&mp_alloc_emergency_exception_buf_obj) },
  168. #endif
  169. #if MICROPY_ENABLE_PYSTACK
  170. { MP_ROM_QSTR(MP_QSTR_pystack_use), MP_ROM_PTR(&mp_micropython_pystack_use_obj) },
  171. #endif
  172. #if MICROPY_ENABLE_GC
  173. { MP_ROM_QSTR(MP_QSTR_heap_lock), MP_ROM_PTR(&mp_micropython_heap_lock_obj) },
  174. { MP_ROM_QSTR(MP_QSTR_heap_unlock), MP_ROM_PTR(&mp_micropython_heap_unlock_obj) },
  175. #if MICROPY_PY_MICROPYTHON_HEAP_LOCKED
  176. { MP_ROM_QSTR(MP_QSTR_heap_locked), MP_ROM_PTR(&mp_micropython_heap_locked_obj) },
  177. #endif
  178. #endif
  179. #if MICROPY_KBD_EXCEPTION
  180. { MP_ROM_QSTR(MP_QSTR_kbd_intr), MP_ROM_PTR(&mp_micropython_kbd_intr_obj) },
  181. #endif
  182. #if MICROPY_ENABLE_SCHEDULER
  183. { MP_ROM_QSTR(MP_QSTR_schedule), MP_ROM_PTR(&mp_micropython_schedule_obj) },
  184. #endif
  185. };
  186. static MP_DEFINE_CONST_DICT(mp_module_micropython_globals, mp_module_micropython_globals_table);
  187. const mp_obj_module_t mp_module_micropython = {
  188. .base = { &mp_type_module },
  189. .globals = (mp_obj_dict_t *)&mp_module_micropython_globals,
  190. };
  191. MP_REGISTER_MODULE(MP_QSTR_micropython, mp_module_micropython);
  192. #endif // MICROPY_PY_MICROPYTHON