3 Commits

Author SHA1 Message Date
a81c04e485 Merge branch 'master' into stack-debug 2012-10-08 16:21:52 -04:00
bb82d588fb Build for atmega32u2 2012-10-04 16:48:01 -04:00
bfaf3010e6 Add some debugging to figure out stack usage 2012-10-04 14:24:32 -04:00
4 changed files with 64 additions and 1 deletions

View File

@@ -13,6 +13,7 @@ SRC = \
main.c \
ftdi.c \
reset.c \
stack.c \
$(LUFA_SRC_USB)
# Default target

6
main.c
View File

@@ -9,6 +9,7 @@
#include <LUFA/Drivers/USB/USB.h>
#include "ftdi.h"
#include "stack.h"
static void setup(void)
{
@@ -36,7 +37,10 @@ int main(void)
c = getchar();
/* If FTDI_NONBLOCKING was provided to ftdi_init,
c will be -1 if no data was available. */
if (c >= 0)
if (c >= 0) {
printf("You sent %d (%c)\n", c, isprint(c) ? c : '?');
printf("Maximum stack space used: %d / %d bytes\n",
(stack_total() - stack_min()), stack_total());
}
}
}

46
stack.c Normal file
View File

@@ -0,0 +1,46 @@
#include "stack.h"
#include <stdint.h>
#include <avr/interrupt.h>
extern uint8_t _end;
extern uint8_t __stack;
void __stack_canary_init(void)
__attribute__ ((naked))
__attribute__ ((section (".init1")));
void __stack_canary_init(void)
{
__asm volatile (" ldi r30,lo8(_end)\n"
" ldi r31,hi8(_end)\n"
" ldi r24,lo8(0xaa)\n" // canary
" ldi r25,hi8(__stack)\n"
" rjmp 2f\n"
"1:\n"
" wdr\n"
" st Z+,r24\n"
"2:\n"
" cpi r30,lo8(__stack)\n"
" cpc r31,r25\n"
" brlo 1b\n"
" breq 1b"
:
:
: "memory");
}
/* return low level mark of free stack space */
uint16_t stack_min(void)
{
const uint8_t *p;
uint16_t c = 0;
for (p = &_end; *p == 0xaa && p <= &__stack; p++)
c++;
return c;
}
/* return total amount of stack */
uint16_t stack_total(void)
{
return &__stack - &_end;
}

12
stack.h Normal file
View File

@@ -0,0 +1,12 @@
#ifndef STACK_H
#define STACK_H
#include <stdint.h>
/* return low level mark of free stack space */
uint16_t stack_min(void);
/* return total amount of stack */
uint16_t stack_total(void);
#endif