Atmega128单片机的RC5和RC6算法比较与改进

发布者:HappyExplorer最新更新时间:2011-12-28 关键字:RC5  RC6  分组密码  混合密钥  Flash 手机看文章 扫描二维码
随时随地手机看文章

引言

在无线局域网中,传输的介质主要是无线电波和红外线,任何具有接收能力的窍听者都有可能拦截无线信道中的数据,掌握传输的内容,造成数据泄密。因此,对于无线局域网来说,数据的加密是关键技术之一。

AVR高速嵌入式单片机是8位RISC MCU,执行大多数指令只需一个时钟周期,速度快(8MHz AVR的运行速度约等于200MHz C51的运行速度);32个通用寄存器直接与ALU相连,消除和运算瓶颈。内嵌可串行下载或自我编程的Flash和EPPROM,功能繁多,具有多种运行模式。

依照IEEE1999年发布的802.11无线局域网协议标准,采用Atmel公司的Atmega128高速嵌入式单片机,开发无线数据传输装置。为了实现无线数据传输时的安全性,同时尽可能节省成本,采用软件进行加密、解密。这就对算法的简法性、高速性及适应性提出了很高的要求。RC5和RC6两种新型的分组加密算法能够比较好地满足上述的要求。

1 RC5及RC6算法

1.1 RC5及RC6的参数

RC5及RC6是参数变量的分组算法,实际上是由三个参数确定的一个加密算法族。一个特定的RC5或者RC6可以表示为RC5-w/r/b或者RC6-w/r/b。其中这三个参数w、f和b分别按照表1所列定义。

表1 RC5及RC6算法参数定义

参  数 定  义 常  用
w 以比特表示的字的尺寸 16,32,64
r 加密轮数 0~255
b 密钥的字节长度 0~255

1.2 RC5及RC6字运算部件

RC5及RC6均由三部分组成,分别为混合密钥生成过程、加密过程和解密过程。在这两种算法中,共使用了六种基本运算:

①模2w加法运算,表示为“+”;

②模2w减法运算,表示为“-”;

③逐位异或运算,表示为+;

④循环左移,字a循环左移b比特表示为“a<<

⑤循环右移,字a循环右移b比特表示为“a>>>b”;

⑥模2w乘法,表示为“×”。

RC5算法运用了上述的①~⑤运算部分,RC6算法使用了上述所有的运算部件。

1.3 RC5算法

(1)RC5算法混合密钥生成过程的伪代码表示

S[0]=Pw

for i=1 to t-1 do

S[i]=S[i-1]+Qw

输入比特数大小为8,密钥长度为b的用户密钥K[0]至K[b-1]

转换K[0]至K[b-1]为数组长度为c,比特数为w的L[]数组

i=j=0 x=y=0

do 3×max(t,c)times:

S[i]=(S[i]+x+y)<<<3;X=S[i];i=(i+1)mod t

L[j]=(L[j]+x+y)<<<(x,y);X=L[j];j=(j+1)modC

其中c=[b×8/w]方括号表示上取整运算,t=2r+2,当w分别为16、32、64时,常数Pw、Qw分别如表2所列。

表2 常数Pw、Qw取值表

W 16 32 64
Pw 0xB7E1 0xB7E15163 0xB7E151628AED2A6B
Qw 0x9E37 0x9E3779B9 0x9E3770B97F4A7C15

(2)RC5加密算法过程的伪代码表示

Input(A,B)

A=A+S(0)B=B+S[1]

for i=1 to r do

A=((A+B)<<

B=((B+A)<<

Output(A,B)

其中初始的A、B分别为要加密的两个比特数为w的数据,最终的A、B分别为加密好的两个比特数为w的数据。

(3)RC5解密算法过程的伪代码表示

Input(A,B)

for i=r down to 1 do

B=((B-S[2i+1])>>>A)+A

A=((A-S[2i])>>>B)+B

A=A-S[0] B=B-S[1]

Output (A,B)

其中初始A、B中的数据就是已经加密了的比特数为w的数据,最终的A、B中的数据为解密后的比特数为w的数据。

1.4 RC6算法

(1)RC6算法混合密钥生成过程伪代码表示

RC6混合密钥生成过程与RC5相同,只是t的取值为2r+4。

(2)RC6加密算法过程伪代码表示

Input(A,B,C,D)

B=B+S[0]D=D+S[1]

for i=1 to r do

t=(B×(2B+1))<<

u=(D×(2D+1))<<<1og2w

A=((A+t)<<

C=((C+u)<<

(A,B,C,D)=(B,C,D,A)

A=A+S[2i+2]C=C+S[2i+3]

Output(A,B,C,D)

其中初始的A、B、C、D分别为要加密的四个比特数为w的数据,最终的A、B、C、D分别为加密好的四个比特数为w的数据。

(3)RC6解密算法过程的伪代码表示

Input(A,B,C,D)

C=C-S[2i+3]A=A-S[2i+2]

for i=1 to r do

(A,B,C,D)=(D,A,B,C)

u=(D×(2D+1))<<

t=(B×(2B+1))<<

C=((C-S[2(r-i)+3])>>>t)+u

A=((A-S[2(r-i)+2])>>>u)+t

D=D-S[1] B=B-S[0]

Output(A,B,C,D)

其中初始的A、B、C、D分别为已经被加密的四个比特数为w的数据,最终的A、B、C、D分别为解密后的四个比特数为w的数据。

2 RC5和RC6算法的实现及改进

2.1 AVR单片机的RC5和RC6算法流程

RC5及RC6算法加密过程实现流程图如图1所示,解密过程实现流程图如图2所示,总体过程流程图如图3所示。

 

2.2 AVR单片机RC5和RC6算法的改进

①在进行算法流程的安排时,考虑到AVR高速嵌入式单片机只有32个8位寄存器,为了节省寄存器的使用,应该在混合密钥生成过程执行后,再把待加密的数据赋予寄存器。这样在混合密钥生成过程以前的寄存器都可以被使用,而不会对整个算法的执行结果造成影响。

②在进行RC5及RC6算法参数的选择时,考虑到AVR高速嵌入式单片机指令最多只支持16位数据相加以及程序的简洁化,所以在本程序中选择w为16而没有选择w为32,r和b的值依据Rivest的建议分别取为12和16。

③在执行算法中的左循环或者右循环运算时,考虑到循环移位的效果,实际循环移位的位数应该为要执行移位次数的低1log2w位。在本程序中为要执行移位次数的后四位。

④在执行算法中的模2w加法运算、模2w减法运算、模2w乘法运算时,由于2w的取值为65536,而2个8位寄存器(0~15位)最高可以表示数据的值为65535,数据再大就要向高位进位,所以在本程序执行上述的算法只需要考虑到2个8位寄存器所表达的值就得到了上述运算的最终结果,而不用再进行模2w运算。

⑤为了提高数据加密及解密的速率,可以把混合密钥生成过程提前执行,以使之生成一张混合密钥表。把这个表装入发送数据端Atmega128高速嵌入式单片机和接收数据端Atmega128高速嵌入式单片机的Flash中,从而在以后的加密与解密过程中直接使用混合密钥。值得注意的是,每当用户输入的用户密钥发生改变时,必须重新执行混合密钥生成过程,并且重新给Flash装载重新生成后的混合密钥表。在本程序中,RC5混合密钥表共占据52个8位寄存单元,RC6混合密钥表共占据56个8位存储单元。

⑥在本程序中运用加法运算以及移位运算实现了16位二进制数乘以16位二进制数的无符号运算。该运算的子程序如下:

chengfa:clr result2

clr result3

ldi count1,16

lsr chengshu1

ror chengshu0

chengfa0:

brcc chengfa1

add result2,beichengshu0

adc result3,beichengshu1

chengfa1:

ror result3

ror result2

ror result1

ror result0

dec count1

brne chengfa0

ret

3 RC5及RC6算法实验结果及其比较与分析

RC5及RC6算法实验的混合密钥过程、加密过程、解密过程和总体过程的效果比较如表3、4、5、6所列。

表3 RC5及RC6算法混合密钥过程效果比较

混合密钥生成过程 周期计数 停止观察/μs 程序大小/字 c t
RC5算法 15 248 1270.67 141 8 26
RC6算法 15 246 1270.50 141 8 28

表4 RC5及RC6算法加密过程效果比较

加密过程(不考虑生成混合密钥的时间) 周期计数 停止观察/μs 程序大小/字 共处理数据的位数 效率/(位/s)
RC5算法 2511 209.25 66 32 约为152 927
RC6算法 62529 5210.75 170 64 约为12 282

表5 RC5及RC6算法解密过程效果比较

解密过程(不考虑生成混合密钥的时间) 周期计数 停止观察/μs 程序大小/字 共处理数据的位数 效率/(位/s)
RC5 算法 2509 209.08 68 32 约为153 051
RC6 算法 62527 5210.58 176 64 约为12 283

表6 RC5及RC6算法总体过程效果比较

总体算法过程(考虑生成混合密钥的时间,不考虑数据传输所用的) 周期计数 停止观察/μs 程序大小/字 共处理数据的位数 效率/(位/s)
RC5算法 20 260 1688.33 267 32 约为18 594
RC6算法 140 274 11 689.50 455 64 约为5475

由表3可以发现,RC6算法和RC5算法在混合密钥生成时程序的大小相同,但量RC6算法却比RC5算法省时。这是因为根据混合密钥生在方法在执行循环,最终生成混合密钥时要执行比较操作。当超出了比较范围t时,要对指针地址重新复位。RC6算法t的取值大于RC5算法中t的取值,因此RC6算法执行了较少的复位操作。从而节省了运行周期,故RC6算法比RC5算法在生成混合密钥时省时。

以上所有实验结果均是在AVR Studio4.07仿真软件上选用Atmel公司的Atmega128高速嵌入式单片机为实验设备平台。选取参数w=16、r=12、b=16,并根据计算公式求得c=8,t=26(RC5算法)或者t=28(RC6算法)在12MHz运行速度下模拟所得。

从实验结果所得的表3、表4、表5、表6可以明确得出以下结论。

①从程序的执行效率来看,无论在加密还是在解密过程中,RC5算法都要比RC6算法执行效率高。

因此,在一些非常注重程序执行效率,而对数据安全性要求不是非常高的情况下,应该采用RC5算法。

②从程序的执行时间来看,无论在加密过程不是在解密过程中,RC5算法都要比RC6算法省时。因此,在一些对程序执行时间长短要求很高,对数据安全性要求不是非常高的情况下,可以采用RC5算法。

③从程序的大小来看,无论在加密过程中还是在解密过程中,RC5算法都要比RC6算法更简洁。因此,在一些对程序所用空间大小要求很高,对数据安全性要求不是非常高的情况下,可以采用RC5算法。

④从安全性角度考虑,RC6算法是在RC5算法基础之上针对RC5算法中的漏洞,主要是循环移位的位移量并不取决于要移动次数的所有比特,通过采用引入乘法运算来决定循环移位次数的方法,对RC5算法进行了改进,从而大大提高了RC6算法的安全性。因此,在一些对数据安全性要求很高的情况下,应该采用RC6算法。

结语

RC5及RC6算法是两种新型的分组密码,它们都具有可变的字长,可变的加密轮数,可变的密钥长度;同时,它们又只使用了常见的初等运算操作,这使它们有很好的适应性,很高的运算速度,并且非常适合于硬件和软件实现。两种算法各有其优缺点,在工程应用中应该根据实际需要选择最适合的方法,以得到最优的效果。

关键字:RC5  RC6  分组密码  混合密钥  Flash 引用地址:Atmega128单片机的RC5和RC6算法比较与改进

上一篇:Atmega128单片机CRC校验码的查表与直接生成
下一篇:AVR单片机在跳频系统数字信号处理中的应用

推荐阅读最新更新时间:2024-03-16 12:49

MSP430F149内部Flash操作
硬件介绍: 要对Flash读写,首先要了解MSP430的存储器组织。430单片机的存储器组织结构采用冯诺依曼结构,RAM和ROM统一编址在同一寻址空间中,没有代码空间和数据空间之分。 一般430的单片机都统一编址在0-64k地址范围中,只有少数高端的型号才能突破64k(如:FG461x系列)。绝大多数的msp430单片机都编址在64kB范围内。地址的大概编码方式如下: 这是msp430f425的存储器分配图,其他在64k范围内的存储器的单片机编址方式与此类似:低256B是寄存器区,然后是RAM;空白;1000H到10FFH是信息Flash区;大于1100H-0FFFFH是主存储器区(从0FFFFH开始往低地址有单片机的主F
[单片机]
MSP430F149内部<font color='red'>Flash</font>操作
stm32f103zet6怎么保存flash参数
  STM32的闪存模块由:主存储器、信息块和闪存存储器接口寄存器等 3 部分组成。   主存储器,该部分用来存放代码和数据常数(如 const 类型的数据)。对于大容量产品,其被划分为 256 页,每页 2K 字节。注意,小容量和中容量产品则每页只有 1K 字节。从上图可以看出主存储器的起始地址就是0X08000000, B0、B1 都接 GND 的时候,就是从 0X08000000开始运行代码的。      信息块,该部分分为 2 个小部分,其中启动程序代码,是用来存储 ST 自带的启动程序,用于串口下载代码,当 B0 接 V3.3,B1 接 GND 的时候,运行的就是这部分代码。用户选择字节,则一般用于配置写保护、读保护等
[单片机]
stm32f103zet6怎么保存<font color='red'>flash</font>参数
利用ST-LINK配合ST-LINK Utility 将bin文件下载到STM32的FLASH
背景 项目需求,要把字模文件导入到32中FLASH的指定地址,使用了ST-LINK V2 连接单片机和计算机,然后通过ST-LINK Utility 软件的配合将弄好的字模bin文件导入到FLASH指定地址。下面记录一下整个过程: 1.连接ST-LINK V2与单片机 博主的只需要连接4个线即可: VDD GND SWCLK SWDIO 2.配置工程 然后打开工程,进行配置,选择ST-Link Debugger 然后查看是否检测到ST-Link(选择SW) 如果你的可以显示如图内容,那么就成功连接了。 3.配置ST-LINK Utility 打开软件后的界面如示: 点击蓝色的球,打开设置界面,设置Por
[单片机]
利用ST-LINK配合ST-LINK Utility 将bin文件下载到STM32的<font color='red'>FLASH</font>中
华邦全新QspiNAND Flash赋能NB-IoT
全球半导体储存解决方案领导厂商华邦电子,宣布推出拥有新功能的 QspiNAND Flash,是专为 Qualcomm® 9205 LTE 调制解调器而设计的。 华邦推出业界首创的 1.8V 512Mb (64MB) QspiNAND Flash,为新型行动网络 NB-IoT 模块的设计人员提供正确的储存容量。 “到了2020年,物联网的规模将成长到500亿个连网装置,未来几年 Quad SPI-NAND 的采用率可能会增加4到5倍,” WebFeet Research 总裁 Alan Niebel 说道,“华邦的 1.8V QspiNAND Flash 相当适合汽车及 IoT 产业使用。NB-IoT 已经蓄势待发,在
[嵌入式]
华邦全新QspiNAND <font color='red'>Flash</font>赋能NB-IoT
MSP430 flash写入(二)
/* --COPYRIGHT--,BSD_EX * Copyright (c) 2012, Texas Instruments Incorporated * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * * Redistributions of source code must retain the above c
[单片机]
U-boot-2014.04移植到MINI2440(10) 移植nand flash保存环境变量、添加分区
一.保存环境变量到nand flash 第一步:修改mini2440.h 由于我们执行saveenv这个命令,然后保存环境变量,u-boot的命令都是在common下实现的,切进去执行gerp “saveenv” –nr ./*.c,查找出如下结果: 这里出现了很多,打开Makefile: # environment obj-y += env_attr.o obj-y += env_callback.o obj-y += env_flags.o obj-$(CONFIG_ENV_IS_IN_DATAFLASH) +=env_dataflash.o obj-$(CONFIG_ENV_IS_IN_E
[单片机]
U-boot-2014.04移植到MINI2440(10) 移植nand <font color='red'>flash</font>保存环境变量、添加分区
2012年Q1 NAND Flash厂营收排名,三星维持第一东芝紧追在后
    May 8, 2012---2012年第一季NAND Flash市场在全球经济复苏缓慢及中国农历年长假销售不如业者预期情况下,除了少数平板计算机及智能型手机客户的OEM需求较稳定外,多数的系统产品客户及记忆卡与随身碟通路市场客户需求,受淡季效应及消化过剩库存影响,呈现疲弱不振的状况。根据TrendForce旗下研究部门DRAMeXchange调查显示,市场在供过于求情况下,2012年第一季 NAND Flash品牌供货商的ASP较上季大幅下跌约16%,第一季整体NAND Flash品牌供货商的位元出货量较上季成长约16% ,故2012年第一季整体NAND Flash品牌供货商营收为47亿9千1百万美元,较上季减少约2.5%。
[手机便携]
基于FLASH介质嵌入式存储方案的设计与实现
摘要 作为一种新型的存储介质,FLASH以其优良的特性,在嵌入式领域中得到了广泛的应用。本文通过分析FLASH介质的自身特性,并结合嵌入式系统的特点,设计实现于兼容性、可靠性以及开销等方面都得到充分优化的FLASH存储系统。 关键字 嵌入式系统 文件系统 FLASH 1 引言 FLASH(闪速存储器)作为一种安全、快速的存储体,具有体积小、容量大、成本低、掉电数据不丢失等一系列优点,已成为嵌入式系统中数据和程序最主要的载体。由于FLASH在结构和操作方式上与硬盘、E2ROM等其他存储介质有较大区别,使用FLASH时必须根据其自身特性,对存储系统进行特殊设计,以保证系统的性能达到最优。 2 FLASH的特点 FLASH是一
[缓冲存储]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

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

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

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