我在编译过程中发现了以下错误
(.sram.text+0x1283):危险的迁移:加窗的长调用跨越1GB的边界;返回可能失败:(UND+0xdeadcafe)
在其中一个功能中。
体系结构是Xtensa,使用的工具链是为Xtensa构建的GNU工具链。此错误位于binutils源代码中文件elf32-xtensa.c中的函数elf_xtensa_do_reloc()中。
请让我知道这个错误的原因和任何可能的解决办法。
发布于 2015-11-19 17:36:06
这是已知的默认Xtensa窗口注册ABI的警告。引用Xtensa ISA参考手册
在
a4中使用返回地址寄存器存储的窗口增量占据寄存器的两个最重要的位,因此这些位必须由子例程返回来填充。RETW和RETW.N指令从它们自己地址中最重要的两个位中填充这些位。这将防止寄存器窗口调用用于调用地址空间中不同的1GB区域中的例程。
您可以有两个选项来解决这个问题:
发布于 2022-05-16 22:25:04
在为ESP32进行PlatformIO开发时遇到同样的错误之后,我发现的解决方案是将优化叠氮标志从-Os更改为-O3。
[env:esp32dev]
build_unflags = -Os
build_flags = -O3https://stackoverflow.com/questions/31049837
复制相似问题