基于CH375的嵌入式USB文件加解密系统的设计

发布者:火星叔叔最新更新时间:2014-09-17 来源: eefocus关键字:文件加密  嵌入式系统  CH375 手机看文章 扫描二维码
随时随地手机看文章
  随着信息与通信技术的飞速发展,信息安全与通信加解密在个人隐私特别在军事情报和国家机密等方面显得尤为突出。数据加密技术无疑是保护信息安全最有效的一种方法。传统的文件加密方式是基于PC平台的,不能满足移动场合的应用需求。基于PC机的加密技术使明文到密文必须经过PC机环节,在不能保证PC机软硬件绝对可靠的情况下,可能失密。基于嵌入式设计的本系统可以便携使用,并在完成加密或解密过程后可将芯片程序擦除或将芯片破坏,避免加解密硬件环节的失密。本设计提高了系统的安全性,提供了便携使用的可能,有一定的理论意义和较高的使用价值。
  1 USB HOST控制器CH375
  CH375 是一款USB总线的通用接口芯片,支持USB HOST主机方式和USB DEVICE/SLAVE设备方式。CH375具有8位数据总线和读、写、片选控制线以及中断输出,可以方便地挂接到单片机/DSP/MCU/MPU等控制器的系统总线上。
  CH375的USB 主机方式支持常用的USB 全速设备,外部单片机可以通过CH375 按照相应的USB 协议与USB 设备通信。CH375 还内置了处理海量存储设备的专用通信协议的固件,外部单片机可以直接以扇区为基本单位读写常用的USB 存储设备(包括USB 硬盘/USB 闪存盘/U盘)[1]。CH375的接口框图如图1所示。


  2 系统结构
  嵌入式文件加解密系统主要分为四个部分:运算处理模块、按键与状态显示模块、USB通信模块、电源模块。系统结构框图如图2所示。


  运算处理模块由P89V51RD2单片机与32KB的RAM 62256及其外围电路组成,负责加解密计算与整个系统的控制。按键产生加解密操作的控制信号,LED显示当前系统状态。USB通信模块对USB存储设备进行数据传输与文件操作。电源模块为本系统供电并且为USB总线提供5V电源电压。

  3 基于CH375的USB HOST在本系统的硬件设计实现
  3.1 CH375与P89V51RD2单片机的接口部分
  CH375与P89V51RD2单片机的接口如图3所示。CH375 的TXD引脚通过1kΩ左右的下拉电阻接地或者直接接地,使CH375 工作于并口方式。CH375的CS#连接到单片机的A15 引脚,端口地址范围为0000H~7FFFH,为了避免冲突,外部RAM地址在8000H 以上。



  电容C3用于CH375 内部电源节点退耦,C3是容量为0.01μF 的独石或高频瓷片电容。电容C4和C5用于外部电源退耦,C4是容量为0.1μF的独石或高频瓷片电容。晶体X1、电容C1和C2组成CH375的时钟振荡电路。USB-HOST主机方式要求时钟频率比较准确,X1的频率为12MHz±0.4‰,C1和C2是容量约为15pF的独石或高频瓷片电容。
  如果电源上电过程较慢并且电源断电后放电时间较长,将导致CH375不能可靠复位。所以在RSTI引脚与VCC 之间跨接一个容量为0.47μF 的电容C11,并且可以减少干扰。
  在设计印刷线路板PCB 时,需要注意:退耦电容C3 和C4尽量靠近CH375 的相连引脚;使UD+和UD-信号线贴近平行布线,尽量在两侧提供地线或者覆铜,减少来自外界的信号干扰;尽量缩短XI和XO引脚相关信号线的长度,减少高频时钟对外界的干扰,并应该在相关元器件周边环绕地线或者覆铜。
  3.2 P89V51RD2单片机扩展部分
  P89V51RD2单片机扩展部分电路图如图4所示。MCS-51 单片机用U2锁存A7~A0 地址。U3用于简单的地址译码,产生所需的片选信号,使本系统CH375 芯片的片选地址范围为B000H~BFFFH,本系统中CH375 需要占用两个地址:地址BXX1H用于写命令,地址BXX0H 用于读写数据。


  3.3 供电电路部分
  供电部分电路如图5所示,用于对USB总线供电。设计时除了要考虑自身功耗,更重要的是要保证对总线提供直流5V/500mA的供电。本设计所用的芯片都工作在直流5V下,所以选用常见的直流电压转换芯片μA7805。该系统工作时,只须外接能够输出直流电压为7V~20V的电源适配器即可(可外挂锂电池组或驳接车载12V电源便携使用)。




  4 系统软件设计
  4.1系统工作流程图
  CH375对文件的读写模式分为扇区模式和字节模式。本系统选用速度较快的扇区模式,每次读取4个扇区数据,循环读写至文件结束。工作流程如图6所示。 [page]


  4.2 单片机软件
  单片机软件编写比较复杂,以下是CH375程序编写时的要点:
  CH375芯片占用两个地址位,单片机A0 引脚为选择命令数据端口,并通过8 位并口对CH375 芯片进行读写,所有操作命令都是由一个命令码、若干个输入数据和若干个输出数据组成,部分命令不需要输入数据,部分命令没有输出数据[2]。
  单片机对CH375的操作步骤如下:
  (1)在A0=1时向命令端口写入命令代码;
  (2)如果该命令具有输入数据,则在A0=0 时依次写入输入数据,每次一个字节;
  (3)如果该命令具有输出数据,则在A0=0 时依次读取输出数据,每次一个字节;
  (4)命令完成,可以暂停或者转到(1)继续执行下一个命令。CH375 芯片专门用于处理USB 通信,在接收到数据后或者发送完数据后,CH375以中断方式通知单片机进行处理。CH375内部中断逻辑图如图7所示。


  单片机通过CH375芯片接收数据的处理步骤如下:
  (1)当CH375接收到USB主机发来的数据时,首先锁定当前USB 缓冲区,防止被后续数据覆盖,然后将INT#引脚设置为低电平,向单片机请求中断。
  (2)单片机进入中断服务程序时,首先执行GET_STATUS 命令获取中断状态。
  (3)CH375在GET_STATUS 命令完成后,将INT#引脚恢复为高电平,取消中断请求。
  (4)由于通过上述GET_STATUS 命令获取的中断状态是“下传成功”,所以单片机执行RD_USB_DATA 命令从CH375读取接收到的数据。
  (5)CH375在RD_USB_DATA 命令完成后释放当前缓冲区,从而可以继续USB通信。
  (6)单片机退出中断服务程序。
  单片机通过CH375芯片发送数据的处理步骤如下:
  (1)单片机执行WR_USB_DATA 命令向CH375写入要发送的数据。
  (2)CH375被动地等待USB 主机在需要时取走数据。
  (3)USB主机取走数据后,CH375首先锁定当前USB缓冲区,防止重复发送数据,然后将INT#引脚设置为低电平,向单片机请求中断。
  (4)单片机进入中断服务程序时,首先执行GET_STATUS 命令获取中断状态。
  (5)CH375在GET_STATUS 命令完成后,将INT#引脚恢复为高电平,取消中断请求。
  (6)由于通过上述GET_STATUS 命令获取的中断状态是“上传成功”,所以单片机执行WR_USB_DATA 命令向CH375写入另一组要发送的数据。如果没有后续数据需要发送,单片机就不必执行WR_USB_DATA 命令。
  (7)单片机执行UNLOCK_USB 命令。
  (8)CH375在UNLOCK_USB 命令完成后释放当前缓冲区,从而可以继续USB 通信。
  (9)单片机退出中断服务程序。
  (10)如果单片机已经写入了另一组要发送的数据,则转到(2),否则结束。
  4.3 加密算法设计
  本系统采用一种基于随机因子的轻量级加密算法。
  传统的置换和替代加密技术比较脆弱,同一明文M在同一文件或所有文件中均为相同的密文C,因此很容易通过频度统计的办法破解。针对传统的置换和替代加密技术的缺点,本系统在对文件进行加密时加入随机因子,使得明文随着位置的不同其对应密文也有所不同,其基本过程如下:
  (1)首先将明文M采取一定的方法“乱”排序:例如将每10个字节分为一组,先在每组内倒序排列,再在组内采取奇偶位置对调,从而完成分组换位的目的。
  (2)其次对“乱”排序的二次明文M进行加密处理:加密各明文到密文的转换不是固定的,而是随机的,称为随机加密因子。基本流程如下:
  ①取出二次明文当前需加密的字节SB。
  ②计算SB的随机加密因子Factor。
  ③变换SB到DB,DB=SB XOR Factor[3]。
  其中,SB为明文,DB为加密后的密文。随机加密因子Factor由两部分组成:密钥Key和SB的位置偏移量p(mod 256)。设密钥为:“Huazhong University of Seience and Technology EI DSP Laboratory Zoe”共69个字符。当前需要加密的二次明文为字母A(SB的ASCII码为65,其在文件中的偏移量p为第234个字节),则密钥Key计算方法如下:234 mod 69=27,密钥中第27个字母为i(ASCII码为105),所以Key=105。随机加密因子Factor=(105+234=339)mod 256=73。密文DB=SB XOR Factor=65 XOR 73=8。如果第236个字节也为字母A,可计算出所对应的Factor=85,密文为17。可见同一明文在文件中的位置不同,相应的密文也有所不同,这样就难以通过频度统计的办法破解。
  本系统硬件可以与计算复杂度不高的任何加密算法配合使用。
  5系统的实验结果与讨论
  5.1供电测试
  按照USB规范,USB总线接入USB设备时,需要总线提供大约500mA电流。接入USB存储设备时产生瞬时电压降不可避免。如果压降过大,会导致系统不能正常工作。在此,有必要对系统工作时的电压进行监测。测试结果,接入USB设备瞬间,电压高于4.6V,系统无异常。
  5.2文件加密准确性测试
  使用本系统分别对U盘中大小为1KB~1MB的10个文件进行加密操作,将得到的密文用UltraEdite-32与正确密文进行自动比对。结果全部正确。可见其加密过程可靠性较好。
  5.3 速度测试
  使用本系统分别对U盘中大小为1KB~10MB的10个文件进行加密操作,分别记录完成时间(从按键操作到LED显示完成)。测得平均加密速度为35KB/s,与CH375公布的100KB/s~200KB/s的读写速度有差距。其原因是加密操作涉及读明文与写密文操作,数据传输量加倍;而且加密计算也需要占用单片机的工作时间。提高速度可使用高性能的MCU,也可对部分子程序改用汇编语言混合编程。
  本文详细介绍了基于CH375和51单片机的嵌入式USB文件加解密系统的设计。该系统使文件加解密脱离了PC机,便捷易用,并使用随机加密因子使密文抗破解能力比传统方法有很大提高。
  参考文献
  [1] 马伟.计算机USB系统原理及其主/从机设计[M].北京:北京航空航天大学出版社,2004.
  [2] USB总线通用接口芯片CH375 U盘文件级子程序库说明.南京沁恒电子有限公司,2004.
  [3] 石林祥,贺海晖,魏淑桃. 一种使用文件加密方法的实现,计算机工程,2004,(12).
关键字:文件加密  嵌入式系统  CH375 引用地址:基于CH375的嵌入式USB文件加解密系统的设计

上一篇:基于MPC8260和FPGA的DMA接口设计
下一篇:数字温度传感器DS18B20在卫星电源系统中的应用

推荐阅读最新更新时间:2024-03-16 13:41

USB主机方式在嵌入式系统的应用
  USB 就是指通用串行总线(Universal Serial Bus),是计算机外围设备通讯的总线标准。USB 能够实现从出现迅速发展到普遍应用,其主要的原因是其具有高速、稳定、廉价、方便的特点。在嵌入式系统中USB技术主要有两种应用方式,一种是USB总线设备的USB设备方式,一种是USB主控制器的嵌入式USB主机。USB 设备已经得到了广泛的使用,但是USB 主机实现其复杂性却没有很多应用实例。文章主要研究了USB应用领域中,采用低端控制器的嵌入式系统如何实现有限的USB主机功能。   由于其良好的特性,USB 总线的应用范围已经开始从计算机外围设备向嵌入式系统扩展,在嵌入式系统中USB总线协议的完整性与复杂性使得它的应
[嵌入式]
嵌入式系统中的内存压缩技术
摘要:介绍内存压缩技术和一个基于硬件的内存压缩系统模型,探讨内存压缩技术在嵌入式系统中的应用;重点介绍内存压缩系统的硬件要求及操作系统对内存压缩机制的支持;简单介绍内存压缩中常用的算法Lempel-Ziv,并就内存压缩技术在嵌入式系统中的应用问题作一些探讨。 关键词:嵌入式系统 内存压缩 压缩内存控制器 Lempel-Ziv算法 1 内存压缩技术介绍 为节省存储空间或传输带宽,人们已经在计算机系统中广泛地使用了数据压缩技术。在磁介质存储数据或网络传输数据时,人们使用基于硬件或软件的各种压缩技术。当压缩技术在各个领域都很流行时,内存压缩技术却由于其复杂性而一直未得到广泛使用。近年来,由于在并行压缩一解压算法以及在硅密度及速度
[嵌入式]
专为中国推出的台式直流电源系列PWS2000
  泰克公司日前宣布,为中国推出首款直流电源PWS2000-SC简体中文系列,以支持中国嵌入式系统设计工程师和教育工作者实现各种应用。PWS2000-SC系列能够输出与各种电压和电流设置准确匹配的直流电源,并带有用户自定义输出控制模式,使用方便,且价格平易近人。每种型号都标配三年保修,以保障客户的投资。   嵌入式系统设计正变得越来越复杂,工程师们需要准确灵活的仪器,为复杂的嵌入式电子设备和元器件供电。此外,高等技术学院的教育工作者们需要基础、可靠、简便易用的直流电源,在有限的预算内完成各种实验室实验。PWS2000-SC系列是满足广大客户不同需求的理想工具。   PWS2000-SC系列的四种型号均可以生成干净稳定的直流电,
[测试测量]
专为中国推出的台式直流电源系列PWS2000
基于ARM嵌入式系统的一种远程可控电源插座设计
互联网的迅速发展,实现了信息的高速传输和资源共享,极大地方便了人们的生活。嵌入式系统广泛应用于各种电器产品、智能仪表和控制设备中,它与互联网的结合是一种必然的趋势。 嵌入式系统和网络技术的快速发展,为网络远程控制的发展和完善提供了技术基础。 笔者综合运用嵌入式系统和Web技术,设计了一种可通过互联网进行远程控制的电源插座系统,实现对家用或工业电器的远程实时控制。用户通过网页浏览器访问该系统,对各插座进行打开或关闭的操作,实现对与其相连接的电器的远程控制。 1 嵌入式Web工作原理 嵌入式Web的体系结构如图1所示。客户端和嵌入式系统中Web服务器之间的通信协议采用HTTP(超文本传输协议)。嵌入式操作系统提供TCP
[单片机]
基于ARM<font color='red'>嵌入式系统</font>的一种远程可控电源插座设计
基于Liunx的嵌入式系统的底层软件的结构、设计和应用
近几年,随着计算机技术和电了技术的飞跃式发展,通过不断的系统功能集成和优化,网络覆盖面积和传输稳定性日益增加,将传统模拟视频监控系统中的模拟信号部分已舍弃,完成了全数字化的视频监控系统,并加入了AD转换功能,使整个视频数据能在网络上进行传输,满足了各类行业部门及家庭对网络可视化业务的需求。这种全数字化的视频监控系统存系统设备规模和系统功能性上,较之前的模数混合型系统,有了巨大的变化和升级。一般网络视频监控系统只需要摄像机、路由器和计算机就能搭建,拓扑结构简单。利用计算机的强大的处理能力,改善了监控系统的控制效率、提高了监控系统的智能化和采集图像的质量。基于网络技术搭建的系统结构,结构清晰、布线简单、系统扩展性强,并且一台主控计
[单片机]
基于Liunx的<font color='red'>嵌入式系统</font>的底层软件的结构、设计和应用
研华产品多采用微软嵌入式系统开发
在IIC-China 2009深圳技术研讨会上,工控领域的老大研华科技的副总经理陈培齐一语惊人:“基于Windows Embedded OS的开发成本比Linux更低,而且开发周期更短。我们大部分产品采用Windows Embedded OS进行开发。” 从研华老总口里听到这话的确是有些意外,因为免费开源的Linux现在是业内的热点话题,很多小型厂商为了节省开发成本都在采用Linux开发产品,包括不少做工控设备的厂商。他们大都告诉笔者,Linux是免费的,因此开发成本会低很多,尽管他们承认必须花费不少的工程资源和时间去将它变成一个商业可用的产品。即便有些小供应商的技术研发实力不够强,他们也可从风河系统、MontaVi
[嵌入式]
基于EP9312的银税类嵌入式系统硬件设计方案
1 嵌入式系统的概念与特点 嵌入式系统结合微处理器或微控制器的系统电路与其专属软件,达到系统操作效率的最高比,这里把嵌入式系统定义为一个体积较小的计算机系统(与PC机相比),由于其体积较小,因此软硬件结构和应用范围与PC机相比有较大的不同,其特性可归纳为下列四项: (1)通常执行特定功能; (2)以微电脑与外围构成核心; (3)严格的时序与稳定性要求; (4)全自动操作循环。 嵌入式系统具有目的性或针对性,其开发是围绕着产品和产品的特定功能来进行的。它必须最大限度的在硬件和软件上"量身订作"以提高效率 ,本文设计的嵌入式系统主要用于金融和税务类产品。 2 总体设计 2.1 CPU的选择 本文采用的是Cirrus L
[嵌入式]
用户关注实时性性,Linux使用率仍然偏低
日前在美国硅谷举办的嵌入式系统研讨会(Embedded Systems Conference)上,一份针对嵌入式操作系统的调查显示,目前(美国)只有17%的嵌入式系统设计工程师采用嵌入式Linux,而66%的人表示他们要么对此没有兴趣,要么就是今后也不会用。 EE Times及其姊妹出版物Embedded Systems Design的“2006年嵌入式系统设计状况调查报告”发现,34%的受调查表示对Linux不感兴趣,2/3的受调查对象说他们对Linux有兴趣,但是,最近不会使用;而17%的人则说他们可能很快就会采用。相比之下,2005年有24%的受调查者表示他们正在使用嵌入式Linux。 在考虑使用嵌入式Linux
[嵌入式]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved