summaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorDamien George <damien.p.george@gmail.com>2014-01-29 19:04:59 +0000
committerDamien George <damien.p.george@gmail.com>2014-01-29 19:04:59 +0000
commit0347fbd2d541d6ede7d281e0b2f8c79d56c5f8be (patch)
tree70a8d4f03d1aed855276ad046093a3b6dafe58bd
parent08d075592f3fa958ac3f24e176bee5ab56e78f49 (diff)
parentbfb01e9da620d974e3e38bf7ea2aa22d9c527d9d (diff)
downloadmicropython-0347fbd2d541d6ede7d281e0b2f8c79d56c5f8be.tar.gz
micropython-0347fbd2d541d6ede7d281e0b2f8c79d56c5f8be.zip
Merge branch 'master' of github.com:iabdalkader/micropython
-rw-r--r--stm/file.c1
-rw-r--r--stm/gccollect.c6
-rw-r--r--stm/gccollect.h5
-rw-r--r--stm/main.c4
-rw-r--r--stm/stm32f405.ld3
5 files changed, 11 insertions, 8 deletions
diff --git a/stm/file.c b/stm/file.c
index 35bfca16a5..84f7251fec 100644
--- a/stm/file.c
+++ b/stm/file.c
@@ -3,7 +3,6 @@
#include "misc.h"
#include "mpconfig.h"
-#include "mpconfigport.h"
#include "qstr.h"
#include "obj.h"
#include "file.h"
diff --git a/stm/gccollect.c b/stm/gccollect.c
index c0f67ac0d5..cea0bc56eb 100644
--- a/stm/gccollect.c
+++ b/stm/gccollect.c
@@ -13,10 +13,10 @@ void gc_helper_get_regs_and_clean_stack(machine_uint_t *regs, machine_uint_t hea
void gc_collect(void) {
uint32_t start = sys_tick_counter;
gc_collect_start();
- gc_collect_root((void**)&_ram_start, ((uint32_t)&_heap_start - (uint32_t)&_ram_start) / 4);
+ gc_collect_root((void**)&_ram_start, (&_heap_start - &_ram_start) / 4);
machine_uint_t regs[10];
- gc_helper_get_regs_and_clean_stack(regs, HEAP_END);
- gc_collect_root((void**)HEAP_END, (RAM_END - HEAP_END) / 4); // will trace regs since they now live in this function on the stack
+ gc_helper_get_regs_and_clean_stack(regs, (machine_uint_t)&_heap_end);
+ gc_collect_root((void**)&_heap_end, (&_ram_end - &_heap_end) / 4); // will trace regs since they now live in this function on the stack
gc_collect_end();
uint32_t ticks = sys_tick_counter - start; // TODO implement a function that does this properly
diff --git a/stm/gccollect.h b/stm/gccollect.h
index 6467ec7d21..9187f0e9df 100644
--- a/stm/gccollect.h
+++ b/stm/gccollect.h
@@ -1,8 +1,7 @@
-#define HEAP_END (0x2001c000) // tunable
-#define RAM_END (0x20020000) // fixed for chip
-
extern uint32_t _ram_start;
extern uint32_t _heap_start;
+extern uint32_t _ram_end;
+extern uint32_t _heap_end;
void gc_collect(void);
diff --git a/stm/main.c b/stm/main.c
index 9fc9633ff2..9f2b6d564a 100644
--- a/stm/main.c
+++ b/stm/main.c
@@ -206,12 +206,14 @@ static mp_obj_t pyb_info(void) {
return mp_const_none;
}
+#if MICROPY_HW_HAS_SDCARD
// SD card test
static mp_obj_t pyb_sd_test(void) {
extern void sdio_init(void);
sdio_init();
return mp_const_none;
}
+#endif
static void SYSCLKConfig_STOP(void) {
/* After wake-up from STOP reconfigure the system clock */
@@ -594,7 +596,7 @@ int main(void) {
soft_reset:
// GC init
- gc_init(&_heap_start, (void*)HEAP_END);
+ gc_init(&_heap_start, &_heap_end);
// Micro Python init
qstr_init();
diff --git a/stm/stm32f405.ld b/stm/stm32f405.ld
index fbfc584f9d..5cef201a9a 100644
--- a/stm/stm32f405.ld
+++ b/stm/stm32f405.ld
@@ -19,6 +19,9 @@ _minimum_heap_size = 16K;
/* top end of the stack */
_estack = ORIGIN(RAM) + LENGTH(RAM);
+_ram_end = 0x20020000;
+_heap_end = 0x2001c000;
+
/* define output sections */
SECTIONS
{