1.前提是keil 配置为arm-gcc 编译器环境
2.配置编译项加上 -fstack-protector-strong
栈溢出的测试代码:
void aaa(int a, char c)
{
char arr[5];
arr[a] = c;
}aaa(8, 'd');//任意地方调用,超过数组arr的元素
添加代码栈溢出检测:
uint32_t __stack_chk_guard = 0xdeadbeef;//判断这值是否被改
void __stack_chk_fail(void)
{
while(1);//当检测到栈溢出,跳进死循环
}
3.对比加不加编译参数选项汇编文件差异:
反汇编的生成指令:
arm-none-eabi-objdump.exe --source --all-headers --demangle --file-headers --line-numbers --wide .\stm32f207.elf > astack.txt