blob: 54cf0f3d3d691580c528e49ad0d0fd8d05bdafb8 [file] [log] [blame]
Damien George04b91472014-05-03 23:27:38 +01001/*
2 * This file is part of the Micro Python 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 */
Damien George9ddbe292014-12-29 01:02:19 +000026#ifndef __MICROPY_INCLUDED_PY_MPCONFIG_H__
27#define __MICROPY_INCLUDED_PY_MPCONFIG_H__
Damien George04b91472014-05-03 23:27:38 +010028
Paul Sokolovskyb372bfc2014-01-03 17:15:53 +020029// This file contains default configuration settings for MicroPython.
Paul Sokolovskyb1422de2014-10-29 04:08:49 +020030// You can override any of the options below using mpconfigport.h file
31// located in a directory of your port.
Paul Sokolovskyb372bfc2014-01-03 17:15:53 +020032
Paul Sokolovskyb1422de2014-10-29 04:08:49 +020033// mpconfigport.h is a file containing configuration settings for a
34// particular port. mpconfigport.h is actually a default name for
35// such config, and it can be overriden using MP_CONFIGFILE preprocessor
36// define (you can do that by passing CFLAGS_EXTRA='-DMP_CONFIGFILE="<file.h>"'
37// argument to make when using standard MicroPython makefiles).
38// This is useful to have more than one config per port, for example,
39// release vs debug configs, etc. Note that if you switch from one config
40// to another, you must rebuild from scratch using "-B" switch to make.
41
42#ifdef MP_CONFIGFILE
43#include MP_CONFIGFILE
44#else
Damien George8340c482014-06-12 19:50:17 +010045#include <mpconfigport.h>
Paul Sokolovskyb1422de2014-10-29 04:08:49 +020046#endif
Paul Sokolovskyb372bfc2014-01-03 17:15:53 +020047
Damien George136f6752014-01-07 14:54:15 +000048// Any options not explicitly set in mpconfigport.h will get default
49// values below.
50
51/*****************************************************************************/
Damien George567184e2015-03-29 14:05:46 +010052/* Object representation */
53
54// A Micro Python object is a machine word having the following form:
55// - xxxx...xxx1 : a small int, bits 1 and above are the value
56// - xxxx...xx10 : a qstr, bits 2 and above are the value
57// - xxxx...xx00 : a pointer to an mp_obj_base_t (unless a fake object)
58#define MICROPY_OBJ_REPR_A (0)
59
60// A Micro Python object is a machine word having the following form:
61// - xxxx...xx01 : a small int, bits 2 and above are the value
62// - xxxx...xx11 : a qstr, bits 2 and above are the value
63// - xxxx...xxx0 : a pointer to an mp_obj_base_t (unless a fake object)
64#define MICROPY_OBJ_REPR_B (1)
65
Damien George8b8d1892015-11-06 23:25:10 +000066// A MicroPython object is a machine word having the following form (called R):
Damien George183edef2015-10-17 23:20:57 +010067// - iiiiiiii iiiiiiii iiiiiiii iiiiiii1 small int with 31-bit signed value
Damien George8b8d1892015-11-06 23:25:10 +000068// - 01111111 1qqqqqqq qqqqqqqq qqqqq110 str with 20-bit qstr value
Damien George183edef2015-10-17 23:20:57 +010069// - s1111111 10000000 00000000 00000010 +/- inf
70// - s1111111 1xxxxxxx xxxxxxxx xxxxx010 nan, x != 0
71// - seeeeeee efffffff ffffffff ffffff10 30-bit fp, e != 0xff
72// - pppppppp pppppppp pppppppp pppppp00 ptr (4 byte alignment)
Damien George8b8d1892015-11-06 23:25:10 +000073// Str and float stored as O = R + 0x80800000, retrieved as R = O - 0x80800000.
74// This makes strs easier to encode/decode as they have zeros in the top 9 bits.
Damien George183edef2015-10-17 23:20:57 +010075// This scheme only works with 32-bit word size and float enabled.
Damien George8b8d1892015-11-06 23:25:10 +000076
Damien George183edef2015-10-17 23:20:57 +010077#define MICROPY_OBJ_REPR_C (2)
78
Damien Georgeb8cfb0d2015-11-27 17:09:11 +000079// A MicroPython object is a 64-bit word having the following form (called R):
80// - seeeeeee eeeeffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff 64-bit fp, e != 0x7ff
81// - s1111111 11110000 00000000 00000000 00000000 00000000 00000000 00000000 +/- inf
82// - 01111111 11111000 00000000 00000000 00000000 00000000 00000000 00000000 normalised nan
83// - 01111111 11111101 00000000 00000000 iiiiiiii iiiiiiii iiiiiiii iiiiiii1 small int
84// - 01111111 11111110 00000000 00000000 qqqqqqqq qqqqqqqq qqqqqqqq qqqqqqq1 str
85// - 01111111 11111100 00000000 00000000 pppppppp pppppppp pppppppp pppppp00 ptr (4 byte alignment)
86// Stored as O = R + 0x8004000000000000, retrieved as R = O - 0x8004000000000000.
87// This makes pointers have all zeros in the top 32 bits.
88// Small-ints and strs have 1 as LSB to make sure they don't look like pointers
89// to the garbage collector.
90#define MICROPY_OBJ_REPR_D (3)
91
Damien George567184e2015-03-29 14:05:46 +010092#ifndef MICROPY_OBJ_REPR
93#define MICROPY_OBJ_REPR (MICROPY_OBJ_REPR_A)
94#endif
95
96/*****************************************************************************/
Damien George66e18f02014-05-05 13:19:03 +010097/* Memory allocation policy */
98
Paul Sokolovsky75feece2015-12-03 01:40:52 +020099// Number of bytes in memory allocation/GC block. Any size allocated will be
100// rounded up to be multiples of this.
Paul Sokolovskyb4eccfd2015-12-03 01:57:50 +0200101#ifndef MICROPY_BYTES_PER_GC_BLOCK
Paul Sokolovsky75feece2015-12-03 01:40:52 +0200102#define MICROPY_BYTES_PER_GC_BLOCK (4 * BYTES_PER_WORD)
Paul Sokolovskyb4eccfd2015-12-03 01:57:50 +0200103#endif
Paul Sokolovsky75feece2015-12-03 01:40:52 +0200104
Damien Georgefd40a9c2015-01-01 22:04:46 +0000105// Number of words allocated (in BSS) to the GC stack (minimum is 1)
106#ifndef MICROPY_ALLOC_GC_STACK_SIZE
107#define MICROPY_ALLOC_GC_STACK_SIZE (64)
108#endif
109
Damien George5ffe1d82016-08-26 15:35:26 +1000110// Be conservative and always clear to zero newly (re)allocated memory in the GC.
111// This helps eliminate stray pointers that hold on to memory that's no longer
112// used. It decreases performance due to unnecessary memory clearing.
Colin Hogben828df542016-10-31 14:52:11 +0000113// A memory manager which always clears memory can set this to 0.
Damien George5ffe1d82016-08-26 15:35:26 +1000114// TODO Do analysis to understand why some memory is not properly cleared and
115// find a more efficient way to clear it.
116#ifndef MICROPY_GC_CONSERVATIVE_CLEAR
Colin Hogben828df542016-10-31 14:52:11 +0000117#define MICROPY_GC_CONSERVATIVE_CLEAR (MICROPY_ENABLE_GC)
Damien George5ffe1d82016-08-26 15:35:26 +1000118#endif
119
Paul Sokolovsky93e353e2016-07-21 00:37:30 +0300120// Support automatic GC when reaching allocation threshold,
121// configurable by gc.threshold().
122#ifndef MICROPY_GC_ALLOC_THRESHOLD
123#define MICROPY_GC_ALLOC_THRESHOLD (1)
124#endif
125
Damien Georgeade9a052015-06-13 21:53:22 +0100126// Number of bytes to allocate initially when creating new chunks to store
127// interned string data. Smaller numbers lead to more chunks being needed
128// and more wastage at the end of the chunk. Larger numbers lead to wasted
129// space at the end when no more strings need interning.
130#ifndef MICROPY_ALLOC_QSTR_CHUNK_INIT
131#define MICROPY_ALLOC_QSTR_CHUNK_INIT (128)
132#endif
133
Damien Georgee1199ec2014-05-10 17:48:01 +0100134// Initial amount for lexer indentation level
Damien George58ebde42014-05-21 20:32:59 +0100135#ifndef MICROPY_ALLOC_LEXER_INDENT_INIT
136#define MICROPY_ALLOC_LEXER_INDENT_INIT (10)
Damien Georgee1199ec2014-05-10 17:48:01 +0100137#endif
138
139// Increment for lexer indentation level
Damien George58ebde42014-05-21 20:32:59 +0100140#ifndef MICROPY_ALLOC_LEXEL_INDENT_INC
141#define MICROPY_ALLOC_LEXEL_INDENT_INC (8)
Damien Georgee1199ec2014-05-10 17:48:01 +0100142#endif
143
Damien George66e18f02014-05-05 13:19:03 +0100144// Initial amount for parse rule stack
Damien George58ebde42014-05-21 20:32:59 +0100145#ifndef MICROPY_ALLOC_PARSE_RULE_INIT
146#define MICROPY_ALLOC_PARSE_RULE_INIT (64)
Damien George66e18f02014-05-05 13:19:03 +0100147#endif
148
149// Increment for parse rule stack
Damien George58ebde42014-05-21 20:32:59 +0100150#ifndef MICROPY_ALLOC_PARSE_RULE_INC
151#define MICROPY_ALLOC_PARSE_RULE_INC (16)
Damien George66e18f02014-05-05 13:19:03 +0100152#endif
153
154// Initial amount for parse result stack
Damien George58ebde42014-05-21 20:32:59 +0100155#ifndef MICROPY_ALLOC_PARSE_RESULT_INIT
156#define MICROPY_ALLOC_PARSE_RESULT_INIT (32)
Damien George66e18f02014-05-05 13:19:03 +0100157#endif
158
159// Increment for parse result stack
Damien George58ebde42014-05-21 20:32:59 +0100160#ifndef MICROPY_ALLOC_PARSE_RESULT_INC
161#define MICROPY_ALLOC_PARSE_RESULT_INC (16)
Damien George66e18f02014-05-05 13:19:03 +0100162#endif
163
Damien George5042bce2014-05-25 22:06:06 +0100164// Strings this length or less will be interned by the parser
165#ifndef MICROPY_ALLOC_PARSE_INTERN_STRING_LEN
166#define MICROPY_ALLOC_PARSE_INTERN_STRING_LEN (10)
167#endif
168
Damien George58e0f4a2015-09-23 10:50:43 +0100169// Number of bytes to allocate initially when creating new chunks to store
170// parse nodes. Small leads to fragmentation, large leads to excess use.
171#ifndef MICROPY_ALLOC_PARSE_CHUNK_INIT
172#define MICROPY_ALLOC_PARSE_CHUNK_INIT (128)
173#endif
174
Damien George66e18f02014-05-05 13:19:03 +0100175// Initial amount for ids in a scope
Damien George58ebde42014-05-21 20:32:59 +0100176#ifndef MICROPY_ALLOC_SCOPE_ID_INIT
177#define MICROPY_ALLOC_SCOPE_ID_INIT (4)
Damien George66e18f02014-05-05 13:19:03 +0100178#endif
179
180// Increment for ids in a scope
Damien George58ebde42014-05-21 20:32:59 +0100181#ifndef MICROPY_ALLOC_SCOPE_ID_INC
182#define MICROPY_ALLOC_SCOPE_ID_INC (6)
183#endif
184
185// Maximum length of a path in the filesystem
186// So we can allocate a buffer on the stack for path manipulation in import
187#ifndef MICROPY_ALLOC_PATH_MAX
188#define MICROPY_ALLOC_PATH_MAX (512)
Damien George66e18f02014-05-05 13:19:03 +0100189#endif
190
Paul Sokolovsky346aacf2014-11-05 00:27:15 +0200191// Initial size of module dict
192#ifndef MICROPY_MODULE_DICT_SIZE
193#define MICROPY_MODULE_DICT_SIZE (1)
194#endif
195
Damien Georged8914522015-02-27 09:54:12 +0000196// Whether realloc/free should be passed allocated memory region size
197// You must enable this if MICROPY_MEM_STATS is enabled
198#ifndef MICROPY_MALLOC_USES_ALLOCATED_SIZE
199#define MICROPY_MALLOC_USES_ALLOCATED_SIZE (0)
200#endif
201
Damien George95836f82015-01-11 22:27:30 +0000202// Number of bytes used to store qstr length
203// Dictates hard limit on maximum Python identifier length, but 1 byte
204// (limit of 255 bytes in an identifier) should be enough for everyone
205#ifndef MICROPY_QSTR_BYTES_IN_LEN
206#define MICROPY_QSTR_BYTES_IN_LEN (1)
207#endif
208
Damien Georgec3bd9412015-07-20 11:03:13 +0000209// Number of bytes used to store qstr hash
210#ifndef MICROPY_QSTR_BYTES_IN_HASH
211#define MICROPY_QSTR_BYTES_IN_HASH (2)
212#endif
213
Paul Sokolovsky7f1c9812015-03-28 01:14:45 +0200214// Avoid using C stack when making Python function calls. C stack still
215// may be used if there's no free heap.
Paul Sokolovsky20397572015-03-28 01:14:44 +0200216#ifndef MICROPY_STACKLESS
217#define MICROPY_STACKLESS (0)
218#endif
219
Paul Sokolovsky7f1c9812015-03-28 01:14:45 +0200220// Never use C stack when making Python function calls. This may break
221// testsuite as will subtly change which exception is thrown in case
222// of too deep recursion and other similar cases.
223#ifndef MICROPY_STACKLESS_STRICT
224#define MICROPY_STACKLESS_STRICT (0)
225#endif
226
Paul Sokolovskyf32020e2015-11-25 23:22:31 +0200227// Don't use alloca calls. As alloca() is not part of ANSI C, this
228// workaround option is provided for compilers lacking this de-facto
229// standard function. The way it works is allocating from heap, and
230// relying on garbage collection to free it eventually. This is of
231// course much less optimal than real alloca().
232#if defined(MICROPY_NO_ALLOCA) && MICROPY_NO_ALLOCA
233#undef alloca
234#define alloca(x) m_malloc(x)
235#endif
236
Damien George66e18f02014-05-05 13:19:03 +0100237/*****************************************************************************/
Damien George136f6752014-01-07 14:54:15 +0000238/* Micro Python emitters */
239
Damien Georged8c834c2015-11-02 21:55:42 +0000240// Whether to support loading of persistent code
241#ifndef MICROPY_PERSISTENT_CODE_LOAD
242#define MICROPY_PERSISTENT_CODE_LOAD (0)
243#endif
244
245// Whether to support saving of persistent code
246#ifndef MICROPY_PERSISTENT_CODE_SAVE
247#define MICROPY_PERSISTENT_CODE_SAVE (0)
248#endif
249
Damien Georgec8e9c0d2015-11-02 17:27:18 +0000250// Whether generated code can persist independently of the VM/runtime instance
Damien Georged8c834c2015-11-02 21:55:42 +0000251// This is enabled automatically when needed by other features
Damien Georgec8e9c0d2015-11-02 17:27:18 +0000252#ifndef MICROPY_PERSISTENT_CODE
Damien George0a2e9652016-01-31 22:24:16 +0000253#define MICROPY_PERSISTENT_CODE (MICROPY_PERSISTENT_CODE_LOAD || MICROPY_PERSISTENT_CODE_SAVE || MICROPY_MODULE_FROZEN_MPY)
Damien Georgec8e9c0d2015-11-02 17:27:18 +0000254#endif
255
Damien George136f6752014-01-07 14:54:15 +0000256// Whether to emit x64 native code
257#ifndef MICROPY_EMIT_X64
258#define MICROPY_EMIT_X64 (0)
259#endif
260
Damien Georgec90f59e2014-09-06 23:06:36 +0100261// Whether to emit x86 native code
262#ifndef MICROPY_EMIT_X86
263#define MICROPY_EMIT_X86 (0)
264#endif
265
Damien George136f6752014-01-07 14:54:15 +0000266// Whether to emit thumb native code
267#ifndef MICROPY_EMIT_THUMB
268#define MICROPY_EMIT_THUMB (0)
269#endif
270
271// Whether to enable the thumb inline assembler
272#ifndef MICROPY_EMIT_INLINE_THUMB
273#define MICROPY_EMIT_INLINE_THUMB (0)
274#endif
275
Damien Georgee8135412015-10-16 22:08:57 +0100276// Whether to enable ARMv7-M instruction support in the Thumb2 inline assembler
277#ifndef MICROPY_EMIT_INLINE_THUMB_ARMV7M
278#define MICROPY_EMIT_INLINE_THUMB_ARMV7M (1)
279#endif
280
=50089722015-04-14 13:14:57 +0100281// Whether to enable float support in the Thumb2 inline assembler
282#ifndef MICROPY_EMIT_INLINE_THUMB_FLOAT
283#define MICROPY_EMIT_INLINE_THUMB_FLOAT (1)
284#endif
285
Fabian Vogtfe3d16e2014-08-16 22:55:53 +0200286// Whether to emit ARM native code
287#ifndef MICROPY_EMIT_ARM
288#define MICROPY_EMIT_ARM (0)
289#endif
290
Damien George8e5aced2016-12-09 16:39:39 +1100291// Whether to emit Xtensa native code
292#ifndef MICROPY_EMIT_XTENSA
293#define MICROPY_EMIT_XTENSA (0)
294#endif
295
Damien Georgef76b1bf2016-12-09 17:03:33 +1100296// Whether to enable the Xtensa inline assembler
297#ifndef MICROPY_EMIT_INLINE_XTENSA
298#define MICROPY_EMIT_INLINE_XTENSA (0)
299#endif
300
Damien George2ac4af62014-08-15 16:45:41 +0100301// Convenience definition for whether any native emitter is enabled
Damien George8e5aced2016-12-09 16:39:39 +1100302#define MICROPY_EMIT_NATIVE (MICROPY_EMIT_X64 || MICROPY_EMIT_X86 || MICROPY_EMIT_THUMB || MICROPY_EMIT_ARM || MICROPY_EMIT_XTENSA)
Damien George2ac4af62014-08-15 16:45:41 +0100303
Damien Georgead297a12016-12-09 13:17:49 +1100304// Convenience definition for whether any inline assembler emitter is enabled
Damien Georgef76b1bf2016-12-09 17:03:33 +1100305#define MICROPY_EMIT_INLINE_ASM (MICROPY_EMIT_INLINE_THUMB || MICROPY_EMIT_INLINE_XTENSA)
Damien Georgead297a12016-12-09 13:17:49 +1100306
Damien George136f6752014-01-07 14:54:15 +0000307/*****************************************************************************/
Damien George58ebde42014-05-21 20:32:59 +0100308/* Compiler configuration */
309
Damien Georgedd5353a2015-12-18 12:35:44 +0000310// Whether to include the compiler
311#ifndef MICROPY_ENABLE_COMPILER
312#define MICROPY_ENABLE_COMPILER (1)
313#endif
314
Damien Georgeea235202016-02-11 22:30:53 +0000315// Whether the compiler is dynamically configurable (ie at runtime)
316#ifndef MICROPY_DYNAMIC_COMPILER
317#define MICROPY_DYNAMIC_COMPILER (0)
318#endif
319
320// Configure dynamic compiler macros
321#if MICROPY_DYNAMIC_COMPILER
322#define MICROPY_OPT_CACHE_MAP_LOOKUP_IN_BYTECODE_DYNAMIC (mp_dynamic_compiler.opt_cache_map_lookup_in_bytecode)
323#define MICROPY_PY_BUILTINS_STR_UNICODE_DYNAMIC (mp_dynamic_compiler.py_builtins_str_unicode)
324#else
325#define MICROPY_OPT_CACHE_MAP_LOOKUP_IN_BYTECODE_DYNAMIC MICROPY_OPT_CACHE_MAP_LOOKUP_IN_BYTECODE
326#define MICROPY_PY_BUILTINS_STR_UNICODE_DYNAMIC MICROPY_PY_BUILTINS_STR_UNICODE
327#endif
328
Damien George64f2b212015-10-08 14:58:15 +0100329// Whether to enable constant folding; eg 1+2 rewritten as 3
330#ifndef MICROPY_COMP_CONST_FOLDING
331#define MICROPY_COMP_CONST_FOLDING (1)
332#endif
333
Damien Georgeddd1e182015-01-10 14:07:24 +0000334// Whether to enable lookup of constants in modules; eg module.CONST
335#ifndef MICROPY_COMP_MODULE_CONST
336#define MICROPY_COMP_MODULE_CONST (0)
337#endif
338
Damien George58ebde42014-05-21 20:32:59 +0100339// Whether to enable constant optimisation; id = const(value)
340#ifndef MICROPY_COMP_CONST
341#define MICROPY_COMP_CONST (1)
342#endif
343
Damien George42e0c592015-03-14 13:11:35 +0000344// Whether to enable optimisation of: a, b = c, d
345// Costs 124 bytes (Thumb2)
346#ifndef MICROPY_COMP_DOUBLE_TUPLE_ASSIGN
347#define MICROPY_COMP_DOUBLE_TUPLE_ASSIGN (1)
348#endif
349
350// Whether to enable optimisation of: a, b, c = d, e, f
351// Cost 156 bytes (Thumb2)
352#ifndef MICROPY_COMP_TRIPLE_TUPLE_ASSIGN
353#define MICROPY_COMP_TRIPLE_TUPLE_ASSIGN (0)
354#endif
355
Damien George58ebde42014-05-21 20:32:59 +0100356/*****************************************************************************/
Damien George136f6752014-01-07 14:54:15 +0000357/* Internal debugging stuff */
358
359// Whether to collect memory allocation stats
360#ifndef MICROPY_MEM_STATS
361#define MICROPY_MEM_STATS (0)
362#endif
363
Damien Georgecbd2f742014-01-19 11:48:48 +0000364// Whether to build functions that print debugging info:
Damien George3417bc22014-05-10 10:36:38 +0100365// mp_bytecode_print
Damien Georgecbd2f742014-01-19 11:48:48 +0000366// mp_parse_node_print
367#ifndef MICROPY_DEBUG_PRINTERS
368#define MICROPY_DEBUG_PRINTERS (0)
Damien Georged3ebe482014-01-07 15:20:33 +0000369#endif
370
Damien George136f6752014-01-07 14:54:15 +0000371/*****************************************************************************/
Damien Georgeee3fd462014-05-24 23:03:12 +0100372/* Optimisations */
373
374// Whether to use computed gotos in the VM, or a switch
375// Computed gotos are roughly 10% faster, and increase VM code size by a little
376#ifndef MICROPY_OPT_COMPUTED_GOTO
377#define MICROPY_OPT_COMPUTED_GOTO (0)
378#endif
379
Damien George7ee91cf2015-01-06 12:51:39 +0000380// Whether to cache result of map lookups in LOAD_NAME, LOAD_GLOBAL, LOAD_ATTR,
381// STORE_ATTR bytecodes. Uses 1 byte extra RAM for each of these opcodes and
382// uses a bit of extra code ROM, but greatly improves lookup speed.
383#ifndef MICROPY_OPT_CACHE_MAP_LOOKUP_IN_BYTECODE
384#define MICROPY_OPT_CACHE_MAP_LOOKUP_IN_BYTECODE (0)
385#endif
386
Doug Currie2e2e15c2016-01-30 22:35:58 -0500387// Whether to use fast versions of bitwise operations (and, or, xor) when the
388// arguments are both positive. Increases Thumb2 code size by about 250 bytes.
389#ifndef MICROPY_OPT_MPZ_BITWISE
390#define MICROPY_OPT_MPZ_BITWISE (0)
391#endif
392
Damien Georgeee3fd462014-05-24 23:03:12 +0100393/*****************************************************************************/
394/* Python internal features */
Damien George136f6752014-01-07 14:54:15 +0000395
Damien George6b239c22016-11-16 16:04:57 +1100396// Whether to use the POSIX reader for importing files
397#ifndef MICROPY_READER_POSIX
398#define MICROPY_READER_POSIX (0)
399#endif
400
Damien Georgedcb9ea72017-01-27 15:10:09 +1100401// Whether to use the VFS reader for importing files
402#ifndef MICROPY_READER_VFS
403#define MICROPY_READER_VFS (0)
404#endif
405
Damien George40d84302016-02-15 22:46:21 +0000406// Hook for the VM at the start of the opcode loop (can contain variable
407// definitions usable by the other hook functions)
408#ifndef MICROPY_VM_HOOK_INIT
409#define MICROPY_VM_HOOK_INIT
410#endif
411
412// Hook for the VM during the opcode loop (but only after jump opcodes)
413#ifndef MICROPY_VM_HOOK_LOOP
414#define MICROPY_VM_HOOK_LOOP
415#endif
416
417// Hook for the VM just before return opcode is finished being interpreted
418#ifndef MICROPY_VM_HOOK_RETURN
419#define MICROPY_VM_HOOK_RETURN
420#endif
421
Damien Georged3ebe482014-01-07 15:20:33 +0000422// Whether to include the garbage collector
423#ifndef MICROPY_ENABLE_GC
424#define MICROPY_ENABLE_GC (0)
425#endif
426
Damien George12bab722014-04-05 20:35:48 +0100427// Whether to enable finalisers in the garbage collector (ie call __del__)
Damien George7860c2a2014-11-05 21:16:41 +0000428#ifndef MICROPY_ENABLE_FINALISER
429#define MICROPY_ENABLE_FINALISER (0)
Damien George12bab722014-04-05 20:35:48 +0100430#endif
431
Paul Sokolovsky23668692014-06-25 03:03:34 +0300432// Whether to check C stack usage. C stack used for calling Python functions,
433// etc. Not checking means segfault on overflow.
434#ifndef MICROPY_STACK_CHECK
Damien George4a5895c2015-01-09 00:10:55 +0000435#define MICROPY_STACK_CHECK (0)
Paul Sokolovsky23668692014-06-25 03:03:34 +0300436#endif
437
Dave Hylands5b7fd202014-07-01 23:46:53 -0700438// Whether to have an emergency exception buffer
439#ifndef MICROPY_ENABLE_EMERGENCY_EXCEPTION_BUF
440#define MICROPY_ENABLE_EMERGENCY_EXCEPTION_BUF (0)
441#endif
442#if MICROPY_ENABLE_EMERGENCY_EXCEPTION_BUF
443# ifndef MICROPY_EMERGENCY_EXCEPTION_BUF_SIZE
444# define MICROPY_EMERGENCY_EXCEPTION_BUF_SIZE (0) // 0 - implies dynamic allocation
445# endif
446#endif
447
Damien George7f1da0a2016-12-15 13:00:19 +1100448// Whether to provide the mp_kbd_exception object
449#ifndef MICROPY_KBD_EXCEPTION
450#define MICROPY_KBD_EXCEPTION (0)
451#endif
452
Paul Sokolovsky1c9210b2015-12-23 00:06:37 +0200453// Prefer to raise KeyboardInterrupt asynchronously (from signal or interrupt
454// handler) - if supported by a particular port.
455#ifndef MICROPY_ASYNC_KBD_INTR
456#define MICROPY_ASYNC_KBD_INTR (0)
457#endif
458
Damien George136f6752014-01-07 14:54:15 +0000459// Whether to include REPL helper function
Damien George58ebde42014-05-21 20:32:59 +0100460#ifndef MICROPY_HELPER_REPL
461#define MICROPY_HELPER_REPL (0)
Damien George136f6752014-01-07 14:54:15 +0000462#endif
463
Tom Soulanille7d588b02015-07-09 16:32:36 -0700464// Whether to include emacs-style readline behavior in REPL
465#ifndef MICROPY_REPL_EMACS_KEYS
Damien Georged8a7f8b2015-07-26 15:49:13 +0100466#define MICROPY_REPL_EMACS_KEYS (0)
Tom Soulanille7d588b02015-07-09 16:32:36 -0700467#endif
468
Damien George0af73012015-08-20 10:34:16 +0100469// Whether to implement auto-indent in REPL
470#ifndef MICROPY_REPL_AUTO_INDENT
471#define MICROPY_REPL_AUTO_INDENT (0)
472#endif
473
Paul Sokolovsky87bc8e22015-01-15 10:46:27 +0200474// Whether port requires event-driven REPL functions
475#ifndef MICROPY_REPL_EVENT_DRIVEN
476#define MICROPY_REPL_EVENT_DRIVEN (0)
477#endif
478
Damien Georged3ebe482014-01-07 15:20:33 +0000479// Whether to include lexer helper function for unix
Damien George58ebde42014-05-21 20:32:59 +0100480#ifndef MICROPY_HELPER_LEXER_UNIX
481#define MICROPY_HELPER_LEXER_UNIX (0)
Damien Georged3ebe482014-01-07 15:20:33 +0000482#endif
483
Paul Sokolovsky48b35722014-01-12 17:30:48 +0200484// Long int implementation
485#define MICROPY_LONGINT_IMPL_NONE (0)
486#define MICROPY_LONGINT_IMPL_LONGLONG (1)
Damien George438c88d2014-02-22 19:25:23 +0000487#define MICROPY_LONGINT_IMPL_MPZ (2)
Paul Sokolovsky48b35722014-01-12 17:30:48 +0200488
489#ifndef MICROPY_LONGINT_IMPL
490#define MICROPY_LONGINT_IMPL (MICROPY_LONGINT_IMPL_NONE)
491#endif
492
493#if MICROPY_LONGINT_IMPL == MICROPY_LONGINT_IMPL_LONGLONG
494typedef long long mp_longint_impl_t;
495#endif
496
Damien George62ad1892014-01-29 21:51:51 +0000497// Whether to include information in the byte code to determine source
498// line number (increases RAM usage, but doesn't slow byte code execution)
499#ifndef MICROPY_ENABLE_SOURCE_LINE
500#define MICROPY_ENABLE_SOURCE_LINE (0)
501#endif
502
Damien George1463c1f2014-04-25 23:52:57 +0100503// Whether to include doc strings (increases RAM usage)
504#ifndef MICROPY_ENABLE_DOC_STRING
505#define MICROPY_ENABLE_DOC_STRING (0)
506#endif
507
Damien George1e9a92f2014-11-06 17:36:16 +0000508// Exception messages are short static strings
Paul Sokolovsky1f85d622014-05-01 01:35:38 +0300509#define MICROPY_ERROR_REPORTING_TERSE (1)
510// Exception messages provide basic error details
511#define MICROPY_ERROR_REPORTING_NORMAL (2)
512// Exception messages provide full info, e.g. object names
513#define MICROPY_ERROR_REPORTING_DETAILED (3)
514
515#ifndef MICROPY_ERROR_REPORTING
516#define MICROPY_ERROR_REPORTING (MICROPY_ERROR_REPORTING_NORMAL)
517#endif
518
Paul Sokolovsky8a8c1fc2015-01-01 09:29:28 +0200519// Whether issue warnings during compiling/execution
520#ifndef MICROPY_WARNINGS
521#define MICROPY_WARNINGS (0)
522#endif
523
Damien George0c36da02014-03-08 15:24:39 +0000524// Float and complex implementation
525#define MICROPY_FLOAT_IMPL_NONE (0)
526#define MICROPY_FLOAT_IMPL_FLOAT (1)
527#define MICROPY_FLOAT_IMPL_DOUBLE (2)
528
529#ifndef MICROPY_FLOAT_IMPL
530#define MICROPY_FLOAT_IMPL (MICROPY_FLOAT_IMPL_NONE)
531#endif
532
533#if MICROPY_FLOAT_IMPL == MICROPY_FLOAT_IMPL_FLOAT
Damien Georgefb510b32014-06-01 13:32:54 +0100534#define MICROPY_PY_BUILTINS_FLOAT (1)
Damien George561844f2016-11-03 12:33:01 +1100535#define MICROPY_FLOAT_CONST(x) x##F
Damien George0c36da02014-03-08 15:24:39 +0000536#define MICROPY_FLOAT_C_FUN(fun) fun##f
537typedef float mp_float_t;
538#elif MICROPY_FLOAT_IMPL == MICROPY_FLOAT_IMPL_DOUBLE
Damien Georgefb510b32014-06-01 13:32:54 +0100539#define MICROPY_PY_BUILTINS_FLOAT (1)
Damien George561844f2016-11-03 12:33:01 +1100540#define MICROPY_FLOAT_CONST(x) x
Damien George0c36da02014-03-08 15:24:39 +0000541#define MICROPY_FLOAT_C_FUN(fun) fun
542typedef double mp_float_t;
543#else
Damien Georgefb510b32014-06-01 13:32:54 +0100544#define MICROPY_PY_BUILTINS_FLOAT (0)
Damien George136f6752014-01-07 14:54:15 +0000545#endif
546
Paul Sokolovsky3b6f7b92014-06-20 01:48:35 +0300547#ifndef MICROPY_PY_BUILTINS_COMPLEX
548#define MICROPY_PY_BUILTINS_COMPLEX (MICROPY_PY_BUILTINS_FLOAT)
549#endif
550
Paul Sokolovskydcac8802014-01-16 19:19:50 +0200551// Enable features which improve CPython compatibility
552// but may lead to more code size/memory usage.
553// TODO: Originally intended as generic category to not
554// add bunch of once-off options. May need refactoring later
555#ifndef MICROPY_CPYTHON_COMPAT
556#define MICROPY_CPYTHON_COMPAT (1)
557#endif
558
Paul Sokolovsky0ef015b2014-05-07 02:23:46 +0300559// Whether POSIX-semantics non-blocking streams are supported
560#ifndef MICROPY_STREAMS_NON_BLOCK
561#define MICROPY_STREAMS_NON_BLOCK (0)
562#endif
563
Paul Sokolovsky61e77a42016-07-30 20:05:56 +0300564// Whether to provide stream functions with POSIX-like signatures
565// (useful for porting existing libraries to MicroPython).
566#ifndef MICROPY_STREAMS_POSIX_API
567#define MICROPY_STREAMS_POSIX_API (0)
568#endif
569
Damien George3c9c3682015-09-15 14:56:13 +0100570// Whether to call __init__ when importing builtin modules for the first time
571#ifndef MICROPY_MODULE_BUILTIN_INIT
572#define MICROPY_MODULE_BUILTIN_INIT (0)
573#endif
574
Damien Georgec14a8162014-10-12 11:46:04 +0100575// Whether module weak links are supported
576#ifndef MICROPY_MODULE_WEAK_LINKS
577#define MICROPY_MODULE_WEAK_LINKS (0)
578#endif
579
Damien George0a2e9652016-01-31 22:24:16 +0000580// Whether frozen modules are supported in the form of strings
581#ifndef MICROPY_MODULE_FROZEN_STR
582#define MICROPY_MODULE_FROZEN_STR (0)
583#endif
584
585// Whether frozen modules are supported in the form of .mpy files
586#ifndef MICROPY_MODULE_FROZEN_MPY
587#define MICROPY_MODULE_FROZEN_MPY (0)
588#endif
589
590// Convenience macro for whether frozen modules are supported
Paul Sokolovsky640e0b22015-01-20 11:52:12 +0200591#ifndef MICROPY_MODULE_FROZEN
Damien George0a2e9652016-01-31 22:24:16 +0000592#define MICROPY_MODULE_FROZEN (MICROPY_MODULE_FROZEN_STR || MICROPY_MODULE_FROZEN_MPY)
Paul Sokolovsky640e0b22015-01-20 11:52:12 +0200593#endif
594
Damien George78d702c2014-12-09 16:19:48 +0000595// Whether you can override builtins in the builtins module
596#ifndef MICROPY_CAN_OVERRIDE_BUILTINS
597#define MICROPY_CAN_OVERRIDE_BUILTINS (0)
598#endif
599
Damien George06593fb2015-06-19 12:49:10 +0000600// Whether to check that the "self" argument of a builtin method has the
601// correct type. Such an explicit check is only needed if a builtin
602// method escapes to Python land without a first argument, eg
603// list.append([], 1). Without this check such calls will have undefined
604// behaviour (usually segfault) if the first argument is the wrong type.
605#ifndef MICROPY_BUILTIN_METHOD_CHECK_SELF_ARG
606#define MICROPY_BUILTIN_METHOD_CHECK_SELF_ARG (1)
607#endif
608
Damien George3f56fd62016-05-10 10:54:06 +0100609// Whether to use internally defined errno's (otherwise system provided ones)
610#ifndef MICROPY_USE_INTERNAL_ERRNO
611#define MICROPY_USE_INTERNAL_ERRNO (0)
612#endif
613
Delio Brignolie2ac8bb2016-08-21 11:33:37 +0200614// Whether to use internally defined *printf() functions (otherwise external ones)
615#ifndef MICROPY_USE_INTERNAL_PRINTF
616#define MICROPY_USE_INTERNAL_PRINTF (1)
617#endif
618
Damien George6e74d242017-02-16 18:05:06 +1100619// Support for internal scheduler
620#ifndef MICROPY_ENABLE_SCHEDULER
621#define MICROPY_ENABLE_SCHEDULER (0)
622#endif
623
624// Maximum number of entries in the scheduler
625#ifndef MICROPY_SCHEDULER_DEPTH
626#define MICROPY_SCHEDULER_DEPTH (4)
627#endif
628
Damien Georgedcb9ea72017-01-27 15:10:09 +1100629// Support for generic VFS sub-system
630#ifndef MICROPY_VFS
631#define MICROPY_VFS (0)
632#endif
633
Damien Georgeee3fd462014-05-24 23:03:12 +0100634/*****************************************************************************/
635/* Fine control over Python builtins, classes, modules, etc */
636
stijn3cc17c62015-02-14 18:44:31 +0100637// Whether to implement attributes on functions
638#ifndef MICROPY_PY_FUNCTION_ATTRS
639#define MICROPY_PY_FUNCTION_ATTRS (0)
640#endif
641
stijn28fa84b2015-02-14 18:43:54 +0100642// Whether to support descriptors (__get__ and __set__)
643// This costs some code size and makes all load attrs and store attrs slow
644#ifndef MICROPY_PY_DESCRIPTORS
645#define MICROPY_PY_DESCRIPTORS (0)
646#endif
647
dmazzella18e65692017-01-03 11:00:12 +0100648// Whether to support class __delattr__ and __setattr__ methods
649// This costs some code size and makes all del attrs and store attrs slow
650#ifndef MICROPY_PY_DELATTR_SETATTR
651#define MICROPY_PY_DELATTR_SETATTR (0)
652#endif
653
pohmelie81ebba72016-01-27 23:23:11 +0300654// Support for async/await/async for/async with
655#ifndef MICROPY_PY_ASYNC_AWAIT
656#define MICROPY_PY_ASYNC_AWAIT (1)
657#endif
658
Paul Sokolovskya1b442b2016-07-22 00:46:24 +0300659// Issue a warning when comparing str and bytes objects
Paul Sokolovsky707cae72016-07-22 00:34:34 +0300660#ifndef MICROPY_PY_STR_BYTES_CMP_WARN
661#define MICROPY_PY_STR_BYTES_CMP_WARN (0)
662#endif
663
Paul Sokolovsky12bc13e2014-06-13 01:05:19 +0300664// Whether str object is proper unicode
665#ifndef MICROPY_PY_BUILTINS_STR_UNICODE
666#define MICROPY_PY_BUILTINS_STR_UNICODE (0)
Damien George8546ce12014-06-28 10:29:22 +0100667#endif
Damien Georgeb3a50f02014-06-28 10:27:15 +0100668
Paul Sokolovsky1b5abfc2016-05-22 00:13:44 +0300669// Whether str.center() method provided
670#ifndef MICROPY_PY_BUILTINS_STR_CENTER
671#define MICROPY_PY_BUILTINS_STR_CENTER (0)
672#endif
673
Paul Sokolovsky56eb25f2016-08-07 06:46:55 +0300674// Whether str.partition()/str.rpartition() method provided
675#ifndef MICROPY_PY_BUILTINS_STR_PARTITION
676#define MICROPY_PY_BUILTINS_STR_PARTITION (0)
677#endif
678
Paul Sokolovskyac2f7a72015-04-04 00:09:23 +0300679// Whether str.splitlines() method provided
680#ifndef MICROPY_PY_BUILTINS_STR_SPLITLINES
681#define MICROPY_PY_BUILTINS_STR_SPLITLINES (0)
682#endif
683
Paul Sokolovskycb78f862014-06-27 20:39:09 +0300684// Whether to support bytearray object
685#ifndef MICROPY_PY_BUILTINS_BYTEARRAY
686#define MICROPY_PY_BUILTINS_BYTEARRAY (1)
Paul Sokolovsky12bc13e2014-06-13 01:05:19 +0300687#endif
688
Damien Georgedd4f4532014-10-23 13:34:35 +0100689// Whether to support memoryview object
690#ifndef MICROPY_PY_BUILTINS_MEMORYVIEW
691#define MICROPY_PY_BUILTINS_MEMORYVIEW (0)
692#endif
693
Damien George3ebd4d02014-06-01 13:46:47 +0100694// Whether to support set object
695#ifndef MICROPY_PY_BUILTINS_SET
696#define MICROPY_PY_BUILTINS_SET (1)
697#endif
698
Damien Georgefb510b32014-06-01 13:32:54 +0100699// Whether to support slice subscript operators and slice object
700#ifndef MICROPY_PY_BUILTINS_SLICE
701#define MICROPY_PY_BUILTINS_SLICE (1)
Damien Georgeee3fd462014-05-24 23:03:12 +0100702#endif
703
Tom Soulanilleaeb62f92015-09-11 14:31:32 -0700704// Whether to support slice attribute read access,
705// i.e. slice.start, slice.stop, slice.step
706#ifndef MICROPY_PY_BUILTINS_SLICE_ATTRS
707#define MICROPY_PY_BUILTINS_SLICE_ATTRS (0)
708#endif
709
Damien Georgeee3fd462014-05-24 23:03:12 +0100710// Whether to support frozenset object
Damien Georgefb510b32014-06-01 13:32:54 +0100711#ifndef MICROPY_PY_BUILTINS_FROZENSET
712#define MICROPY_PY_BUILTINS_FROZENSET (0)
Damien Georgeee3fd462014-05-24 23:03:12 +0100713#endif
714
Damien Georgefb510b32014-06-01 13:32:54 +0100715// Whether to support property object
716#ifndef MICROPY_PY_BUILTINS_PROPERTY
717#define MICROPY_PY_BUILTINS_PROPERTY (1)
Damien Georgeee3fd462014-05-24 23:03:12 +0100718#endif
719
Peter D. Grayb2a237d2015-03-06 14:48:14 -0500720// Whether to implement the start/stop/step attributes (readback) on
721// the "range" builtin type. Rarely used, and costs ~60 bytes (x86).
722#ifndef MICROPY_PY_BUILTINS_RANGE_ATTRS
723#define MICROPY_PY_BUILTINS_RANGE_ATTRS (1)
724#endif
725
Daniel Campora077812b2015-06-29 22:45:39 +0200726// Whether to support timeout exceptions (like socket.timeout)
727#ifndef MICROPY_PY_BUILTINS_TIMEOUTERROR
728#define MICROPY_PY_BUILTINS_TIMEOUTERROR (0)
729#endif
730
Paul Sokolovsky98c4bc32015-01-30 01:42:49 +0200731// Whether to support complete set of special methods
732// for user classes, otherwise only the most used
733#ifndef MICROPY_PY_ALL_SPECIAL_METHODS
734#define MICROPY_PY_ALL_SPECIAL_METHODS (0)
735#endif
736
Damien Georgec9fc6202014-10-25 21:59:14 +0100737// Whether to support compile function
738#ifndef MICROPY_PY_BUILTINS_COMPILE
739#define MICROPY_PY_BUILTINS_COMPILE (0)
740#endif
741
Paul Sokolovskye2d44e32015-04-06 23:50:37 +0300742// Whether to support enumerate function(type)
743#ifndef MICROPY_PY_BUILTINS_ENUMERATE
744#define MICROPY_PY_BUILTINS_ENUMERATE (1)
745#endif
746
Damien Georgedd5353a2015-12-18 12:35:44 +0000747// Whether to support eval and exec functions
748// By default they are supported if the compiler is enabled
749#ifndef MICROPY_PY_BUILTINS_EVAL_EXEC
750#define MICROPY_PY_BUILTINS_EVAL_EXEC (MICROPY_ENABLE_COMPILER)
751#endif
752
Damien George2a3e2b92014-12-19 13:36:17 +0000753// Whether to support the Python 2 execfile function
754#ifndef MICROPY_PY_BUILTINS_EXECFILE
755#define MICROPY_PY_BUILTINS_EXECFILE (0)
756#endif
757
Paul Sokolovsky22ff3972015-08-20 01:01:56 +0300758// Whether to support filter function(type)
759#ifndef MICROPY_PY_BUILTINS_FILTER
760#define MICROPY_PY_BUILTINS_FILTER (1)
761#endif
762
Paul Sokolovsky282ca092015-04-07 00:16:51 +0300763// Whether to support reversed function(type)
764#ifndef MICROPY_PY_BUILTINS_REVERSED
765#define MICROPY_PY_BUILTINS_REVERSED (1)
766#endif
767
Paul Sokolovsky5ab5ac52015-05-04 19:45:53 +0300768// Whether to define "NotImplemented" special constant
769#ifndef MICROPY_PY_BUILTINS_NOTIMPLEMENTED
770#define MICROPY_PY_BUILTINS_NOTIMPLEMENTED (0)
771#endif
772
pohmelie354e6882015-12-07 15:35:48 +0300773// Whether to support min/max functions
774#ifndef MICROPY_PY_BUILTINS_MIN_MAX
775#define MICROPY_PY_BUILTINS_MIN_MAX (1)
776#endif
777
Damien Georgea19b5a02017-02-03 12:35:48 +1100778// Support for calls to pow() with 3 integer arguments
779#ifndef MICROPY_PY_BUILTINS_POW3
780#define MICROPY_PY_BUILTINS_POW3 (0)
781#endif
782
Damien George9f04dfb2017-01-21 23:17:51 +1100783// Whether to provide the help function
784#ifndef MICROPY_PY_BUILTINS_HELP
785#define MICROPY_PY_BUILTINS_HELP (0)
786#endif
787
788// Use this to configure the help text shown for help(). It should be a
789// variable with the type "const char*". A sensible default is provided.
790#ifndef MICROPY_PY_BUILTINS_HELP_TEXT
791#define MICROPY_PY_BUILTINS_HELP_TEXT mp_help_default_text
792#endif
793
Damien Georgef5172af2017-01-22 12:12:54 +1100794// Add the ability to list the available modules when executing help('modules')
795#ifndef MICROPY_PY_BUILTINS_HELP_MODULES
796#define MICROPY_PY_BUILTINS_HELP_MODULES (0)
797#endif
798
Paul Sokolovskyd0f5e612014-07-25 11:00:15 +0300799// Whether to set __file__ for imported modules
800#ifndef MICROPY_PY___FILE__
801#define MICROPY_PY___FILE__ (1)
802#endif
803
Damien George89deec02015-01-09 20:12:54 +0000804// Whether to provide mem-info related functions in micropython module
805#ifndef MICROPY_PY_MICROPYTHON_MEM_INFO
806#define MICROPY_PY_MICROPYTHON_MEM_INFO (0)
807#endif
808
Paul Sokolovskycb78f862014-06-27 20:39:09 +0300809// Whether to provide "array" module. Note that large chunk of the
810// underlying code is shared with "bytearray" builtin type, so to
811// get real savings, it should be disabled too.
812#ifndef MICROPY_PY_ARRAY
813#define MICROPY_PY_ARRAY (1)
814#endif
815
Paul Sokolovskycefcbb22015-02-27 22:16:05 +0200816// Whether to support slice assignments for array (and bytearray).
817// This is rarely used, but adds ~0.5K of code.
818#ifndef MICROPY_PY_ARRAY_SLICE_ASSIGN
819#define MICROPY_PY_ARRAY_SLICE_ASSIGN (0)
820#endif
821
Damien George5aa311d2015-04-21 14:14:24 +0000822// Whether to support attrtuple type (MicroPython extension)
823// It provides space-efficient tuples with attribute access
824#ifndef MICROPY_PY_ATTRTUPLE
825#define MICROPY_PY_ATTRTUPLE (1)
826#endif
827
Damien Georgeee3fd462014-05-24 23:03:12 +0100828// Whether to provide "collections" module
829#ifndef MICROPY_PY_COLLECTIONS
830#define MICROPY_PY_COLLECTIONS (1)
831#endif
832
Paul Sokolovsky0ef01d02015-03-18 01:25:04 +0200833// Whether to provide "collections.OrderedDict" type
834#ifndef MICROPY_PY_COLLECTIONS_ORDEREDDICT
835#define MICROPY_PY_COLLECTIONS_ORDEREDDICT (0)
836#endif
837
Damien Georgeee3fd462014-05-24 23:03:12 +0100838// Whether to provide "math" module
839#ifndef MICROPY_PY_MATH
840#define MICROPY_PY_MATH (1)
841#endif
842
Damien George5cbeace2015-02-22 14:48:18 +0000843// Whether to provide special math functions: math.{erf,erfc,gamma,lgamma}
844#ifndef MICROPY_PY_MATH_SPECIAL_FUNCTIONS
845#define MICROPY_PY_MATH_SPECIAL_FUNCTIONS (0)
846#endif
847
Damien Georgeee3fd462014-05-24 23:03:12 +0100848// Whether to provide "cmath" module
849#ifndef MICROPY_PY_CMATH
850#define MICROPY_PY_CMATH (0)
851#endif
852
853// Whether to provide "gc" module
854#ifndef MICROPY_PY_GC
855#define MICROPY_PY_GC (1)
856#endif
857
Paul Sokolovsky755a55f2014-06-05 22:48:02 +0300858// Whether to return number of collected objects from gc.collect()
859#ifndef MICROPY_PY_GC_COLLECT_RETVAL
860#define MICROPY_PY_GC_COLLECT_RETVAL (0)
861#endif
862
Damien Georgeee3fd462014-05-24 23:03:12 +0100863// Whether to provide "io" module
864#ifndef MICROPY_PY_IO
865#define MICROPY_PY_IO (1)
866#endif
867
868// Whether to provide "io.FileIO" class
869#ifndef MICROPY_PY_IO_FILEIO
870#define MICROPY_PY_IO_FILEIO (0)
871#endif
872
873// Whether to provide "io.BytesIO" class
874#ifndef MICROPY_PY_IO_BYTESIO
875#define MICROPY_PY_IO_BYTESIO (1)
876#endif
877
Paul Sokolovsky5d93dfb2016-03-25 01:10:49 +0200878// Whether to provide "io.BufferedWriter" class
879#ifndef MICROPY_PY_IO_BUFFEREDWRITER
880#define MICROPY_PY_IO_BUFFEREDWRITER (0)
881#endif
882
Damien Georgeee3fd462014-05-24 23:03:12 +0100883// Whether to provide "struct" module
884#ifndef MICROPY_PY_STRUCT
885#define MICROPY_PY_STRUCT (1)
886#endif
887
888// Whether to provide "sys" module
889#ifndef MICROPY_PY_SYS
890#define MICROPY_PY_SYS (1)
891#endif
892
Paul Sokolovsky4e0eeeb2014-07-03 16:50:11 +0300893// Whether to provide "sys.maxsize" constant
894#ifndef MICROPY_PY_SYS_MAXSIZE
895#define MICROPY_PY_SYS_MAXSIZE (0)
896#endif
897
Paul Sokolovsky1a1d11f2015-12-05 00:09:10 +0200898// Whether to provide "sys.modules" dictionary
899#ifndef MICROPY_PY_SYS_MODULES
900#define MICROPY_PY_SYS_MODULES (1)
901#endif
902
Paul Sokolovsky8b85d142015-04-25 03:17:41 +0300903// Whether to provide "sys.exc_info" function
904// Avoid enabling this, this function is Python2 heritage
905#ifndef MICROPY_PY_SYS_EXC_INFO
906#define MICROPY_PY_SYS_EXC_INFO (0)
907#endif
908
Damien Georgeee3fd462014-05-24 23:03:12 +0100909// Whether to provide "sys.exit" function
910#ifndef MICROPY_PY_SYS_EXIT
Paul Sokolovsky403c9302016-12-14 21:10:22 +0300911#define MICROPY_PY_SYS_EXIT (1)
Damien Georgeee3fd462014-05-24 23:03:12 +0100912#endif
913
914// Whether to provide sys.{stdin,stdout,stderr} objects
915#ifndef MICROPY_PY_SYS_STDFILES
916#define MICROPY_PY_SYS_STDFILES (0)
Damien George3bb8bd82014-04-14 21:20:30 +0100917#endif
918
Damien George3c4b5d42015-05-13 23:49:21 +0100919// Whether to provide sys.{stdin,stdout,stderr}.buffer object
920// This is implemented per-port
921#ifndef MICROPY_PY_SYS_STDIO_BUFFER
922#define MICROPY_PY_SYS_STDIO_BUFFER (0)
923#endif
Paul Sokolovsky82158472014-06-28 03:03:47 +0300924
Damien George596a3fe2016-05-10 10:54:25 +0100925// Whether to provide "uerrno" module
926#ifndef MICROPY_PY_UERRNO
927#define MICROPY_PY_UERRNO (0)
928#endif
929
Damien Georgef5634062017-02-22 12:53:42 +1100930// Whether to provide the uerrno.errorcode dict
931#ifndef MICROPY_PY_UERRNO_ERRORCODE
932#define MICROPY_PY_UERRNO_ERRORCODE (1)
933#endif
934
Paul Sokolovsky8f5bc3f2016-11-20 23:49:45 +0300935// Whether to provide "uselect" module (baremetal implementation)
936#ifndef MICROPY_PY_USELECT
937#define MICROPY_PY_USELECT (0)
938#endif
939
Paul Sokolovskya9728442016-10-14 20:13:02 +0300940// Whether to provide "utime" module functions implementation
941// in terms of mp_hal_* functions.
942#ifndef MICROPY_PY_UTIME_MP_HAL
943#define MICROPY_PY_UTIME_MP_HAL (0)
944#endif
945
Paul Sokolovsky76146b32016-10-30 03:02:07 +0300946// Period of values returned by utime.ticks_ms(), ticks_us(), ticks_cpu()
947// functions. Should be power of two. All functions above use the same
948// period, so if underlying hardware/API has different periods, the
949// minimum of them should be used. The value below is the maximum value
950// this parameter can take (corresponding to 30 bit tick values on 32-bit
951// system).
952#ifndef MICROPY_PY_UTIME_TICKS_PERIOD
953#define MICROPY_PY_UTIME_TICKS_PERIOD (MP_SMALL_INT_POSITIVE_MASK + 1)
954#endif
955
Damien George27cc0772016-04-22 22:52:33 +0000956// Whether to provide "_thread" module
957#ifndef MICROPY_PY_THREAD
958#define MICROPY_PY_THREAD (0)
959#endif
960
Damien George4cec63a2016-05-26 10:42:53 +0000961// Whether to make the VM/runtime thread-safe using a global lock
962// If not enabled then thread safety must be provided at the Python level
963#ifndef MICROPY_PY_THREAD_GIL
964#define MICROPY_PY_THREAD_GIL (MICROPY_PY_THREAD)
965#endif
966
Damien Georgef6c22a02017-02-06 10:50:43 +1100967// Number of VM jump-loops to do before releasing the GIL.
968// Set this to 0 to disable the divisor.
969#ifndef MICROPY_PY_THREAD_GIL_VM_DIVISOR
970#define MICROPY_PY_THREAD_GIL_VM_DIVISOR (32)
971#endif
972
Paul Sokolovsky82158472014-06-28 03:03:47 +0300973// Extended modules
Paul Sokolovsky510296f2014-08-08 22:51:40 +0300974
Paul Sokolovsky82158472014-06-28 03:03:47 +0300975#ifndef MICROPY_PY_UCTYPES
976#define MICROPY_PY_UCTYPES (0)
977#endif
978
Paul Sokolovsky34162872014-10-12 08:16:34 -0700979#ifndef MICROPY_PY_UZLIB
980#define MICROPY_PY_UZLIB (0)
981#endif
982
Damien George612045f2014-09-17 22:56:34 +0100983#ifndef MICROPY_PY_UJSON
984#define MICROPY_PY_UJSON (0)
985#endif
986
Paul Sokolovskyc71e0452014-09-12 18:48:07 +0300987#ifndef MICROPY_PY_URE
988#define MICROPY_PY_URE (0)
989#endif
990
Damien Georgef5d69792014-10-22 17:37:18 +0000991#ifndef MICROPY_PY_UHEAPQ
992#define MICROPY_PY_UHEAPQ (0)
993#endif
994
Paul Sokolovskyd02f6a92016-12-22 00:29:32 +0300995// Optimized heap queue for relative timestamps
996#ifndef MICROPY_PY_UTIMEQ
997#define MICROPY_PY_UTIMEQ (0)
998#endif
999
Paul Sokolovskyf4b19c82014-11-22 01:19:13 +02001000#ifndef MICROPY_PY_UHASHLIB
1001#define MICROPY_PY_UHASHLIB (0)
1002#endif
1003
Paul Sokolovskybfdc2052014-11-29 06:19:30 +02001004#ifndef MICROPY_PY_UBINASCII
1005#define MICROPY_PY_UBINASCII (0)
1006#endif
1007
Paul Sokolovskyc4283672016-08-24 18:28:43 +03001008// Depends on MICROPY_PY_UZLIB
1009#ifndef MICROPY_PY_UBINASCII_CRC32
1010#define MICROPY_PY_UBINASCII_CRC32 (0)
1011#endif
1012
Paul Sokolovskya58a91e2016-01-17 12:10:28 +02001013#ifndef MICROPY_PY_URANDOM
1014#define MICROPY_PY_URANDOM (0)
1015#endif
1016
Damien Georgea53af6c2016-01-22 16:19:32 +00001017// Whether to include: randrange, randint, choice, random, uniform
1018#ifndef MICROPY_PY_URANDOM_EXTRA_FUNCS
1019#define MICROPY_PY_URANDOM_EXTRA_FUNCS (0)
1020#endif
1021
Paul Sokolovsky01162182015-05-03 20:25:40 +03001022#ifndef MICROPY_PY_MACHINE
1023#define MICROPY_PY_MACHINE (0)
1024#endif
1025
Damien George33168082016-05-31 14:25:19 +01001026// Whether to include: time_pulse_us
1027#ifndef MICROPY_PY_MACHINE_PULSE
1028#define MICROPY_PY_MACHINE_PULSE (0)
1029#endif
1030
Damien Georged0837122016-04-12 13:42:35 +01001031#ifndef MICROPY_PY_MACHINE_I2C
1032#define MICROPY_PY_MACHINE_I2C (0)
1033#endif
1034
Damien George0823c1b2016-09-01 15:07:20 +10001035#ifndef MICROPY_PY_MACHINE_SPI
1036#define MICROPY_PY_MACHINE_SPI (0)
1037#endif
1038
Paul Sokolovskyaaa88672015-10-06 18:10:00 +03001039#ifndef MICROPY_PY_USSL
1040#define MICROPY_PY_USSL (0)
1041#endif
1042
Paul Sokolovsky24342dd2016-03-24 19:14:12 +02001043#ifndef MICROPY_PY_WEBSOCKET
1044#define MICROPY_PY_WEBSOCKET (0)
1045#endif
1046
Damien George53ad6812016-04-08 11:08:37 +01001047#ifndef MICROPY_PY_FRAMEBUF
1048#define MICROPY_PY_FRAMEBUF (0)
1049#endif
1050
Paul Sokolovsky737bd9c2016-07-02 14:57:42 +03001051#ifndef MICROPY_PY_BTREE
1052#define MICROPY_PY_BTREE (0)
1053#endif
1054
Damien George58ebde42014-05-21 20:32:59 +01001055/*****************************************************************************/
1056/* Hooks for a port to add builtins */
1057
Damien Georgecaac5422014-03-25 14:18:18 +00001058// Additional builtin function definitions - see builtintables.c:builtin_object_table for format.
Damien George58ebde42014-05-21 20:32:59 +01001059#ifndef MICROPY_PORT_BUILTINS
1060#define MICROPY_PORT_BUILTINS
Paul Sokolovsky910843e2014-02-14 12:02:34 +02001061#endif
Damien Georgecaac5422014-03-25 14:18:18 +00001062
1063// Additional builtin module definitions - see builtintables.c:builtin_module_table for format.
Damien George58ebde42014-05-21 20:32:59 +01001064#ifndef MICROPY_PORT_BUILTIN_MODULES
1065#define MICROPY_PORT_BUILTIN_MODULES
Damien Georgecaac5422014-03-25 14:18:18 +00001066#endif
1067
Damien Georgec14a8162014-10-12 11:46:04 +01001068// Any module weak links - see builtintables.c:mp_builtin_module_weak_links_table.
1069#ifndef MICROPY_PORT_BUILTIN_MODULE_WEAK_LINKS
1070#define MICROPY_PORT_BUILTIN_MODULE_WEAK_LINKS
1071#endif
1072
Damien George57e99eb2014-04-10 22:42:11 +01001073// Additional constant definitions for the compiler - see compile.c:mp_constants_table.
Damien George58ebde42014-05-21 20:32:59 +01001074#ifndef MICROPY_PORT_CONSTANTS
1075#define MICROPY_PORT_CONSTANTS
Damien George57e99eb2014-04-10 22:42:11 +01001076#endif
1077
Damien Georgeb4b10fd2015-01-01 23:30:53 +00001078// Any root pointers for GC scanning - see mpstate.c
1079#ifndef MICROPY_PORT_ROOT_POINTERS
1080#define MICROPY_PORT_ROOT_POINTERS
1081#endif
1082
Damien George136f6752014-01-07 14:54:15 +00001083/*****************************************************************************/
1084/* Miscellaneous settings */
1085
Damien George28631532015-02-08 13:42:00 +00001086// All uPy objects in ROM must be aligned on at least a 4 byte boundary
1087// so that the small-int/qstr/pointer distinction can be made. For machines
1088// that don't do this (eg 16-bit CPU), define the following macro to something
1089// like __attribute__((aligned(4))).
1090#ifndef MICROPY_OBJ_BASE_ALIGNMENT
1091#define MICROPY_OBJ_BASE_ALIGNMENT
1092#endif
1093
Dave Hylands5b7fd202014-07-01 23:46:53 -07001094// On embedded platforms, these will typically enable/disable irqs.
1095#ifndef MICROPY_BEGIN_ATOMIC_SECTION
Damien George4859edb2014-10-15 17:33:24 +00001096#define MICROPY_BEGIN_ATOMIC_SECTION() (0)
Dave Hylands5b7fd202014-07-01 23:46:53 -07001097#endif
1098#ifndef MICROPY_END_ATOMIC_SECTION
Damien George4859edb2014-10-15 17:33:24 +00001099#define MICROPY_END_ATOMIC_SECTION(state) (void)(state)
Dave Hylands5b7fd202014-07-01 23:46:53 -07001100#endif
1101
Paul Sokolovskyd5df6cd2014-02-12 18:15:40 +02001102// Allow to override static modifier for global objects, e.g. to use with
1103// object code analysis tools which don't support static symbols.
1104#ifndef STATIC
1105#define STATIC static
1106#endif
1107
Paul Sokolovskyfc5aac82014-01-12 16:10:19 +02001108#define BITS_PER_BYTE (8)
1109#define BITS_PER_WORD (BITS_PER_BYTE * BYTES_PER_WORD)
Damien George40f3c022014-07-03 13:25:24 +01001110// mp_int_t value with most significant bit set
1111#define WORD_MSBIT_HIGH (((mp_uint_t)1) << (BYTES_PER_WORD * 8 - 1))
Paul Sokolovskyfc5aac82014-01-12 16:10:19 +02001112
Damien Georgea9bcd512014-10-06 13:44:59 +00001113// Make sure both MP_ENDIANNESS_LITTLE and MP_ENDIANNESS_BIG are
1114// defined and that they are the opposite of each other.
1115#if defined(MP_ENDIANNESS_LITTLE)
1116#define MP_ENDIANNESS_BIG (!MP_ENDIANNESS_LITTLE)
1117#elif defined(MP_ENDIANNESS_BIG)
1118#define MP_ENDIANNESS_LITTLE (!MP_ENDIANNESS_BIG)
1119#else
1120 // Endiannes not defined by port so try to autodetect it.
1121 #if defined(__BYTE_ORDER__)
1122 #if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
1123 #define MP_ENDIANNESS_LITTLE (1)
1124 #else
1125 #define MP_ENDIANNESS_LITTLE (0)
1126 #endif
Damien Georgef32498f2014-10-06 16:09:31 +00001127 #elif defined(__LITTLE_ENDIAN__) || defined(__LITTLE_ENDIAN) || defined (_LITTLE_ENDIAN)
1128 #define MP_ENDIANNESS_LITTLE (1)
Damien Georgea9bcd512014-10-06 13:44:59 +00001129 #elif defined(__BIG_ENDIAN__) || defined(__BIG_ENDIAN) || defined (_BIG_ENDIAN)
1130 #define MP_ENDIANNESS_LITTLE (0)
1131 #else
Damien George4e4772b2015-05-30 23:12:30 +01001132 #include <endian.h>
1133 #if defined(__BYTE_ORDER)
1134 #if __BYTE_ORDER == __LITTLE_ENDIAN
1135 #define MP_ENDIANNESS_LITTLE (1)
1136 #else
1137 #define MP_ENDIANNESS_LITTLE (0)
1138 #endif
1139 #else
1140 #error endianness not defined and cannot detect it
1141 #endif
Damien Georgea9bcd512014-10-06 13:44:59 +00001142 #endif
1143 #define MP_ENDIANNESS_BIG (!MP_ENDIANNESS_LITTLE)
Andrew Schellercc837372014-04-14 02:39:56 +01001144#endif
Paul Sokolovsky2da81fa2014-04-11 03:44:00 +03001145
Damien George3c658a42014-08-24 16:28:17 +01001146// Make a pointer to RAM callable (eg set lower bit for Thumb code)
1147// (This scheme won't work if we want to mix Thumb and normal ARM code.)
1148#ifndef MICROPY_MAKE_POINTER_CALLABLE
1149#define MICROPY_MAKE_POINTER_CALLABLE(p) (p)
1150#endif
1151
Damien George7f9d1d62015-04-09 23:56:15 +01001152// If these MP_PLAT_*_EXEC macros are overridden then the memory allocated by them
Damien George2127e9a2015-01-14 00:11:09 +00001153// must be somehow reachable for marking by the GC, since the native code
1154// generators store pointers to GC managed memory in the code.
Fabian Vogtb7235b82014-09-03 16:59:33 +02001155#ifndef MP_PLAT_ALLOC_EXEC
Damien George4dea9222015-04-09 15:29:54 +00001156#define MP_PLAT_ALLOC_EXEC(min_size, ptr, size) do { *ptr = m_new(byte, min_size); *size = min_size; } while (0)
Fabian Vogtb7235b82014-09-03 16:59:33 +02001157#endif
1158
1159#ifndef MP_PLAT_FREE_EXEC
1160#define MP_PLAT_FREE_EXEC(ptr, size) m_del(byte, ptr, size)
1161#endif
1162
Damien George7f9d1d62015-04-09 23:56:15 +01001163// This macro is used to do all output (except when MICROPY_PY_IO is defined)
1164#ifndef MP_PLAT_PRINT_STRN
Damien George4300c7d2015-10-15 00:05:55 +01001165#define MP_PLAT_PRINT_STRN(str, len) mp_hal_stdout_tx_strn_cooked(str, len)
Damien George7f9d1d62015-04-09 23:56:15 +01001166#endif
1167
Paul Sokolovsky722e5622014-09-06 19:17:23 +03001168#ifndef MP_SSIZE_MAX
1169#define MP_SSIZE_MAX SSIZE_MAX
1170#endif
1171
Damien George40f3c022014-07-03 13:25:24 +01001172// printf format spec to use for mp_int_t and friends
Damien George136f6752014-01-07 14:54:15 +00001173#ifndef INT_FMT
stijn3baf6b52015-11-20 15:59:06 +01001174#if defined(__LP64__)
Damien George40f3c022014-07-03 13:25:24 +01001175// Archs where mp_int_t == long, long != int
Paul Sokolovskyc90c0f62014-01-04 01:57:00 +02001176#define UINT_FMT "%lu"
1177#define INT_FMT "%ld"
stijn3baf6b52015-11-20 15:59:06 +01001178#elif defined(_WIN64)
stijn0a4eb4d2015-12-18 10:20:33 +01001179#define UINT_FMT "%llu"
1180#define INT_FMT "%lld"
Paul Sokolovskyc90c0f62014-01-04 01:57:00 +02001181#else
Damien George40f3c022014-07-03 13:25:24 +01001182// Archs where mp_int_t == int
Paul Sokolovskyc90c0f62014-01-04 01:57:00 +02001183#define UINT_FMT "%u"
1184#define INT_FMT "%d"
1185#endif
1186#endif //INT_FMT
Paul Sokolovskye9085912014-04-30 05:35:18 +03001187
1188// Modifier for function which doesn't return
stijn01d6be42014-05-05 12:18:27 +02001189#ifndef NORETURN
Paul Sokolovskye9085912014-04-30 05:35:18 +03001190#define NORETURN __attribute__((noreturn))
stijn01d6be42014-05-05 12:18:27 +02001191#endif
mux5c8db482014-06-21 17:24:55 +02001192
1193// Modifier for weak functions
1194#ifndef MP_WEAK
1195#define MP_WEAK __attribute__((weak))
1196#endif
Paul Sokolovsky361909e2014-12-29 00:51:06 +02001197
Paul Sokolovsky0f5bf1a2016-06-15 23:52:00 +03001198// Modifier for functions which should be never inlined
1199#ifndef MP_NOINLINE
1200#define MP_NOINLINE __attribute__((noinline))
1201#endif
1202
Paul Sokolovsky1bc29112016-08-07 22:36:05 +03001203// Modifier for functions which should be always inlined
1204#ifndef MP_ALWAYSINLINE
1205#define MP_ALWAYSINLINE __attribute__((always_inline))
1206#endif
1207
Paul Sokolovsky361909e2014-12-29 00:51:06 +02001208// Condition is likely to be true, to help branch prediction
1209#ifndef MP_LIKELY
1210#define MP_LIKELY(x) __builtin_expect((x), 1)
1211#endif
1212
1213// Condition is likely to be false, to help branch prediction
1214#ifndef MP_UNLIKELY
1215#define MP_UNLIKELY(x) __builtin_expect((x), 0)
1216#endif
Damien George9ddbe292014-12-29 01:02:19 +00001217
1218#endif // __MICROPY_INCLUDED_PY_MPCONFIG_H__