Merge pull request #333 from pfalcon/heapsize-cmdline
unix: Allow to set heap size using "-X heapsize=N" option.
This commit is contained in:
commit
a11906d03b
83
unix/main.c
83
unix/main.c
@ -24,9 +24,10 @@
|
|||||||
#include <readline/history.h>
|
#include <readline/history.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if MICROPY_ENABLE_GC
|
||||||
// Heap size of GC heap (if enabled)
|
// Heap size of GC heap (if enabled)
|
||||||
// TODO: allow to specify on command line
|
long heap_size = 128*1024;
|
||||||
#define HEAP_SIZE 128*1024
|
#endif
|
||||||
|
|
||||||
// Stack top at the start of program
|
// Stack top at the start of program
|
||||||
void *stack_top;
|
void *stack_top;
|
||||||
@ -233,13 +234,34 @@ static mp_obj_t pyb_gc(void) {
|
|||||||
MP_DEFINE_CONST_FUN_OBJ_0(pyb_gc_obj, pyb_gc);
|
MP_DEFINE_CONST_FUN_OBJ_0(pyb_gc_obj, pyb_gc);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// Process options which set interpreter init options
|
||||||
|
void pre_process_options(int argc, char **argv) {
|
||||||
|
for (int a = 1; a < argc; a++) {
|
||||||
|
if (argv[a][0] == '-') {
|
||||||
|
if (strcmp(argv[a], "-X") == 0) {
|
||||||
|
if (a + 1 >= argc) {
|
||||||
|
exit(usage());
|
||||||
|
}
|
||||||
|
#if MICROPY_ENABLE_GC
|
||||||
|
if (strncmp(argv[a + 1], "heapsize=", sizeof("heapsize=") - 1) == 0) {
|
||||||
|
heap_size = strtol(argv[a + 1] + sizeof("heapsize=") - 1, NULL, 0);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
a++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
int main(int argc, char **argv) {
|
int main(int argc, char **argv) {
|
||||||
volatile int stack_dummy;
|
volatile int stack_dummy;
|
||||||
stack_top = (void*)&stack_dummy;
|
stack_top = (void*)&stack_dummy;
|
||||||
|
|
||||||
|
pre_process_options(argc, argv);
|
||||||
|
|
||||||
#if MICROPY_ENABLE_GC
|
#if MICROPY_ENABLE_GC
|
||||||
char *heap = malloc(HEAP_SIZE);
|
char *heap = malloc(heap_size);
|
||||||
gc_init(heap, heap + HEAP_SIZE);
|
gc_init(heap, heap + heap_size);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
qstr_init();
|
qstr_init();
|
||||||
@ -319,37 +341,42 @@ int main(int argc, char **argv) {
|
|||||||
printf(" peak %d\n", m_get_peak_bytes_allocated());
|
printf(" peak %d\n", m_get_peak_bytes_allocated());
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (argc == 1) {
|
bool executed = false;
|
||||||
do_repl();
|
for (int a = 1; a < argc; a++) {
|
||||||
} else {
|
if (argv[a][0] == '-') {
|
||||||
for (int a = 1; a < argc; a++) {
|
if (strcmp(argv[a], "-c") == 0) {
|
||||||
if (argv[a][0] == '-') {
|
if (a + 1 >= argc) {
|
||||||
if (strcmp(argv[a], "-c") == 0) {
|
|
||||||
if (a + 1 >= argc) {
|
|
||||||
return usage();
|
|
||||||
}
|
|
||||||
do_str(argv[a + 1]);
|
|
||||||
a += 1;
|
|
||||||
} else {
|
|
||||||
return usage();
|
return usage();
|
||||||
}
|
}
|
||||||
|
do_str(argv[a + 1]);
|
||||||
|
executed = true;
|
||||||
|
a += 1;
|
||||||
|
} else if (strcmp(argv[a], "-X") == 0) {
|
||||||
|
a += 1;
|
||||||
} else {
|
} else {
|
||||||
// Set base dir of the script as first entry in sys.path
|
return usage();
|
||||||
char *basedir = realpath(argv[a], NULL);
|
|
||||||
if (basedir != NULL) {
|
|
||||||
char *p = strrchr(basedir, '/');
|
|
||||||
path_items[0] = MP_OBJ_NEW_QSTR(qstr_from_strn(basedir, p - basedir));
|
|
||||||
free(basedir);
|
|
||||||
}
|
|
||||||
for (int i = a; i < argc; i++) {
|
|
||||||
rt_list_append(py_argv, MP_OBJ_NEW_QSTR(qstr_from_str(argv[i])));
|
|
||||||
}
|
|
||||||
do_file(argv[a]);
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
// Set base dir of the script as first entry in sys.path
|
||||||
|
char *basedir = realpath(argv[a], NULL);
|
||||||
|
if (basedir != NULL) {
|
||||||
|
char *p = strrchr(basedir, '/');
|
||||||
|
path_items[0] = MP_OBJ_NEW_QSTR(qstr_from_strn(basedir, p - basedir));
|
||||||
|
free(basedir);
|
||||||
|
}
|
||||||
|
for (int i = a; i < argc; i++) {
|
||||||
|
rt_list_append(py_argv, MP_OBJ_NEW_QSTR(qstr_from_str(argv[i])));
|
||||||
|
}
|
||||||
|
do_file(argv[a]);
|
||||||
|
executed = true;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!executed) {
|
||||||
|
do_repl();
|
||||||
|
}
|
||||||
|
|
||||||
rt_deinit();
|
rt_deinit();
|
||||||
|
|
||||||
//printf("total bytes = %d\n", m_get_total_bytes_allocated());
|
//printf("total bytes = %d\n", m_get_total_bytes_allocated());
|
||||||
|
Loading…
Reference in New Issue
Block a user