gpt4 book ai didi

c - LINKER脚本GCC如何避免单板调用

转载 作者:太空宇宙 更新时间:2023-11-04 04:12:06 25 4
gpt4 key购买 nike

我在项目中将一些函数从 FLASH 复制到 RAM 并调用它们。一切正常,除了我遇到的一个小问题 - 如果我直接调用函数,编译器会改为添加 veneer 调用(它会正确调用 RAM 中的函数)。

如果我通过指针调用它,一切都可以。调试器显示函数的解析地址是正确的。

#define RAMFCALL(func, ...)   {unsigned (* volatile fptr)() =  (unsigned (* volatile)())func; fptr(__VA_ARGS__);}

RAMFCALL(FLASH_EraseSector, 0, 0);
FLASH_EraseSector(0,0);

和相应的调用:

 311        RAMFCALL(FLASH_EraseSector, 0, 0);
0801738e: ldr r3, [pc, #88] ; (0x80173e8 <flashSTMInit+140>)
08017390: str r3, [sp, #12]
08017392: ldr r3, [sp, #12]
08017394: movs r1, #0
08017396: mov r0, r1
08017398: blx r3
312 FLASH_EraseSector(0,0);
0801739a: movs r1, #0
0801739c: mov r0, r1
0801739e: bl 0x801e9f0 <__FLASH_EraseSector_veneer>

调试器显示正确的地址。

enter image description here

和链接描述文件的相应部分

  OVERLAY : NOCROSSREFS
{
.RAM_functions
{
. = ALIGN(512);
RAM_functions_load = LOADADDR(.RAM_functions);
PROVIDE(RAM_VectorTable_start = .);
KEEP(*(.RAM_VectorTable))
KEEP(*(.RAM_VectorTable*))
PROVIDE(RAM_VectorTable_end = .);

. = ALIGN(4);
RAM_functions_start = .;
KEEP(*(.RAM_functions))
KEEP(*(.RAM_functions*))
RAM_functions_end = .;

. = ALIGN(4);
RAM_functionsDATA_start = .;
KEEP(*(.RAM_functionsDATA))
KEEP(*(.RAM_functionsDATA*))
RAM_functionsDATA_end = .;
. = ALIGN(4);
RAM_functionsBUFFER_start = .;
}

/* used by the startup to initialize data */

/* Initialized data sections goes into RAM, load LMA copy after code */
.data
{
. = ALIGN(4);
_sdata = .; /* create a global symbol at data start */
*(.data) /* .data sections */
*(.data*) /* .data* sections */

. = ALIGN(4);
_edata = .; /* define a global symbol at data end */
}
}>RAM AT> FLASH

又是一个问题:如何去除单板调用

最佳答案

我会自己回答,因为我找到了原因:)

bl指令相对于PC是+=32MB。我是从 FLASH 调用 RAM 中的函数,实际距离远超过 32MB。因此链接器必须放置胶合函数调用。

关于c - LINKER脚本GCC如何避免单板调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56019518/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com