当前位置: 首页 > article >正文

STM32无硬件RNG时,如何利用ADC噪声与DMA高效生成真随机数

1. 为什么STM32需要真随机数在嵌入式开发中随机数的应用场景远比我们想象的广泛。比如智能家居设备的配对码生成、工业控制中的防碰撞算法、物联网设备的密钥协商等场景都需要高质量的随机数。我遇到过最典型的案例是一个智能门锁项目由于使用简单的伪随机数算法导致密码组合可预测差点造成安全隐患。传统伪随机数算法如rand()的问题在于它们的确定性。就像用固定公式计算数列只要知道初始种子和算法就能预测后续所有数值。曾经有个学生问我用系统时钟做种子不就能保证随机性吗实测发现如果攻击者能推测设备启动时间仍然可以缩小预测范围。这就是为什么金融级应用必须使用真随机数。2. ADC噪声的随机性原理2.1 电子噪声的本质ADC模数转换器的底噪就像老式收音机的沙沙声这种噪声来源于电子的热运动。我在实验室用示波器观察过即使给ADC输入恒定电压最低两位数据也会像跳舞一样不停跳动。这种微观层面的量子效应正是真随机性的物理基础。具体到STM32的ADC模块有三个关键特性可以利用量化误差12位ADC实际有效位通常只有10-11位热噪声电阻和半导体器件的电子热运动电源噪声LDO稳压器输出的微小波动2.2 硬件连接方案最简单的实现只需要两个元件// 硬件连接示意图 VCC ━┳━ 10kΩ ━━━━━━┓ ┗━━━━━┓ ┃ ADC_IN ┣━ 100nF电容到地 GND ━━━━━━━━━━━━━━┛这个分压电路会产生约1.65V的中间电压但实际测量时会发现ADC值在±3LSB范围内波动。我对比过不同型号的STM32发现F1系列的噪声比H7系列更明显这反而成了我们的优势。3. DMA采集方案优化3.1 传统轮询方式的瓶颈早期我尝试过直接轮询ADCuint32_t get_random_byte() { uint8_t result 0; for(int i0; i8; i) { HAL_ADC_Start(hadc1); HAL_ADC_PollForConversion(hadc1, 10); result | (HAL_ADC_GetValue(hadc1) 0x01) i; } return result; }实测发现生成1字节需要约56us72MHz主频这在实时控制系统中根本无法接受。3.2 DMA双缓冲技巧后来改进的方案采用DMA循环采集双缓冲#define SAMPLE_SIZE 256 uint16_t adc_buf1[SAMPLE_SIZE], adc_buf2[SAMPLE_SIZE]; void ADC_Init() { // DMA配置 hdma_adc1.Instance DMA1_Channel1; hdma_adc1.Init.Mode DMA_CIRCULAR; hdma_adc1.Init.MemoryDataSize DMA_MDATAALIGN_HALFWORD; // 其他配置省略... HAL_ADC_Start_DMA(hadc1, (uint32_t*)adc_buf1, SAMPLE_SIZE); } uint32_t get_random_bulk() { static uint32_t pool 0; static int bit_pos 0; if(bit_pos 32) { bit_pos 0; pool 0; } // 取最低位噪声 pool | (adc_buf1[bit_pos] 0x01) bit_pos; bit_pos; return pool; }这种方案将CPU占用率从原来的90%降到不足3%实测生成速度达到1.2Mbps完全满足大多数应用需求。4. 随机性增强处理4.1 冯·诺依曼校正原始ADC噪声可能存在偏差比如60%的概率为1我们可以用经典算法处理uint8_t von_neumann(uint16_t raw) { static uint8_t last 0; static uint8_t count 0; if((raw 0x03) 0x01) return 0; if((raw 0x03) 0x02) return 1; return -1; // 丢弃无效组合 }这个算法会损失约50%的原始数据但能保证输出比特的均匀分布。我在智能电表项目中实测处理后通过所有NIST随机性测试。4.2 混合熵池设计更完善的方案可以结合多种熵源typedef struct { uint32_t adc_noise; uint32_t jitter; uint32_t interrupt_timing; } entropy_pool; void feed_entropy(entropy_pool* pool) { // 获取ADC噪声 pool-adc_noise (pool-adc_noise 1) | (get_adc_sample() 0x01); // 利用定时器抖动 uint32_t t TIM2-CNT; pool-jitter ^ (t 16) | (t 16); // 外部中断时间熵 if(exti_triggered) { pool-interrupt_timing TIM2-CNT; exti_triggered 0; } }这种设计类似Linux的/dev/random实现我在一个区块链终端设备上应用成功通过FIPS 140-2认证。5. 实际应用中的坑与技巧5.1 电源噪声的影响有一次客户反映随机数质量不稳定排查发现是他们使用了劣质LDO。解决方法很简单在ADC输入引脚并联100nF1μF电容避免与无线模块共用电源在PCB布局时让ADC走线远离高频信号5.2 温度补偿技巧在-40℃~85℃工业环境测试时发现温度每升高10℃ADC噪声幅度降低约5%。我的应对方案是// 根据温度传感器动态调整采样次数 int get_sample_count() { float temp read_temperature(); return 32 (25 - temp) * 0.5; }这个小技巧保证了全温度范围内的随机性稳定。6. 性能对比测试我用STM32F407做了组对比实验方法生成速度CPU占用NIST通过率纯软件rand()8.4Mbps2%42%ADC轮询0.05Mbps95%98%ADCDMA本文方案1.2Mbps3%99.6%硬件RNG1.8Mbps0.5%100%可以看到我们的方案在真随机性方面接近硬件RNG而CPU占用率仅比伪随机数略高。在需要加密通信的共享单车锁项目中这个方案成功替代了外置加密芯片。

相关文章:

STM32无硬件RNG时,如何利用ADC噪声与DMA高效生成真随机数

1. 为什么STM32需要真随机数? 在嵌入式开发中,随机数的应用场景远比我们想象的广泛。比如智能家居设备的配对码生成、工业控制中的防碰撞算法、物联网设备的密钥协商等场景,都需要高质量的随机数。我遇到过最典型的案例是一个智能门锁项目&am…...

室内无人机自主定位:融合Mid360激光雷达与光流传感器的无GPS导航实践

1. 室内无人机定位的挑战与解决方案 在仓库巡检、隧道勘测等室内场景中,无人机最头疼的问题就是失去GPS信号后的定位难题。传统光流传感器虽然能提供相对运动信息,但在长距离飞行时误差会不断累积;而激光雷达虽然精度高,但单独使用…...

Clion+CubeMX联合开发环境配置全攻略(附ST-Link烧录避坑指南)

ClionCubeMX联合开发环境配置全攻略(附ST-Link烧录避坑指南) 嵌入式开发中,环境配置往往是项目启动的第一道门槛。对于STM32开发者而言,JetBrains的Clion结合ST官方的CubeMX,能够打造出高效且现代化的开发工作流。本文…...

Linux内核中的电源管理技术详解

Linux内核中的电源管理技术详解 引言 电源管理是Linux内核中一项重要的功能,它负责管理系统的电源消耗,提高能源效率,延长设备的电池寿命。随着移动设备和数据中心的普及,电源管理变得越来越重要。Linux内核通过一系列电源管理技术…...

电容是什么?一个“快充快放”的微型充电宝氯

一、前言:什么是 OFA VQA 模型? OFA(One For All)是字节跳动提出的多模态预训练模型,支持视觉问答、图像描述、图像编辑等多种任务,其中视觉问答(VQA)是最常用的功能之一——输入一张…...

从“开盲盒”到“当导演”:我是如何用ControlNet的8个模型,把AI绘画变成精准设计工具的

从“开盲盒”到“当导演”:我是如何用ControlNet的8个模型,把AI绘画变成精准设计工具的 作为一名UI设计师,我曾经对AI绘画又爱又恨。爱的是它能瞬间生成几十种风格的概念图,恨的是这些图总像开盲盒——你永远不知道下一张是惊喜还…...

MySQL锁机制:从全局锁到行级锁的深度解读犊

如果有多个供应商,你也可以使用 [[CC-Switch]] 来可视化管理这些API key,以及claude code 的skills。 # 多平台安装指令 curl -fsSL https://claude.ai/install.sh | bash ## Claude Code 配置 GLM Coding Plan curl -O "https://cdn.bigmodel.cn/i…...

3分钟快速定位Windows热键冲突:Hotkey Detective终极指南

3分钟快速定位Windows热键冲突:Hotkey Detective终极指南 【免费下载链接】hotkey-detective A small program for investigating stolen key combinations under Windows 7 and later. 项目地址: https://gitcode.com/gh_mirrors/ho/hotkey-detective 你是否…...

终极Windows驱动清理指南:DriverStore Explorer轻松释放20GB磁盘空间

终极Windows驱动清理指南:DriverStore Explorer轻松释放20GB磁盘空间 【免费下载链接】DriverStoreExplorer Driver Store Explorer 项目地址: https://gitcode.com/gh_mirrors/dr/DriverStoreExplorer 你是否发现Windows系统盘空间越来越少,却不…...

不用装软件!这款MicroPython浏览器 IDE :让你在手机上也能调试树莓派 Pico汉

1、普通的insert into 如果(主键/唯一建)存在,则会报错 新需求:就算冲突也不报错,用其他处理逻辑 回到顶部 2、基本语法(INSERT INTO ... ON CONFLICT (...) DO (UPDATE SET ...)/(NOTHING)) 语…...

别再傻傻用numpy.convolve了!用FFT卷积给Python音频处理提速10倍(附完整代码)

别再被numpy.convolve拖慢!FFT卷积实战指南:音频处理效率提升10倍 当你在Python中处理音频信号时,是否经历过这样的煎熬——一段3分钟的音频文件,用numpy.convolve做卷积运算竟然要等待近20秒?这种体验就像用拨号上网下…...

Facenet-Pytorch人脸识别实战指南:5步快速构建精准人脸识别系统

Facenet-Pytorch人脸识别实战指南:5步快速构建精准人脸识别系统 【免费下载链接】facenet-pytorch Pretrained Pytorch face detection (MTCNN) and facial recognition (InceptionResnet) models 项目地址: https://gitcode.com/gh_mirrors/fa/facenet-pytorch …...

OpenClaw开源贡献:为Phi-3-mini开发新技能指南

OpenClaw开源贡献:为Phi-3-mini开发新技能指南 1. 为什么选择为Phi-3-mini开发OpenClaw技能? 去年夏天,我在尝试用OpenClaw自动化处理日常工作报告时,发现现有的技能库对小型语言模型的支持相当有限。当时正好接触到微软开源的P…...

Bootstrap Switch 终极指南:如何快速创建现代化切换开关

Bootstrap Switch 终极指南:如何快速创建现代化切换开关 【免费下载链接】bootstrap-switch Turn checkboxes and radio buttons in toggle switches. 项目地址: https://gitcode.com/gh_mirrors/bo/bootstrap-switch Bootstrap Switch 是一款强大的开源工具…...

loadtest WebSocket测试全攻略:实时应用的性能验证方法

loadtest WebSocket测试全攻略:实时应用的性能验证方法 【免费下载链接】loadtest Runs a load test on the selected URL. Fast and easy to use. Can be integrated in your own workflow using the API. 项目地址: https://gitcode.com/gh_mirrors/lo/loadtest…...

IOFILE结构体的介绍与House of orange媚

认识Pass层级结构 Pass范围从上到下一共分为5个层级: 模块层级:单个.ll或.bc文件 调用图层级:函数调用的关系。 函数层级:单个函数。 基本块层级:单个代码块。例如C语言中{}括起来的最小代码。 指令层级:单…...

nlp_structbert_sentence-similarity_chinese-large部署教程:阿里云PAI-EAS一键部署全流程

nlp_structbert_sentence-similarity_chinese-large部署教程:阿里云PAI-EAS一键部署全流程 1. 工具简介 nlp_structbert_sentence-similarity_chinese-large是一个专门用于中文句子语义相似度计算的强大工具。它基于阿里达摩院开源的StructBERT大规模预训练模型&a…...

RedisDesktopManager-Windows核心功能详解:数据库连接、键值管理与数据可视化

RedisDesktopManager-Windows核心功能详解:数据库连接、键值管理与数据可视化 【免费下载链接】RedisDesktopManager-Windows RedisDesktopManager Windows版本 项目地址: https://gitcode.com/gh_mirrors/re/RedisDesktopManager-Windows RedisDesktopManag…...

Komikku与追踪器集成:如何实现与MyAnimeList、AniList的自动同步

Komikku与追踪器集成:如何实现与MyAnimeList、AniList的自动同步 【免费下载链接】komikku Free and open source manga reader for Android 项目地址: https://gitcode.com/gh_mirrors/ko/komikku Komikku是一款免费开源的Android漫画阅读应用,支…...

FigmaCN技术解析:本地化方案如何实现设计效率优化

FigmaCN技术解析:本地化方案如何实现设计效率优化 【免费下载链接】figmaCN 中文 Figma 插件,设计师人工翻译校验 项目地址: https://gitcode.com/gh_mirrors/fi/figmaCN 中文设计师在使用Figma时,常因界面语言障碍导致操作效率降低30…...

Python AOT编译正式落地2026:3步完成插件下载、5分钟完成生产级安装(附官方校验码)

第一章:Python AOT编译正式落地2026:里程碑意义与核心价值2026年3月,CPython官方宣布Python 3.14版本原生支持AOT(Ahead-of-Time)编译模式,标志着Python首次在标准发行版中实现无需第三方运行时干预的静态可…...

Windows Cleaner:终极免费的Windows系统清理工具让C盘重获新生

Windows Cleaner:终极免费的Windows系统清理工具让C盘重获新生 【免费下载链接】WindowsCleaner Windows Cleaner——专治C盘爆红及各种不服! 项目地址: https://gitcode.com/gh_mirrors/wi/WindowsCleaner 你是否经常面对C盘爆红的警告而束手无策…...

智能合约安全审计:awesome-game-security 中的安全漏洞与防护方案

智能合约安全审计:awesome-game-security 中的安全漏洞与防护方案 【免费下载链接】awesome-game-security awesome game security [Welcome to PR] 项目地址: https://gitcode.com/gh_mirrors/aw/awesome-game-security 在游戏开发领域,智能合约…...

PINCE代码注入实战:.so文件注入完全指南

PINCE代码注入实战:.so文件注入完全指南 【免费下载链接】PINCE Reverse engineering tool for linux games 项目地址: https://gitcode.com/gh_mirrors/pi/PINCE PINCE是一款强大的Linux游戏逆向工程工具,专注于动态链接库注入技术,为…...

深入详解PHP中的自动加载机制

什么是自动加载? 当使用 new ClassName() 时,PHP自动帮你找到并包含对应的文件。 1 2 3 4 5 6 7 // 传统写法 require_once User.php; require_once Product.php; $user new User(); // 自动加载:无需手动包含 $user new User(); // PHP…...

FreeRTOS任务跑飞别慌!教你用PSP和uxTaskGetStackHighWaterMark锁定罪魁祸首

FreeRTOS任务跑飞排查实战:从PSP追踪到栈溢出的全链路分析 当你在深夜调试一个复杂的FreeRTOS项目时,突然发现某个任务毫无征兆地崩溃进入HardFault_Handler——这种经历对嵌入式开发者来说简直如同噩梦。与裸机环境不同,RTOS的多任务特性让问…...

基于ECMS的混合动力汽车Simulink模型:可用于能量管理研究且模型无误

基于ECMS搭建的混合动力汽车simulink模型 可用于能量管理研究 模型运行无误 联系赠送模型搭建参考文献一份,赠送nedc、udds等常用工况数据表,可自行更改工况进行模型开发ECMS算法这玩意儿在混动能量管理圈子里挺能打,最近刚用Simulink搭了个模…...

Le Git Graph 终极指南:GitHub提交图谱可视化工具快速上手

Le Git Graph 终极指南:GitHub提交图谱可视化工具快速上手 【免费下载链接】le-git-graph Browser extension to add git graph to GitHub website. 项目地址: https://gitcode.com/gh_mirrors/le/le-git-graph Le Git Graph 是一款功能强大的浏览器扩展&…...

【ComfyUI】Qwen-Image-Edit-F2P 在Unity数字人中的应用:驱动3D角色面部表情生成

ComfyUI Qwen-Image-Edit-F2P 在Unity数字人中的应用:驱动3D角色面部表情生成 1. 引言:当AI绘画遇上3D表情动画 想象一下,你正在开发一款游戏或者制作一个虚拟偶像,角色需要做出成百上千种表情——开心的、悲伤的、惊讶的、愤怒…...

ARM架构和主要内核介绍-D

目录 概述 1 ARM架构的历史发展线 1.1 技术演进 1.2 关键阶段与技术里程碑 1.3 成功的核心:商业模式创新 2 Cortex-M内核 2.1 主要特性 2.2 系列通用核心优势 3 Cortex-R系列 3.1 内核介绍 3.2 核心技术特性 4 Cortex-A系列 4.1 主要特性 4.2 核心架构…...