keil 配置栈溢出保护(arm)
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
原文地址:https://blog.csdn.net/haidscs/article/details/142994526
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!