历史上的今天
返回首页

历史上的今天

今天是:2025年04月07日(星期一)

正在发生

2018年04月07日 | DS1991的简介及其带密码保护存储器区的读写方法分析

2018-04-07 来源:eefocus

    Dallas公司的iButton产品是一系列1-wire总线新型器件。DS1991是一种加密存储器型信息纽扣,封装于直径为16mm的不锈钢外壳中,体积小巧,便于携带、保存,防尘、防腐蚀,可以在恶劣的应用环境中实现带密码保护的数据传送。本文介绍DS1991的特点、工作原理及其带密码保护存储器区的读写方法。

    内容摘要:


    DS1991是Dallas公司的1-wire总线信息纽扣家庭中的一员,是一种加密存储器型信息纽扣。它内部集成了1Kbit是非易失性存储器及加密保护逻辑,封装于直径为16mm、厚约6mm的不锈钢外壳中,何种小巧、操作便捷,防潮、抗震、防灰尘,可在恶劣的环境中实现带密码保护的数据传送。

    1 DS1991的特点

    DS1991是一种很有特色的加密存储器型TM卡,为用户的保密数据提价节可靠的保护措施。DS1991内部有1152位的密码保护存储器区,512位的非密码保护存储器scratchpad。密码保护存储器被分为三个可独立操作的密钥子存储器(subkey),每区为384位,每个密钱子区都有自己的64位密码及64位的ID码,对密钥子区的读/写操作均需进行密码验证。三个区的数据可分别操作,互不干扰。非密码保护存储器区主要用于加密数据的拷贝,以保证数据的完整性。

    2 DS1991与单片机硬件接口及软件设计

    DS1991与单片机的硬件接口电路如图1。545

    DS1991与单片机的接口非常方便,只用1根数据线和1根地址.数据线由单片机的1根I/O口线控制,口线外接一个5kΩ的上拉电阻.DIOBITP1.0;引脚定义RETDJNZR6,WRB1

    DS1991操作的基础是1-wire总线的初始化、读/写1位时序,如图2、图3、图4和图5.VPULLUP为图1中D点在口线为输入状态时的电位.初始化由主机发出复位脉冲.DS1991回复应答脉冲,使主机了解DS1991存在于总线上并已作好操作准备.命令和数据的各个字节由最低有效位起一位一位传送.子程序RESET、RDBYTE和WRBYTE分别是初始化、读/写1字节的子程序.

545

    RESET:CLR DIO ;得位子程序

    MOV R7,#205

    DELPP1:NOP

    DJNZ R7,DELPP1

    SETB DIO

    MOV R7,#12

    DJNZ R7,$

    MOV R7,#27

    RESETP1:JNB DIO,RESETP2

    DJNZ R7,RESETP1

    RESRET:SETB DIO

    MOV A,#0EH

    RESETP2:MOV R7,#75

    DJNZ R7,$

    MOV R7,#54

    RESETP4:JB DIO,RESETP5

    DJNZ R7,RESETP4

    RESETP5:MOV R7,#180

    DJNZ R7,$

    SETB DIO

    MOV A,#0

    RET

    WRBYTE:MOV R6,#8 ;写1字节子程序

    WRB1:CLR DIO

    MOV R7,#2

    DJNZ R7,$

    RRC A

    MOV DIO,C

    MOV R7,#30H

    DJNZ R7,$

    SETB DIO

    NOP

    NAP

    NOP

    RET

    RDBYTE:MOV R6,#8 ;读1字节子程序

    RDB1:CLR DUO

    NOP

    NOP

    SETB DIO

    MOV R7,#3

    DJNZ R7,$

    MOV C,DIO

    RRC A

    MOV R7,#32

    DJNZ R7,$

    SETB DIO

    MOV R7,#3

    DJNZ R7,$

    DJNZ R6,RDB1

    RET

545

    3 DS1991激光ROM码、存储器结构及操作

    像所有的1-wire总线器件一样,主机必须先进行初始化和ROM操作,而后才能进行读写DS1991存储器的操作.

    DS1991有一个自身唯一的工厂刻入的64位激光ROM系列码.该码不会与其它任何一个1-wire总线器件相重.该码前8位是1-wire总线家族码,后48位是器件唯一的系列码,最后8位为前56位数据的CRC校验码.ROM操作指令建立被访问的1-wire器件与主机的连接,ROM操作指令如表1.DS1991的存储器映像如图1.

54

    表1 ROM操作指令

57


MOV A,#0

RET

WRBYTE:MOV R6,#8 ;写1字节子程序

WRB1:CLR DIO

MOV R7,#2

DJNZ R7,$

RRC A

MOV DIO,C

MOV R7,#30H

DJNZ R7,$

SETB DIO

NOP

NAP

NOP

 

RET

RDBYTE:MOV R6,#8 ;读1字节子程序

RDB1:CLR DUO

NOP

NOP

SETB DIO

MOV R7,#3

DJNZ R7,$

MOV C,DIO

RRC A

MOV R7,#32

DJNZ R7,$

SETB DIO

MOV R7,#3

DJNZ R7,$

DJNZ R6,RDB1

RET

3 DS1991激光ROM码、存储器结构及操作

像所有的1-wire总线器件一样,主机必须先进行初始化和ROM操作,而后才能进行读写DS1991存储器的操作。

DS1991有一个自身唯一的工厂刻入的64位激光ROM系列码。该码不会与其它任何一个1-wire总线器件相重。该码前8位是1-wire总线家族码,后48位是器件唯一的系列码,最后8位为前56位数据的CRC校验码。ROM操作指令建立被访问的1-wire器件与主机的连接,ROM操作指令如表1。DS1991的存储器映像如图1。

表1 ROM操作指令

命  令字  节功    能
read ROM33H读取DS1991的ROM系统列码
Match ROM55H总线接多个器件时用于寻址特定的器件
Skip ROMCCH总线上只有一个器件时,跳过ROM系列码的匹配而直接进行存储器的访问
Search ROMF0H主机使用该命令读加器件的ROM系列码

DS1991的scratchpad和每个subkey区都有自己的地址。Scratchpad共64字节,不受密码保护,主要用于将数据拷贝到密钥子区。密钥子区的00~07H为8字节的该区ID码,08H~0FH为8字节的该区密码,10H~3FH即为密码保护的数据存储区。

该/写Scratchpad不需要密码,但拷贝操作必须提供正确的密码。密码子区读写均受64位的密码保护,保密性大大提高。对存储器的操作指令如表2。存储器操作指令的流程如图2。

表2 DS1991存储器操作命令格式

命令第1字节第2字节第3
字节

功  能

bit7bit6bit5bit4bit3bit2bit1bit0
写scratchpad96H 1  1 00H~3FH中的任意值第2字节取反将数据写入scratchpad
读scratchpad69H从scratchpa读出数据
拷贝scratchpad3CHSubke区号
0    0或
0    1或
1    0 
000000将数据块从scratchpa拷贝到指定的subkey
读subkey66H10H~3FH中的任意值将数据写入subkey
写subkey99G从subkey中读取数据
写密码5AH000000将密码和ID码写入subkey

4 DS1991存储器的读写程序

主机读写DS1991的存储器由3个步骤组成:初始化、ROM操作和存储器读写。

下面的程序采用写SUBYKEY命令将RAM 40H~47H单元数据写入subkey 0区的10H~17H,并用读SUBKEY命令将该内容读回,存放RAM。50H~57H,该区的密码和ID码存放在程序的表格中。

;将RAM40H~47H单元内容写入

;subkey

WRSUBKEY:LCALL RETSET

MOV R2,#99H

MOV R0,#10H

LCALL WRCOM

LCALL IDPASS

MOV R1,#40H

MOV R4,#8

REWRSUB:MOV A,@R1

LCALL WRBYTE

INC R1

DJNZ R4,REWRSUB

LCALL RESET

RET

;读subkey存入RAM40H~47H

RDSUBKEY:LCALL RESET

MOV R2,#66H

MOV R0,#10H

LCALL WRCOM

LCALL IDPASS

MOV R1,#40H

MOV R4,#8

RERDSUB:LCALL RDYBTE

MOV @R1,A

INC R1

DJNZ R4,RERDSUB

LCALL RESET

RET

IDPASS:MOV R4,#8

MOV R1,#50H

RERD1:LCALL RDBYTE

MOV @R1,A

INC R1

DJNZ R4,RERD1

MOV R4,#8

CLR A

MOV DPTR,#PSTAB

REWR1:MOVC A,@A+DPTR

LCALL WRBYTE

INC A

DJNZ R4,REWR1

RET

IDTAB:DB10H,00H,00H,00H,

DB 00H,00H,00H,00H

PSTAB:DB12H,34H,56H,78H,DB12H,34H,56H,78H

WRCOM:MOV A,#33H

LCALL WRBYTE

MOV R4,#8

RDROM1:LCALL RDBYTE

DJNZ R4,RDROM1

MOV A,R2

LCALL WRBYTE

MOV A,R0

LCALL WRBYTE

MOV A,R0

CPL A

LCALL WRBYTE

RET



结语

DS1991的密码保护存储器区为用户提供高可靠的数据保护措施。本文提供的DS1991与单片机接口的软硬件设计,已在信息纽扣卡型公用电表系统中应用。

命  令字  节功    能
read ROM33H读取DS1991的ROM系统列码
Match ROM55H总线接多个器件时用于寻址特定的器件
Skip ROMCCH总线上只有一个器件时,跳过ROM系列码的匹配而直接进行存储器的访问
Search ROMF0H主机使用该命令读加器件的ROM系列码


推荐阅读

史海拾趣

Comax Industrial Co Ltd公司的发展小趣事

在电子产品市场竞争日益激烈的背景下,Comax Industrial Co Ltd公司始终坚持品质至上的原则。公司建立了严格的质量管理体系,从原材料的采购到生产制造的每一个环节都进行严格把控。通过持续改进和优化生产流程,公司不断提升产品的品质与性能。这种对品质的执着追求,使得Comax的产品在市场上赢得了广泛的认可与信赖。

常州星海电子(Starsea)公司的发展小趣事

随着市场需求的不断变化和消费者需求的多样化,常州星海电子不断调整和优化产品结构。公司现已形成了包括普通整流、开关、快速恢复、高效率、超快速、肖特基、双向触发管、整流桥、高反压以及瞬间突波电压吸收、稳压等多种系列、多种封装形式的二极管产品。这些产品广泛应用于电脑、家电、邮电通讯等行业,为公司赢得了广阔的市场空间。

Extech公司的发展小趣事

1994年,Extech公司推出了国内第一套基于“AutoCAD FOR WINDOWS”的XTMCAD软件,这一创新举措标志着公司在CAD领域迈出了坚实的步伐。XTMCAD软件凭借其先进的技术和易用性,迅速获得了市场的认可,并在同年荣获了国家教委科技进步一等奖。这一荣誉不仅是对Extech公司技术实力的肯定,也为公司未来的发展奠定了坚实的基础。

Abracon公司的发展小趣事

为了响应国家振兴制造业的号召,培养优秀的数字化设计与制造技术人才,Extech公司在近年来启动了“PLM China”计划。该计划面向全国高校提供价值1000万人民币的软件支持,旨在与教育行业携手合作,共同提升中国制造业的整体设计研发水平。通过这一计划的实施,Extech公司不仅展现了自己的社会责任感,也为中国制造业的发展做出了积极的贡献。

以上五个故事分别从不同角度展现了Extech公司在电子行业中的发展历程和成就。通过持续的创新和努力,Extech公司已经成为了一家在制造业信息化领域具有重要影响力的企业。

Antenna Factor公司的发展小趣事

随着无线通信技术的快速发展,Antenna Factor公司始终保持敏锐的洞察力,不断推出创新产品。他们研发的智能天线系统,能够根据信号环境的变化自动调整参数,显著提高通信质量和稳定性。这一技术创新在市场上引起了广泛的关注,使得Antenna Factor公司在行业中树立了技术领先的形象。

BERGQUIST公司的发展小趣事

随着电子设备的不断发展和性能提升,热管理问题变得日益突出。BERGQUIST公司凭借其在热管理领域的深厚积累,成功研发出了一系列具有革命性的热管理产品。这些产品不仅有效解决了电子设备散热问题,还大大提高了设备的稳定性和可靠性。其中,BERGQUIST的柔性石墨散热片凭借其优异的导热性能和良好的适应性,在市场上获得了广泛认可。

问答坊 | AI 解惑

PCB短路解决方法

PCB短路解决方法介绍…

查看全部问答>

MP3维修思路

一.不开机不找盘原因 1.更换66EP(1.5V稳压管).例:918 2.程序丢失,重升级.如:918 802 3.晶振不良,脱焊,假焊,晶振坏 4.开关坏,不良 5.电源断裂,二极管坏 6.USB坏,不良,USB内部短路 7.电池坏,开关坏 8.升压IC坏 9.FLASH虚焊,假焊 10.显示屏 ...…

查看全部问答>

周立功自己做的TKStudio大家有用过吗?

本信息来自合作QQ群:NXP Cortex-M0/M3交流(87394268) 群管理员在坛子里的ID:pepsi360     请教一个问题,周立功自己做的TKStudio大家有用过吗?…

查看全部问答>

MAX232真奇怪

前段时间用串口给STC芯片下载程序,但是怎么搞程序都烧不进去,而且在我点击download时MAX3232发出吱吱的响声,芯片瞬间发烫。后来上网查资料,有网友谈到这个国产MAX3232(CSE)的问题,后来我就换成MAX232的,现在烧程序时芯片不会发出声音,但是 ...…

查看全部问答>

CE下关于16C2550的驱动

RT,现准备学习16C2550的驱动,网上资料太少,故在此,求点资料。 先谢谢。…

查看全部问答>

请问VI是个什么东西

请问vi是什么东西呀?老师要我们翻译一篇文章, 我不知sub vi是什么意思?  还有就是context help是什么意思?多谢…

查看全部问答>

ADS1115IDGSR管脚

哪位大神知道ADS1115IDGSR的ALERT/RDY管脚是做什么用的,如果与51连接,悬空行不????急求…

查看全部问答>

TMP112温度传感器搞不定了

昨天用TI的低功耗温度传感器TMP112,单片机是MSP430F2132,使用IO模拟I2C,总是在写入第二个字节后,传感器没有应答,第一个字节是器件地址,第二个字节是内部寄存器地址,不知道怎么回事?各位大侠有用过这个传感器的吗?…

查看全部问答>

Xilinx DDS Compiler IP核使用问题,用过的高手来看一下

我要在FPGA中做数字正交,故此要用到DDS IP核,5.0版本的,但是研究了两天始终无法产生比较满意的正玄波,用ChipScope采到的波形要不是就是像下图这种,要不就是一些比较混乱的,反正不是比较正常的正玄波。 设置如下,外面给的aclk是50Mhz的, ...…

查看全部问答>

有没有网友有闲置的apple earpods耳机的?

本帖最后由 hanskying666 于 2015-3-10 22:23 编辑 有没有网友有闲置的apple earpods耳机的?iphone 5S 后面出的那个耳机,最好是全新的,是苹果手机自带的哦,不是市场上卖的!如果有想出售的请跟帖或私信,请附带价格,优先购买全新,谢谢!…

查看全部问答>