STM32F4X RNG随机数发生器

STM32F4X RNG随机数发生器

随机数的作用

随机数顾名思义就是随机产生的数字,这种数字最大的特点就是其不确定性,你不知道它下一次产生的数字是什么。随机数被广泛应用于密码学、模拟实验、游戏开发领域等。

STM32F4X 随机数发生器

RNG控制寄存器


RNG的控制寄存器的bit0使能随机数发生器是否工作,bit1则使能是否使用中断

RNG状态寄存器


状态寄存器是判断随机数发生器工作是否正常,通过判断状态寄存器的位可以知道随机数是否产生是否正确

RNG数据寄存器

如果上面的随机数的状态寄存器里面的状态都没有异常,而且数据已经准备就绪了,用户就可以读取数据寄存器把随机数读出来。

RNG数据步骤

STM32F4X的数据手册给出了随机数发生器的使用步骤

RNG例程

c 复制代码
#include "rng.h"



void rng_init(void)
{
	NVIC_InitTypeDef NVIC_InitStruct;
	
	RCC_AHB2PeriphClockCmd(RCC_AHB2Periph_RNG,ENABLE); // 使能RNG时钟
	
#ifdef RNG_INIT
	NVIC_InitStruct.NVIC_IRQChannel = HASH_RNG_IRQn; //  中断编号
	NVIC_InitStruct.NVIC_IRQChannelPreemptionPriority = 2; // 抢占优先级为1
	NVIC_InitStruct.NVIC_IRQChannelSubPriority =  2; // 响应优先级为1
	NVIC_InitStruct.NVIC_IRQChannelCmd = ENABLE; // 使能中断
	NVIC_Init(&NVIC_InitStruct); // 初始化中断
	RNG_ITConfig(ENABLE);
	
#endif	
	RNG_Cmd(ENABLE);
	
	
}

uint32_t get_rng_randomdata(void)
{
	static uint32_t first_random_num = 0,second_random_num = 0,count = 0;

	if(RNG_GetFlagStatus(RNG_FLAG_CECS | RNG_FLAG_SECS) == RESET) // 判断CECS 和 SECS
	{
		if(RNG_GetFlagStatus(RNG_FLAG_DRDY) == SET) // 判断随机数是都准备好
		{
			count++;
			if (count >= 0xFFFFFFFF)
				count = 0;
			if (count == 1)
				return;
			
			second_random_num = first_random_num;
			first_random_num = RNG_GetRandomNumber(); // 读取随机数
			if(first_random_num != second_random_num) // 本次生成的随机数跟上一次生成的随机数对比
				printf("random create success %8X %8X\r\n",first_random_num,second_random_num);
			else 
				printf("random create fail \r\n");
		}

		RNG_ClearFlag(RNG_FLAG_CECS | RNG_FLAG_SECS);
			
	}
	return 0;
}
	
void HASH_RNG_IRQHandler(void)
{
	static uint32_t first_random_num = 0,second_random_num = 0,count = 0;
	if(RNG_GetITStatus(RNG_IT_CEI | RNG_IT_SEI) == RESET)
	{
		if(RNG_GetFlagStatus(RNG_FLAG_DRDY) == SET)
		{
			count++;
			if (count >= 0xFFFFFFFF)
				count = 0;
			if (count == 1)
				return;
			
			second_random_num = first_random_num;
			first_random_num = RNG_GetRandomNumber(); // 读取随机数
			if(first_random_num != second_random_num) // 本次生成的随机数跟上一次生成的随机数对比
				printf("random create success %8X %8X\r\n",first_random_num,second_random_num);
			else 
				printf("random create fail \r\n");
		}
		RNG_ClearITPendingBit(RNG_IT_CEI | RNG_IT_SEI);
		
	}
		
		
}
相关推荐
望云山1908 分钟前
ESP32—S3学习--入门五个基础实验
嵌入式硬件·学习
wit_yuan9 分钟前
openbmc 支持mctp over pcie(三)(支持作为endpoint)
linux·服务器·嵌入式硬件
小郭团队13 分钟前
1_2_五段式SVPWM (传统算法反正切+DPWMmin)算法理论与 MATLAB 实现详解
开发语言·嵌入式硬件·matlab·dsp开发
小郭团队16 分钟前
1_3_五段式SVPWM (传统算法反正切+DPWMmax)算法理论与 MATLAB 实现详解
开发语言·嵌入式硬件·matlab·dsp开发
2301_7722042820 分钟前
51单片机——UART
单片机·嵌入式硬件·51单片机
Zeku30 分钟前
Linux应用与驱动开发:mmap和内存映射
stm32·freertos·linux驱动开发·linux应用开发
qq_4112624231 分钟前
如果 4G 模块的 UART TX 高电平真的是 3.7V,直接接到 ESP32 的 UART RX/GPIO 不建议,存在风险。
单片机·嵌入式硬件
电化学仪器白超40 分钟前
计量室电路板长期稳定性自动化测试系统开发与部署
python·单片机·嵌入式硬件·自动化
小郭团队1 小时前
1_1_七段式SVPWM (传统算法反正切)算法理论与 MATLAB 实现详解
人工智能·stm32·嵌入式硬件·算法·dsp开发
松涛和鸣1 小时前
DAY53 UART Serial Communication
c语言·单片机·嵌入式硬件·tcp/ip·51单片机