我在linux内核中查看这个头文件:https: //elixir.bootlin.com/linux/v4.14/source/arch/x86/boot/string.h
#ifndef BOOT_STRING_H
#define BOOT_STRING_H
/* Undef any of these macros coming from string_32.h. */
#undef memcpy
#undef memset
#undef memcmp
void *memcpy(void *dst, const void *src, size_t len);
void *memset(void *dst, int c, size_t len);
int memcmp(const void *s1, const void *s2, size_t len);
#define memcpy(d,s,l) __builtin_memcpy(d,s,l)
#define memset(d,c,l) __builtin_memset(d,c,l)
#define memcmp __builtin_memcmp
...
#endif /* BOOT_STRING_H */
Run Code Online (Sandbox Code Playgroud)
我无法弄清楚#undef +函数声明+宏在memcpy,memset和memcmp上的定义是什么.例如,它首先声明一个函数memcpy,然后在此之后定义一个宏memcpy.我不确定这是什么目的.我发现这个函数在这里定义:https://elixir.bootlin.com/linux/v4.14/source/arch/x86/boot/copy.S#L20.如果代码中的某个地方使用memcpy(例如这里:https://elixir.bootlin.com/linux/v4.14/source/arch/x86/boot/main.c#L40)使用memcpy它使用什么?copy.S或__builtin_memcpy中定义的函数?
我正在尝试理解初始化代码如何与Keil(realview v4)一起用于STM32微控制器.具体来说,我试图了解堆栈是如何初始化的.
在ARM网站上的文档中,它提到startup_xxx.s中的一个例程,__user_initial_stack_heap不应该使用超过88个字节的堆栈.你知道这个限制来自哪里吗?
似乎当重置处理程序调用System_Init时,它正在C环境中执行一些函数,我相信这意味着它正在使用某种形式的临时堆栈(它分配了一些自动变量).但是,所有这些堆栈项目一旦返回就应该超出范围,然后调用从__main哪里__user_initial_stack_heap调用.
那么为什么__user_initial_stack_heap不要使用超过88个字节的这个要求呢?剩下的__main使用了大量的堆栈还是什么?
任何与启动序列相关的cortex-m3堆栈架构的解释都会很棒.