相关疑难解决方法(0)

冲突的函数声明和宏?

我在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中定义的函数?

c linux-kernel

5
推荐指数
1
解决办法
93
查看次数

ARM Cortex-M3启动代码

我正在尝试理解初始化代码如何与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堆栈架构的解释都会很棒.

embedded arm cpu-architecture cortex-m3

2
推荐指数
1
解决办法
2458
查看次数

标签 统计

arm ×1

c ×1

cortex-m3 ×1

cpu-architecture ×1

embedded ×1

linux-kernel ×1