gcc - 重新定义gcc-arm-none-eabi的stdlibc的一些功能
问题描述
STM32 芯片(和许多其他芯片)具有硬件随机数生成器(RNG),它比 libc 提供的软件 RNG 更快、更可靠。编译器对硬件一无所知。
有没有办法重新定义实现rand()
?
还有其他硬件模块,即实时时钟 (RTC),可以为time()
.
解决方案
您只需通过定义具有相同签名的函数来覆盖它们。如果它们是WEAK
在标准库中定义的,它们将被覆盖,否则它们会在第一次解析的基础上被覆盖,只要在搜索 libc之前将您的实现传递给链接器,它将被覆盖。此外 .o / .obj 文件在 .a / .lib 文件之前专门用于符号解析,因此如果您的实现包含在项目源代码中,它将始终覆盖。
您应该小心确保实现的语义正确。例如rand()
返回一个有符号整数 0 到 RAND_MAX,这可能与 RNG 硬件不同。由于 RAND_MAX 是一个宏,因此更改它需要更改标准标头,因此您的实现需要强制执行现有的 RAND_MAX。
使用 STM32 标准外设库的示例:
#include <stdlib.h>
#include <stm32xxx.h> // Your processor header here
#if defined __cplusplus
extern "C"
{
#endif
static int rng_running = 0 ;
int rand( void )
{
if( rng_running == 0 )
{
RCC_AHB2PeriphClockCmd(RCC_AHB2Periph_RNG, ENABLE);
RNG_Cmd(ENABLE);
rng_running = 1 ;
}
while(RNG_GetFlagStatus(RNG_FLAG_DRDY)== RESET) { }
// Assumes RAND_MAX is an "all ones" integer value (check)
return (int)(RNG_GetRandomNumber() & (unsigned)RAND_MAX) ;
}
void srand( unsigned ) { }
#if defined __cplusplus
}
#endif
对于类似的应用,在Problem with time() function in Embedded application with C 中time()
有一个示例