HAL_AVR: moved memcheck into HAL_AVR

This commit is contained in:
Andrew Tridgell 2013-12-28 14:50:42 +11:00
parent efc7f88e4b
commit 36e06a1709
2 changed files with 8 additions and 10 deletions

View File

@ -1,4 +1,7 @@
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*- /// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
/*
keep track of available memory on AVR
*/
/* /*
* note that we use a 32 bit sentinel to reduce the chance * note that we use a 32 bit sentinel to reduce the chance
@ -7,7 +10,8 @@
#include <stdlib.h> #include <stdlib.h>
#include <stdint.h> #include <stdint.h>
#include <AP_HAL_Boards.h>
#if (CONFIG_HAL_BOARD == HAL_BOARD_APM1 || CONFIG_HAL_BOARD == HAL_BOARD_APM2)
static const uint32_t *stack_low; static const uint32_t *stack_low;
extern unsigned __brkval; extern unsigned __brkval;
@ -28,7 +32,7 @@ static __attribute__((noinline)) const uint32_t *current_stackptr(void)
* deep stack usage. It should be caught by the sentinel, but this * deep stack usage. It should be caught by the sentinel, but this
* is an added protection * is an added protection
*/ */
void memcheck_update_stackptr(void) static void memcheck_update_stackptr(void)
{ {
if (current_stackptr() < stack_low) { if (current_stackptr() < stack_low) {
uintptr_t s = (uintptr_t)(current_stackptr() - STACK_OFFSET); uintptr_t s = (uintptr_t)(current_stackptr() - STACK_OFFSET);
@ -41,7 +45,6 @@ void memcheck_update_stackptr(void)
*/ */
void memcheck_init(void) void memcheck_init(void)
{ {
#if CONFIG_HAL_BOARD == HAL_BOARD_APM1 || CONFIG_HAL_BOARD == HAL_BOARD_APM2
uint32_t *p; uint32_t *p;
free(malloc(1)); // ensure heap is initialised free(malloc(1)); // ensure heap is initialised
stack_low = current_stackptr(); stack_low = current_stackptr();
@ -49,7 +52,6 @@ void memcheck_init(void)
for (p=(uint32_t *)(stack_low-1); p>(uint32_t *)__brkval; p--) { for (p=(uint32_t *)(stack_low-1); p>(uint32_t *)__brkval; p--) {
*p = SENTINEL; *p = SENTINEL;
} }
#endif
} }
/* /*
@ -58,13 +60,11 @@ void memcheck_init(void)
*/ */
unsigned memcheck_available_memory(void) unsigned memcheck_available_memory(void)
{ {
#if CONFIG_HAL_BOARD == HAL_BOARD_APM1 || CONFIG_HAL_BOARD == HAL_BOARD_APM2
memcheck_update_stackptr(); memcheck_update_stackptr();
while (*stack_low != SENTINEL && stack_low > (const uint32_t *)__brkval) { while (*stack_low != SENTINEL && stack_low > (const uint32_t *)__brkval) {
stack_low--; stack_low--;
} }
return (uintptr_t)(stack_low) - __brkval; return (uintptr_t)(stack_low) - __brkval;
#else
return 0x1000;
#endif
} }
#endif // CONFIG_HAL_BOARD

View File

@ -2,5 +2,3 @@
unsigned memcheck_available_memory(void); unsigned memcheck_available_memory(void);
void memcheck_init(void); void memcheck_init(void);
void memcheck_update_stackptr(void);