0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

技术分享 | 随机数生成过慢导致系统阻塞怎么办?

启扬ARM嵌入式开发 2022-08-15 09:20 次阅读

/dev/random和/dev/urandom是linux上的随机数生成器,是个字符设备,为系统提供随机数。随机数主要应用在加密方面,没有加密的操作都是可预测且不安全的。

linux上随机数的生成原理

linux上随机数的生成原理是将系统的中断信息收集起来放入熵池中,通过算法生成更多无序的数据,有了大量的无序数据之后,每次获取随机数,就会从池子中读取指定的字节序列,而这些字节序列就是生成器生成的随机数。

linux开机时就会伴随着random设备的初始化,一般我们经常会遇见这两条log:

random: crng init done,

random: 7 urandom warning(s) missed due to ratelimiting,

这说明随机数已经初始化完成,可以随时请求使用。但是在某些时候会卡在这个log很长时间,这是因为在开机时系统中断不够或程序运行时熵不足,生成随机数非常缓慢,导致阻塞,进而导致无法开机、app无法正常运行等一系列bug。

为了解决这个问题,我们可以移植一个工具对熵池进行补熵,这样随机数生成器就会快速生成随机数,解决阻塞导致的一系列问题。

解决方案

解决这个问题的工具有很多,这里我们选用移植haveged工具,并使用启扬IAC-IMX8MM-kit开发板展示具体操作过程。

移植haveged-1.9.3

首先source我们的sdk开发环境,然后进入到源码内,通过configure配置makfile文件,命令如下:

./configure --host=aarch64-poky-linux --prefix=/home/ylook/haveged

配置完成后执行make && make install命令,会在/home/ylook/haveged目录下生成编译完成后的二进制文件以及相关库文件,如下图所示:

(注:笔者路径有所不同,根据环境自行更改即可)

279007a6-1a5a-11ed-9ade-dac502259ad0.png

注意:

为防止错误,可以使用file命令检查二进制文件架构,保证为aarch64架构即可。

将编译出来的二进制文件拷贝到板子的/usr/bin/目录,库文件拷贝到/usr/lib/目录,执行haveged --h命令,如下图所示:

27b356a2-1a5a-11ed-9ade-dac502259ad0.png

这里就相当于我们已经把板子里的环境配置好了,为了能够开机就使用该工具生成熵,所以我们需要在开机进程中将该工具设置为自动运行。

因为启扬i.MX8M Mini开发板上使用systemed工具配置相关服务,所以我们需要写一个service,然后让它开机运行,具体service如下:

27cc616a-1a5a-11ed-9ade-dac502259ad0.png

使用systemctl enable haveged之后重启就会生效,可从开机log中看出,如图所示,在很早之前初始化就已经完成了。

27efc4e8-1a5a-11ed-9ade-dac502259ad0.png

也可以使用命令cat /proc/sys/kernel/random/entropy_avail,查看当前熵值,在没有haveged之前该值只有几十几百,而开启之后有几千。

281a6a90-1a5a-11ed-9ade-dac502259ad0.png

这样,就完美解决了随机数生成过慢导致系统阻塞的问题。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 生成器
    +关注

    关注

    7

    文章

    302

    浏览量

    20239
收藏 人收藏

    评论

    相关推荐

    如何使用Python生成四位随机数

    为了实现这些目标,Python 为我们提供了random() 模块。random() 是一个内置的 Python 模块,用于生成随机数
    的头像 发表于 04-15 12:47 150次阅读

    请问rt-thread studio如何使用硬件随机数生成器?

    指导一下。 经过查询得知可以使用rt_hw_random_get()函数来获取硬件随机数,请文需要做什么配置才能使用rt_hw_random_get()函数。
    发表于 02-23 08:03

    用rand形成的不是真正的随机数,怎么才能达到真正的随机?

    用rand形成的不是真正的随机数啊,,怎么才能达到真正的随机
    发表于 10-30 06:14

    单片机是如何产生随机数的?

    单片机如何产生随机数
    发表于 10-27 06:44

    AT32的随机数的产生

    AT32的随机数的产生为设计者使用AT32芯片时,产生符合应用需求的随机数,提供设计建议。
    发表于 10-26 06:04

    STM8有随机数发生器吗?

    怎么才能用STM8产生一个随机数
    发表于 10-23 06:55

    如何使用雪花算法生成真正的随机数

    下的熵池,所谓熵池就是当前系统下的环境噪音,描述了一个系统的混乱程度,环境噪音由这几个方面组成,如内存的使用,文件的使用量,不同类型的进程数量等等。 利用/dev/urandom可以生成随机数
    的头像 发表于 10-09 10:05 761次阅读

    FPGA的伪随机数发生器学习介绍

    随机试验的结果,产生随机数有多种不同的方法。这些方法被称为随机数生成器。随机数最重要的特性是它在产生时后面的那个数与前面的那个数毫无关系。
    的头像 发表于 09-12 09:13 794次阅读

    STM32L4随机数生成器模块(RNG)介绍

    基于噪声源的32位真随机数生成器。 •使用线性反馈移位寄存器进行后处理。 •由专用时钟(PLL48CLK)计时 •两个连续随机数之间的PLL48CLK时钟信号的40个周期 •可禁用以降低功耗 •5个
    发表于 09-11 07:29

    Arm真随机数发生器(TRNG)表征应用说明

    本章概述ARM®真随机数生成器(TRNG)及其特性。 ARM®真随机数生成器(TRNG)从物理熵源收集熵,物理熵源是能够生成不可预测或
    发表于 08-29 07:19

    Arm真随机数生成器固件接口1.0平台设计文件

    本文档定义了操作系统(OS)和提供条件熵源的TRNG FW实现之间的接口。 条件熵通常用于种子确定随机数生成器或生成密钥,以及其他用例。 本文件认为TRNG FW实施由以下要素组成:
    发表于 08-11 07:26

    i.MX8QM真随机数生成器符合什么要求?

    大家好, 我们的客户要求我们指定一个真正的随机数生成器。 i.MX8QM 真随机数生成器符合什么要求? 以下是对 SE050 中的随机数
    发表于 05-18 06:13

    【野火 fireFlasher Mini 脱机烧录器】随机数测试

    随机数测试 野火mini脱机烧录器支持在指定地址添加指定个数的随机数,最多支持4组,每组4096个随机数。本篇来测试一下随机数的功能。 小试牛刀 先简单测试一下,在地址0x080040
    发表于 05-12 21:42

    【野火 fireFlasher Mini 脱机烧录器】3. 随机数功能测试以及遇到的问题

    fireFlasher Mini 脱机烧录器】1. 上手实测。 在烧录固件到单片机的过程中,会比单独烧录LED.axf慢一些,我猜测是因为随机数是在烧录固件到单片机的时候才生成的,所以会比较慢一点,后边实测也验证了
    发表于 05-07 22:05

    S32K312如何获取随机数

    S32K312如何获取随机数
    发表于 05-06 07:46