基于STM32的数字加密录音笔设计

分享到:

随着电子产品对数字信号处理技术的需求广泛应用,语音信息的保密性也成为信息处理领域的一个重要研究方向。模拟音频信号的数字化过程包括采样、量化和编码等,数字信号具有抗干扰能力强、信号动态范围大(S/N>90dB)以及可进行数据压缩的特点。数据加密是由加密密钥和加密算法将明文数据转化为没有固定意义的密文;数据解密即是由解密密钥和解密算法将密文恢复为明文。
 
系统使用基于ARM内核的STM32处理器执行加密算法和系统的协作控制。采用TEA加密算法对接收到的音频数据进行实时加密,加密后的语音数据存储到外部SD卡中,并可将语音文件通过USB接口传输到计算机进行解密处理。文中设计完成了数字录音模块和STM32外围配置的硬件电路;PCB布局布线;编写加密录音笔软件,实现了数字录音笔的数据加密与数据存储功能。
 
1系统整体设计
 
系统硬件电路主要分为数字录音模块和STM32处理器模块两部分,如图1所示。数字录音模块负责模拟音频信号捕获和信号采样、量化以及编码处理;处理器模块实现数字数据的加密运算、数据存储以及系统的整体控制。
 
基于STM32的数字加密录音笔设计
图1系统整体设计框图
 
语音信号通过麦克风输入后进行数字录音,数字录音电路包括滤波器网络、增益放大和语音处理3部分。由于系统要求尽可能减小PCB板面积,所以本文选择能同时满足增益放大、A/D采样以及编码处理的录音芯片VS1003。STM32处理器模块负责加密算法的执行和系统的协作控制。VS1003将采集到的数据通过SPI接口实时传输到STM32进行加密处理,并将加密后的密文数据通过另一个SPI接口存储到外部容量为2GB的SD卡中。
 
2硬件电路设计
 
2.1 STM32处理器电路
 
2.1.1主控芯片配置电路
 
主控芯片使用STM公司的STM32F103C6T6控制器,该系列32位闪存微控制器使用ARM公司具有突破性的Cortrex-M3内核,Cortex-M3内核基于哈佛架构,指令总线和数据总线相互独立,使STM32的性能得到明显提高,并在大幅提高了应用程序的执行速度。
 
STM32通过BOO了[1:0]引脚选择3种不同的启动模式,系统使用主闪存存储模式,即主闪存存储器被选为启动区域;系统时钟采用8MHz内部时钟经内部倍频为48MHz。STM32支持两种调试接口(SWJ):SW调试和JTAG调试,且SW调试和JTAG调试的部分引脚是复用的。本文采用SW(同步串行协议)调试:SWCLK为从主机到目标的时钟信号;SWDIO为双向数据信号;SWDIO为双向接口,需接100kΩ的上拉电阻。STM32主控芯片的配置结构如图2所示。
 
基于STM32的数字加密录音笔设计
图2 STM32主控芯片配置图
 
2.1.2SD卡存储电路
 
安全数码卡(SecureDigitalMemoryCard,SD)是基于半导体快闪记忆器的多功能存储卡,具有容量大、性能高、安全性强等优点。SD卡支持3种传输模式:SPI模式、1位SD模式以及4位SD模式,文中使用SPI传输模式与STM32主控制器进行通信,SD卡与STM32的连接如图3所示。
 
基于STM32的数字加密录音笔设计
图3 SD卡连接图
 
2.1.3USB通信电路
 
STM32处理器内部自带一个USB从控制器,符合USB通信连接规范。USB传输所需的48MHz时钟由内部系统时钟提供,USB接口电压由+5V供电。其接口电路连接图如图4所示。
 
基于STM32的数字加密录音笔设计
图4 USB接口电路图
 
2.2数字录音电路
 
数字录音单元通过对输入的模拟音频信号进行低通滤波、增益放大以及采样、量化和ADPCM编码处理,输出数字音频数据。VS1003是VLSI公司的一款支持MP3/WMA/MIDI音频编解码和ADPCM编码的芯片,内置一个高性能、低功耗的DSP处理器内核,具有5kB的指令RAM,0.5kB的数据RAM,串行控制/数据输入接口,1个UART口以及4个通用IO口;同时片内带有一个立体声DAC以及一个可变采样率的ADC。
 
输入模拟音频信号经LINE_IN引脚输入到VS1003进行A/D采样,量化和ADPCM编码,并通过SPI通信协议与STM32主控制器进行数据与控制信号的传输。录音电路与STM32的连接电路如图5所示。
 
 
基于STM32的数字加密录音笔设计
图5 VS1003电路连接图
 
VS1003芯片由外部晶振提供12.288MHz时钟作为主时钟,如图5所示。录音芯片由系统电源模块供电,所需2.5V模拟电压、3.3V数字电压以及3.3V模拟电压,由AMS1117线性电源模块提供。XRESET信号提供录音芯片的硬件复位,当XRESET为低时,VS1003处于复位状态。系统通电或硬件复位后,主机通过对各硬件寄存器的设置来实现对录音芯片录音模式和具体参数的设定。
 
2.3供电电路
 
系统由外部电源或锂电池供电,采用数字5V进行供电,使用CN3052充电电路对锂电池充电。CN3052A是对单节锂离子或锂-聚合物可充电电池进行恒流/恒压充电的充电器电路,其只需较少的外围器件,且符合USB总线技术规范。充电模块电路如图6所示。
 
基于STM32的数字加密录音笔设计
图6 充电模块电路图
 
3录音笔软件设计
 
录音系统的软件程序包括加密录音程序和上位机解密程序。加密录音过程为,首先对VS1003语音芯片进行初始化配置,设定录音参数,通过计数器计数值为文件名,创建WAV头文件,读取SPI接口采集的数字音频数据并进行数据加密处理,随后再保存为WAV文件。上位机解密软件通过计算机对加密录音文件进行解密处理。加密录音流程如图7(a)所示。
 
 
基于STM32的数字加密录音笔设计
图7 软件设计流程图
 
3.1底层驱动程序
 
S7M32控制器通过SPI接口对VS1003录音芯片进行寄存器配置,然后进行数字音频数据的传输,经加密处理后将数据存储到SD卡中,上位机通过USB接口直接对存储器进行读写操作,以方便加密录音文件的拷贝。系统使用VS1003,采样率为8kHz,采样位数为16bit,其配置流程如图7(b)所示。STM32为USB开发工具集提供了完整且经过认证的固件包,从而可轻易实现对各类USB固件的开发。其中包括:用于普通设备管理任务的控制传输、批量传输、中断传输以及同步传输。USB接口配置流程如图7(c)所示。
 
3.2 TEA加密程序
 
为满足实时加密的要求,本文采用基于TEA的加密算法。TEA是一种小型的对称加解密算法,支持128位密钥,该加密算法的优点是速度快、效率高。为避免for循环和除法运算,采用升级版的TEA加密算法,通过对加密算法的更改,可一次加密512Byte,符合Flash一页扇区的存储大小。TEA加密算法通过加密轮数来保证数据的可靠性,程序采用12轮加密,故具有较高的可靠性。
 
算法的主要思想是将输入的512Byte明文数据进行分组,得到每组32bit,共128组的数组V0,V1,…,V127,并对128位密钥进行分组得到4组32bit的数组K0,K1,K2,K3,然后将每组数据Vj进行加MX运算,共进行128次,完成一轮加密。密钥常量设置为
unsignedcharTEA_key[16]={0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,0x09,0x0A,0x0B,0x0C,0x0D,0x0E,0x0F,0x10};
 
TEA加密算法流程如图8所示。
 
 
基于STM32的数字加密录音笔设计
图8 TEA加密算法流程图
 
其中,Delta的初始值为0x9E3779B9,Delta值的不断变化使得每轮的加密均有所不同。TEA解密算法是加密的逆运算,对加密后的wav文件进行解密处理,本文使用C#编写解密界面。
 
4实验仿真
 
打开电源开关,状态指示灯闪烁一次;使用录音中间"一键录音"按键,录音指示灯常亮;再次按键时录音指示灯熄灭,停止录音。本文使用音频处理软件CoolEditPro进行波形观察,加密的录音源文件和解密后的波形文件如图9所示。
 
 
基于STM32的数字加密录音笔设计
图9 音频文件波形图
 
通过音频信号的波形对比可看出,加密后的音频信号波形是完全随机的乱码,语音播放时呈噪音状态,解密后的音频文件声音还原性良好。
 
5结束语
 
系统使用VS1003、STM32等器件实现一键录音加密录音笔的设计,USB从控制器与PC机进行通信,实现数据传输。数字录音技术是现代数字信号处理的重要组成部分,其融合了音频数据采集与传输、音频数据处理以及嵌入式等多种技术,具有广阔的应用前景。
继续阅读
意法半导体推出功能完整的电能表评估板 集成低成本传感器和稳健的电隔离功能

中国,2021年2月25日——意法半导体新推出的电表评估板采用低成本的抗电分流传感器和先进的电流隔离技术实现出色的可靠性和鲁棒性,加快三相交流电能表设计,满足国际上最严格的电能表质量和精度标准。

意法半导体将在MWC 2021上海大会上展出业界领先的智能出行、电源和能源管理、物联网和5G解决方案

中国上海,2021年2月23日——横跨多重电子应用领域的全球领先的半导体供应商意法半导体(STMicroelectronics,简称ST;纽约证券交易所代码:STM)将在MWC 2021上海大会(2月23-25日)上,围绕“意法半导体,科技始之于你”主题,展示其行业领先的智能出行、电源与能源管理、物联网与5G半导体产品和解决方案。

意法半导体推出面向大众市场的 STM32WL LoRa®无线系统芯片系列产品

今天新推出的STM32WL型号包括基于Arm®Cortex®-M4内核和Cortex-M0 + MCU内核的双核STM32WL55。开发者可以完全开放和灵活地使用两个内核,双核架构可以有效地实现硬件隔离,增强网络安全性,应用更新无需重新认证设备,并增强射频和应用的实时性能。

意法半导体工业峰会2020将于12月2日在深圳举行

首届“意法半导体工业峰会2019”取得了巨大成功,赢得了包括公司高层、高级管理人员、商业伙伴和行业专家在内的900多名参会者的赞扬。作为一个业内重要的年度盛会,意法半导体工业峰会汇集了来自贯穿不同尖端技术的工业市场领域的领导者、专家和行业影响力者,为现有及新兴工业应用市场共同探索并加速开发下一代产品和解决方案。

意法半导体推出双轴测斜仪芯片 搭载可编程机器学习内核

日前,意法半导体推出两轴数字测斜仪芯片,可用于工业自动化以及结构健康监测。