微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > MCU和DSP > 基于CH375的嵌入式USB文件加解密系统的设计

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

时间:06-22 来源:21ic中国电子网 点击:


  单片机通过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).

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top