2014-03-13 01:06:26 +00:00
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
// options to control how Micro Python is built
|
|
|
|
|
|
|
|
#define MICROPY_EMIT_THUMB (1)
|
|
|
|
#define MICROPY_EMIT_INLINE_THUMB (1)
|
|
|
|
#define MICROPY_ENABLE_GC (1)
|
2014-04-05 20:35:48 +01:00
|
|
|
#define MICROPY_ENABLE_FINALISER (1)
|
2014-03-13 01:06:26 +00:00
|
|
|
#define MICROPY_ENABLE_REPL_HELPERS (1)
|
2014-04-13 14:51:56 +01:00
|
|
|
#define MICROPY_ENABLE_SOURCE_LINE (1)
|
2014-03-13 01:06:26 +00:00
|
|
|
#define MICROPY_LONGINT_IMPL (MICROPY_LONGINT_IMPL_MPZ)
|
|
|
|
#define MICROPY_FLOAT_IMPL (MICROPY_FLOAT_IMPL_FLOAT)
|
|
|
|
#define MICROPY_PATH_MAX (128)
|
2014-04-17 23:24:13 +01:00
|
|
|
#define MICROPY_USE_COMPUTED_GOTO (1)
|
2014-03-13 01:06:26 +00:00
|
|
|
/* Enable FatFS LFNs
|
|
|
|
0: Disable LFN feature.
|
|
|
|
1: Enable LFN with static working buffer on the BSS. Always NOT reentrant.
|
|
|
|
2: Enable LFN with dynamic working buffer on the STACK.
|
|
|
|
3: Enable LFN with dynamic working buffer on the HEAP.
|
|
|
|
*/
|
2014-03-17 14:04:19 +00:00
|
|
|
#define MICROPY_ENABLE_LFN (1)
|
|
|
|
#define MICROPY_LFN_CODE_PAGE (437) /* 1=SFN/ANSI 437=LFN/U.S.(OEM) */
|
2014-04-13 19:00:56 +01:00
|
|
|
#define MICROPY_MOD_SYS_STDFILES (1)
|
2014-03-17 14:04:19 +00:00
|
|
|
|
|
|
|
// extra built in names to add to the global namespace
|
2014-03-24 11:27:56 +00:00
|
|
|
extern const struct _mp_obj_fun_native_t mp_builtin_help_obj;
|
2014-03-22 23:53:50 +00:00
|
|
|
extern const struct _mp_obj_fun_native_t mp_builtin_input_obj;
|
2014-03-17 14:04:19 +00:00
|
|
|
extern const struct _mp_obj_fun_native_t mp_builtin_open_obj;
|
|
|
|
#define MICROPY_EXTRA_BUILTINS \
|
2014-04-05 22:36:42 +01:00
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_help), (mp_obj_t)&mp_builtin_help_obj }, \
|
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_input), (mp_obj_t)&mp_builtin_input_obj }, \
|
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_open), (mp_obj_t)&mp_builtin_open_obj },
|
2014-03-13 01:06:26 +00:00
|
|
|
|
2014-03-25 14:18:18 +00:00
|
|
|
// extra built in modules to add to the list of known ones
|
|
|
|
extern const struct _mp_obj_module_t os_module;
|
|
|
|
extern const struct _mp_obj_module_t pyb_module;
|
stmhal: Add stm module, which contains some constants for the MCU.
Also contains raw memory read/write functions, read8, read16, read32,
write8, write16, write32. Can now do:
stm.write16(stm.GPIOA + stm.GPIO_BSRRL, 1 << 13)
This turns on the red LED.
With the new constant folding, the above constants for the GPIO address
are actually compiled to constants (and the addition done) at compile
time. For viper code and inline assembler, this optimisation will make
a big difference. In the inline assembler, using these constants would
not be possible without this constant folding.
2014-04-10 22:46:40 +01:00
|
|
|
extern const struct _mp_obj_module_t stm_module;
|
2014-03-25 14:18:18 +00:00
|
|
|
extern const struct _mp_obj_module_t time_module;
|
|
|
|
#define MICROPY_EXTRA_BUILTIN_MODULES \
|
2014-04-05 22:36:42 +01:00
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_os), (mp_obj_t)&os_module }, \
|
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_pyb), (mp_obj_t)&pyb_module }, \
|
stmhal: Add stm module, which contains some constants for the MCU.
Also contains raw memory read/write functions, read8, read16, read32,
write8, write16, write32. Can now do:
stm.write16(stm.GPIOA + stm.GPIO_BSRRL, 1 << 13)
This turns on the red LED.
With the new constant folding, the above constants for the GPIO address
are actually compiled to constants (and the addition done) at compile
time. For viper code and inline assembler, this optimisation will make
a big difference. In the inline assembler, using these constants would
not be possible without this constant folding.
2014-04-10 22:46:40 +01:00
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_stm), (mp_obj_t)&stm_module }, \
|
2014-04-05 22:36:42 +01:00
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_time), (mp_obj_t)&time_module }, \
|
2014-03-25 14:18:18 +00:00
|
|
|
|
stmhal: Add stm module, which contains some constants for the MCU.
Also contains raw memory read/write functions, read8, read16, read32,
write8, write16, write32. Can now do:
stm.write16(stm.GPIOA + stm.GPIO_BSRRL, 1 << 13)
This turns on the red LED.
With the new constant folding, the above constants for the GPIO address
are actually compiled to constants (and the addition done) at compile
time. For viper code and inline assembler, this optimisation will make
a big difference. In the inline assembler, using these constants would
not be possible without this constant folding.
2014-04-10 22:46:40 +01:00
|
|
|
// extra constants
|
|
|
|
#define MICROPY_EXTRA_CONSTANTS \
|
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_pyb), (mp_obj_t)&pyb_module }, \
|
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_stm), (mp_obj_t)&stm_module }, \
|
|
|
|
|
2014-03-13 01:06:26 +00:00
|
|
|
// type definitions for the specific machine
|
|
|
|
|
|
|
|
#define BYTES_PER_WORD (4)
|
|
|
|
|
|
|
|
#define UINT_FMT "%lu"
|
|
|
|
#define INT_FMT "%ld"
|
|
|
|
|
|
|
|
typedef int32_t machine_int_t; // must be pointer size
|
|
|
|
typedef uint32_t machine_uint_t; // must be pointer size
|
|
|
|
typedef void *machine_ptr_t; // must be of pointer size
|
|
|
|
typedef const void *machine_const_ptr_t; // must be of pointer size
|
|
|
|
|
|
|
|
// There is no classical C heap in bare-metal ports, only Python
|
|
|
|
// garbage-collected heap. For completeness, emulate C heap via
|
|
|
|
// GC heap. Note that MicroPython core never uses malloc() and friends,
|
|
|
|
// so these defines are mostly to help extension module writers.
|
|
|
|
#define malloc gc_alloc
|
|
|
|
#define free gc_free
|
|
|
|
#define realloc gc_realloc
|
|
|
|
|
2014-03-14 07:51:26 +00:00
|
|
|
#define USE_DEVICE_MODE
|
|
|
|
//#define USE_HOST_MODE
|
2014-03-13 01:06:26 +00:00
|
|
|
|
2014-03-14 07:51:26 +00:00
|
|
|
// board specific definitions
|
2014-03-13 01:06:26 +00:00
|
|
|
#include "mpconfigboard.h"
|