附录-整套24c16单片机读写驱动程序文件

上传人:仙*** 文档编号:104563648 上传时间:2022-06-10 格式:DOC 页数:8 大小:55.50KB
返回 下载 相关 举报
附录-整套24c16单片机读写驱动程序文件_第1页
第1页 / 共8页
附录-整套24c16单片机读写驱动程序文件_第2页
第2页 / 共8页
附录-整套24c16单片机读写驱动程序文件_第3页
第3页 / 共8页
点击查看更多>>
资源描述
. 用单片机实现通用存贮器IC卡的读写自动化仪表2002 Vol.23 No.6 P.37-41本文对AT24系列存贮器和AT89系列单片机的特征与总线状态作为介绍,并以AT24C01与AT89C2051为例详细描述了通用存贮器IC卡的工作原理与用单片机对其进行读写操作的基本电路连接和软件编程方法。用存贮器IC卡是由通用存贮器芯片封装而成的,由于它的结构和功能简单,生产成本低,使用方便,因此在各领域都得到了广泛的应用。目前用于IC卡的通用存贮器芯片多为E2PROM,其常用的协议主要有两线串行连接协议(I2C)和三线串行协议,其中比较常用的是ATMEL公司生产的AT24系列芯片。以该系列中的AT24C01为例,它具有1k的存贮容量,适用于2V5V的低电压/标准电压的操作,具有低功耗和高可靠性等优点。而AT89C2051虽是ATMEL公司89系列单片机的低档型,但它具有2k的FLASH ROM(可重编闪速存贮器)、1288位部RAM与全静态操作方式,同样也具有低功耗和较强的功能。下面以AT24C2051为例,对通用存贮器IC卡的工作原理与基本电路连线作一介绍,该线路简单,使用灵活,能可靠地对通用存贮器IC卡进行读写。 2 硬件特性 2.1 AT24系列存贮器的特性 AT24系列存贮器芯片采用CMOS工艺制造,置有高压泵,可在单电压供电条件下工作。其标准封装为8脚DIP封装形式,各引脚的功能说明如下:SCL:串行时钟。在该脚的上升沿时,系统将数据输入到每个EEPROM器件,在下降沿时输出。 SDA:串行数据。该引脚为开漏极驱动,可双向传送数据。 A0、A1、A2:器件/页面寻址。为器件地址输入端。在AT24C01/02中,该引脚被硬连接。 Vcc:一般输入+5V的工作电压。 图1是符合ISO7816-2标准的IC卡的触点图(见IC卡书P186)。对于AT24系列通用存贮器IC卡来说,通常只需使用四个触点。AT24C01的部组态为128个8位字节,而对随机字寻址则需要一个7位地址。2.2 总线状态与时序 AT24C01的SCL与SDA两总线可通过一个电阻上拉为高电平,SDA上的数据仅在SCL为低电平时才能改变。当SCL为高电平时,SDA的改变表示“开始”和“停止”状态。此时,所有地址和数据字都以8位串行码方式输入输出EEPROM。 开始状态:SCL为高电平时,SDA由高电平转入低电平。该命令必须在其它命令前执行。SCLSDA停止状态:SCL为高电平时,SDA由低电平转入高电平。该命令可终止所有通讯。SCLSDA确认:相同总线上的设备在收到数据后,以置SDA为低电平的方式对其进行确认。SCLSDA2.3 器件寻址 AT24系列EEPROM在开始状态后需紧接一个8位器件地址,以进行应读写操作。设备寻址码的高4位为1、0、1、0,对于AT24C01/02,寻址码高4位后面的三位是器件寻址码,与它们的硬连线管脚相对应。最低应是读写选择位,置0时可激发读操作。 AT24设备寻址码具体的格式如下: 1010A2A1A0R/W 2.4 AT89C2051芯片 AT89C2051是MCS-51产品的兼容型,它具有2k的FLASH ROM、128字节ROM,15根I/O引线、两个16位定时/计数器、一个五向量两级中断结构、一个全双工串行口、一个精密模拟比较器以与片振荡电路和时钟电路。它的P1口和P3口是双向I/O口,其中P1.2P1.7、P3.0P3.5和P3.7带有部上拉电阻。在AT89C2051用作输入端时,将首先向引脚写“1”而使部MOS管截止以便引脚处于悬浮状态,从而可获得高阻抗输入。 图2为通用存贮器IC卡的基本电路连接图。(略)3 读写操作软件 当系统采用6MHz晶体振荡器时所定义的I/O口线与器件地址如下: SCL BIT P1.7 SDA BIT P1.6 DEVICEAD_W DATA 10100000B ;写卡器件地址 DEVICEAD_R DATA 10100001B ;读卡器件地址 3.1 开始条件(START_IC) 当SCL为高电平时,SDA由高转为低。程序如下: SCL 0SDA 在SCL、SDA全1前提下进入开始,开始完成后,SCL、SDA全0 0START_IC:CLR SCL;SCL由高变低,因为SCL低电平时才允许SDA更改 NOP ;加入空指令延时以确保信号可靠 NOP SETB SDA ;SDA先高NOP NOP SETB SCL ;SCL高,起始条件建立时间大于4.7usNOP NOP CLR SDA ;SDA低,起始条件锁定时大于4usNOP NOP CLR SCL ;SCL低, 钳住总线,准备发数据NOP RET 3.2 停止条件(STOP_IC) 当SCL为高电平时,SDA由低转为高。程序如下:SCLSDA;在SCL、SDA高或低的前提下均可进入停止过程 ; 停止过程完成后,SCL、SDA全1STOP_IC:CLR SCL ;SCL低NOP CLR SDA NOP NOP SETB SCL ; 发送完毕条件的时钟信号NOP ;完毕总线时间大于4us(取4.7us)NOP SETB SDA ;完毕总线NOP ;保证一个终止信号和起始信号的空闲时间大于4.7usNOP ;在SCL、SDA高或低的前提下均可进入停止,停止完成后,SCL、SDA全1RET 3.3 应答确认信号(MACK_IC)与非应答信号MNACK_IC在接收方,每收到一字节后便将SDA电平拉低,程序如下:SCL 0SDA 1 ;应答完成后,SCL=0,SDA=1应答确认信号(MACK_IC)MACK_IC:CLR SCL NOP CLR SDA ;在第9个SLC脉冲,将SDA置0NOP NOP SEIB SCL NOP ;保持数据时间,即SCL为高时间大于4.7usNOP CLR SCL NOP SETB SDA ;在SDA高或低的任何前提下,应答完成后,SCL=0,SDA=1NOP RET 发送非应答信号MNACK_ICMNACK_IC: CLR SCL NOP NOP SETB SDA ;将SDA置1 NOP NOP SETB SCL NOP NOP ;保持数据时间,即SCL为高时间大于4.7us NOP NOP NOP CLR SCLNOP SETB SDA NOP RET 24C16程序资源安排是:R0=字节的循环指针,R2=位数的计数器,R3=卡器件地址, R4=字节地址,R5=字节数或页面长度。 R1可以留作其他循环指针,R6、R7可以留作uS级延时。3.4 写一字节数据到IC卡(WR_BYTE)SCLSDA D7 D6 D0 等待IC确认在以下程序中,参数A表示源数据,R2表示字节位数。WR_BYTE:MOV R2,#08 ;一字节8位数据 CLR SCL NOP NOP WR_BYTE1:RLC A ;带进位位左移,A.8-C MOV SDA,C ;SCL低电平时改变SDA上的数据 NOP SETB SCL ;拉高SCL =4.7uS把数据发送出去 NOP NOP CLR SCL NOP NOP DJNZ R2,WR_BYTE1;依次发送A中的8位数据 SETB SDA NOP NOP SETB SCL CLR F0 NOP NOP MOV C,SDA JC WR_BYTE2 SETB F0 ;判断应答位WR_BYTE2:NOP CLR SCL NOP RET此子程序的主要作用是按照定义的时序,顺序左移A中一字节8位数据,并通过引脚传送出去。当一字节发完后,等待IC卡发回的确认信号。 3.5 从IC卡读一字节(RD_BYTE) 从IC卡中读一字节的源程序如下:SCLSDA D7 D6 D0 发停止状态RD_BYTE:MOV R2,#08 SETB SDA ;设备SDA为读状态 CLR A ;清空A寄存器NOPNOPRD_BTYE1:SETB SCL ;时钟线为高,接收数据位NOP NOP MOV C,SDA ;读取一位数据到进位位RLC A ;左移数据到ACC.0 CLR SCL ;将SCL拉低,时间大于4.7us NOP NOPDJNZ R2,RD_BYTE1;依次读出8位数据到A中 RET ;无应答信号利用该程序可将读出的数据存放在A中。需要注意的是:读数据的器件不是通过确认状态来应答的,而是随后产生一个停止状态。 3.6 字节写入模式写单字节数据(WRITE_BYTE) 以下程序入口参数:R3=卡器件地址,R4= 目的字节地址, A= 待写数据 出口参数:F0 作应答位,F0=1有应答占用资源:A、R4、CY、F0发开始信号-写卡器件地址-写入字节地址-写入单字节数据-发停止信号WRITE_BYTE:PUSH ACC ;保存A中的数据LCALL START_IC ;发开始信号 MOV A,R3 ;写入器件地址8位LCALL WR_BYTE JNB F0,RETWRB ;无应答则跳转MOV A,R4 ;写入字节地址8位LCALL WR_BYTE JNB F0,RETWRB ;无应答则跳转POP ACC ;恢复待写的A中数据 LCALL WR_BYTE ;写入单字节数据LCALL STOP_IC ;发停止信号RETRETWRB: POP ACCLCALL STOPRET在收到8位数据后,EEPROM将通过SDA来回送确认信号,而传送设备必须用停止状态来终止写操作。这时,EEPROM将进入一个时固定存贮器的写入周期并且禁止在此其间的所有输入,直到写操作完成后才对通讯应答。其写入周期可自定义,最大为10ms。 3.7 页面写入模式写多字节数据(WRITE_PAGE)入口参数:R3=卡器件地址,R4= 目的字节地址,R5=页面长度。R0=写数据缓冲指针发开始信号-写卡器件地址-写页面目的地址-连续写(R5)个字节数据-发停止信号WRITE_PAGE:LCALL START_IC;发开始信号MOV A,R3 ;写卡器件地址LCALL WR_BYTEJNB F0, IWRNBYTEMOV A,R4 ;写页面目的地址LCALL WR_BYTE JNB F0, IWRNBYTEWRITE_PAGE1:MOV A,R0 ;连续写(R5)个字节数据LCALL WR_BYTE JNB F0, IWRNBYTEINC R0DJNZ R5,WRITE_PAGE1 IWRNBYTE:LCALL STOP_IC ;发停止信号RET AT24C01/02可利用上述程序进行8字节的页面写入,它的操作类似于写字节。不同的是,它无需在第一个字节送出后以停止状态,不同在收到确认信号后,再传送7个字节的数据码,最后以停止状态来终止页面写序列。AT24C04/08/16的页面为16字节。3.8 立即性地址读单字节模式(READ_BYTEC) 立即地址读模式读一字节数据的程序如下:入口参数:R3=卡器件地址,(字节源地址以芯片的当前地址)出口数据:读取数据ACC 开始信号-写出读卡器件-读出默认地址数据-发停止状态应答READ_BYTEC:LCALL START_IC ;开始信号MOV A,R3 ;写读卡器件地址LCALL WR_BYTE JNB F0, RETRDBLCALL RD_BYTE ;读出默认地址数据 LCALL MNACK ;读完最后一个字节数据需要发非应答信号RETRDB : LCALL STOP_IC;发停止状态应答 RET 该程序执行后,其部数据字地址指针将保持在上次读写操作访问的最后一个地址,并按1递增且在芯片上电期间一直有效。只有当地址为页面的最末时,下次访问才滚动到该页面的首地址。 3.9 选择性地址读单字节模式(READ_BYTER) 在以下程序中,R3=卡器件地址,R4= 字节源地址出口数据:读取数据ACC程序如下:开始信号-执行空字节写卡器件地址-写入源地址-开始信号-写卡器件地址-立即地址的数据读出停止信号READ_BYTER:LCALL START_IC ;启动总线MOV A,R3 ;执行空字节写卡器件地址LCALL WR_BYTE JNB F0,READ_BYTE3MOV A,R4 ;写入源字节地址LCALL WR_BYTELCALL START_IC ;重新启动总线MOV A,R3LCALL WR_BYTE ;写卡器件地址 JNB F0,READ_BYTE3LCALL RD_BYTE ;立即地址数据读出LCALL MNACK ;读完最后一个字节数据需要发非应答信号READ_BYTE3: LCALL STOP_IC ;停止信号RET读操作模式需要一个字节写序列载入数据地址。在器件和数据地址写入并得到确认后,将再产生另一个开始条件,并送出读操作器件的地址,同时激发一个立即地址读取。 3.10 立即地址的连续读取N个字节数据(READ_BYTES);功能:从卡器件的当前立即字节地址开始读取N个数据入口参数: R3=卡器件地址,(字节源地址默认当前立即地址),R5=N数据长度出口参数: R0=目的指针开始信号-写出读卡器件-(R5)个立即地址的数据读出-停止信号READ_BYTES:LCALL START_IC ;开始信号MOV A,R3 ;写出读卡器件LCALL WR_BYTE JNB F0, BYTESRETREAD_BYS2:LCALL RD_BYTE ;连续立即地址的数据读出MOV R0,A ;存放数据到目的地址 INC R0DJNZ R5,READ_BYS1LCALL MNACK ;读完最后一个字节数据需要发非应答信号BYTESRET: LCALL STOP_IC ;读完N个字节后发停止信号RET READ_BYS1:LCALL ACK_IC ;收到数据后发确认信号SJMP READ_BYS2其中连续读取由立即地址读或选择性地址读激发,并在收到一字节数据后发确认信号应答。当读数器件以停止状态应答时,操作被终止。 3.11选择性地址的连续读取N个字节数据(READ_BYTES) ;功能:从卡器件某指定的字节地址开始读取N个数据;入口参数: R3=卡器件地址,R4= 字节源地址,R5=N数据长度;出口参数: R0=接收数据目的缓冲区指针;占用资源:A、 R0、 R2、R3、 R4、 R5、CY IRDNBYTE: LCALL START ;启动总线 MOV A, R3 LCALL WR_BYTE ;发送卡器件地址 JNB F0 ,RETRDN MOV A,R4 ;指定源字节地址 LCALL WR_BYTE LCALL START ;重新启动总线 MOV A,R3 LCALL WR_BYTE ;写卡器件地址 JNB F0,IRDNBYTE RDN1: LCALL RDBYTE ;读操作开始 MOV R0,A INC R0 DJNZ R5,SACK LCALL MNACK ;读完最后一个字节数据需要发非应答信号RETRDN: LCALL STOP_IC ; 发停止信号 RETSACK: LCALL MACK SJMP RDN14 总结该系统结构简单,在实际运行时具有很高的可靠性,同时具有一定的可扩展性,并可通过单片机的串行口经电平转换后直接与计算机相连,以进行数据通讯。另外,也可根据需要连接到其它引脚或卡座触点,如果适当改进电路和程序,还可读写加密卡和CPU卡等。8 / 8
展开阅读全文
相关资源
相关搜索

最新文档


当前位置:首页 > 管理文书 > 施工组织


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!