打造一个通用性MCU架构,支持CX32/AT32/NRF51/NRF52等。 OS支持RTX4/RTX5/FreeRtos。 采用VsCode+GCC组合,VsCode+KEIL5,超强开发方式。 QQ群:524408033

LiSun

打造一个通用性MCU架构,支持CX32/AT32/NRF51/NRF52等。 OS支持RTX4/RTX5/FreeRtos。 采用VsCode+GCC组合,VsCode+KEIL5,超强开发方式。 QQ群:524408033

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

RNG — 随机数生成器

随机数生成器(RNG)基于适合于加密目的的内部热噪声生成真正的非确定性随机数。 RNG不需要种子值。
图58:随机数生成器
通过触发START任务启动RNG,通过触发STOP任务停止RNG。 当启动时,新的随机数将连续生成,并在准备就绪时写入VALUE寄存器。 每个写入VALUE寄存器的新随机数都会生成一个VALRDY事件。 这意味着在生成VALRDY事件后,CPU有时间直到下一个VALRDY事件从VALUE寄存器读出随机数,然后再被一个新的随机数覆盖。

偏差纠正

在内部比特流上使用偏差校正算法,以消除对’1’或’0’的任何偏差。 然后,这些位被排到一个8位寄存器中,以便从VALUE寄存器并行读出。 可以在CONFIG寄存器中启用偏差校正。 这将导致较慢的值生成,但将确保随机值的统计均匀分布。

速度

生成一个随机字节数据所需的时间是不可预测的,并且可能随字节的不同而变化。 当启用偏差校正时尤其如此。

/********************************************************************************
* @file    bsp_rng.c
* @author  jianqiang.xue
* @version V1.0.0
* @date    2021-07-09
* @brief   随机数生成
********************************************************************************/
/* Includes ------------------------------------------------------------------*/
#include <stdint.h>
#include <stdbool.h>

#include "RTE_Components.h"
#include CMSIS_device_header

#include "nrf_rng.h"
#include "nrf_error.h"

#include "bsp_rng.h"

/* Private function prototypes -----------------------------------------------*/
/**
 * @brief  启动硬件随机数,并返回一个随机数值
 * @note   NULL
 * @retval 0-255 随机数
 */
static uint8_t get_random_vector(void)
{
    uint8_t value;

    NRF_RNG->CONFIG      = 1;
    NRF_RNG->TASKS_START = 1;
    // 生成新的随机数并写入VALUE寄存器。
    NRF_RNG->EVENTS_VALRDY = 0;
    while (NRF_RNG->EVENTS_VALRDY == 0)
    {
    }
    value = NRF_RNG->VALUE;
    NRF_RNG->TASKS_STOP = 1;
    NRF_RNG->INTENCLR   = 0;
    NRF_RNG->CONFIG     = 0;
    return value;
}

/**
 * @brief  得到一组随机数
 * @note   NULL
 * @param  *pbuff: 缓存区
 * @param  size: 数量
 * @retval None
 */
void random_vector_generate(uint8_t *pbuff, uint8_t size)
{
    uint8_t i;

    for (i = 0; i < size; i++)
    {
        pbuff[i] = get_random_vector();
    }
}

/********************************************************************************
* @file    bsp_rng.h
* @author  jianqiang.xue
* @version V1.0.0
* @date    2021-07-09
* @brief   随机数生成
********************************************************************************/

#ifndef __BSP_RNG_H
#define __BSP_RNG_H

/* Includes ------------------------------------------------------------------*/
#include <stdint.h>

/* Public Function Prototypes ------------------------------------------------*/

void random_vector_generate(uint8_t * pbuff, uint8_t size);
#endif

posted on 2022-08-13 11:00  xuejianqiang  阅读(50)  评论(0编辑  收藏  举报
打造一个通用性MCU架构,支持CX32/AT32/NRF51/NRF52等。 OS支持RTX4/RTX5/FreeRtos。 采用VsCode+GCC组合,VsCode+KEIL5,超强开发方式。 QQ群:524408033