CPU卡中T=0通讯协议的分析与实现.docxVIP

  1. 1、本文档共3页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
CPU卡中T=0通讯协议的分析与实现 摘要:t=0是国际标准中规定的一种接触式cpu卡通讯协议。结合开发实践,将该协议分为四个层次,主要从cpu卡的角度出发,结合终端,从两个方面系统地阐述了该协议的特点和实现过程,并对t=0协议的优缺点进行了分析,目前已将开发成果应用于实际中。关键词:卡片操作系统(cos)终端应用层(tal)终端传输层(ttl)应用协议数据单元(apdu)传输协议数据单元(tpdu)ic卡的应用越来越广泛,从存储卡到逻辑加密卡,目前cpu卡已经逐渐在应用中占据主导地位。cpu卡根据通讯协议可分为两种:接触式和非接触式。接触式cpu卡主要采用两种通讯协议:t=0和t=1通讯协议。t=0是异步半双工字符传输协议,t=1是异步半双工块传输协议。目前t=0通讯协议的应用较为广泛,国内外大多数cpu卡都支持该协议,在金融交易中也采用这种通讯协议。为了便于说明问题,本文从t=0协议的功能出发,将该协议分为四个层次:物理层、数据链路层、终端传输层和应用层,见图1。由于该协议的特殊性,终端传输层与应用层联系非常紧密,实现起来比较繁琐,在cpu卡中,这些任务通过卡片操作系统(cos)来实现。终端在与卡的信息交换中,始终处于主动地位,终端向卡发送符合t=0协议的命令字节,卡中的cos完成对数据的处理并将处理结果返回给终端。下面对t=0协议的四个层次进行详述。1t=0协议的物理层描述终端与智能卡之间通过改变i/o传输线上的电平来交换信息。由于t=0协议是面向字符的传输协议,这里先定义字符帧的结构,并对组成字符帧位的信息表示作了具体描述。字符帧的结构如图2所示。字符帧由1个起始位s、8个数据位和1个偶校验位p共10位组成。在数据传输中每一位的持续时间称为基本时间单元etu(elementarytimeunit),etu的值由时钟频率决定,etu与时钟频率呈现性关系:1etu=(f/d)×(1/f)(1)其中f称为时钟频率转换因子,d称为波特率调整因子。时钟频率的范围为1mhz~5mhz,正常的工作频率为3.57mhz,数据传输的波特率采用9600bps,根据国际标准的取值范围,取f=372,d=1,代入式(1),可得:1etu=372/f=372(2)即一个基本时间单元为372个时钟周期。将工作频率定为3.57mhz,可以保证数据传输的波特率为9600bps。如果要提高数据的传输率,可以调整参数f来确定传输率。对每一位电平采用三次采样来确定,在位持续时间的中间和左右15%的间隔各取样一次,取样点如图3所示。当有两次以上电平为低,则判断该位为0;否则该位为1,这样确保了取样值的可靠性。由于数据位的持续时间是用汇编语句来控制的,可以通过延时语句调整采样的时间间隔。但实现采样的最基本汇编语句的执行时间不能再缩短,因此数据传输率有一上限。当每一位取样三次时,数据传输率最高可达到57600bps。如果再提高速率,取样时序将无法保证。字符帧的起始位为低电平,起始位的检测是通过周期性地对i/o传输线进行采样来得到。国际标准中规定采样时间间隔不得大于0.2etu,实际上起始位的采样时间间隔只有几个时钟周期,完全满足要求。2t=0协议的数据链路层实现数据链路层描述了字符交换的时序要求和差错控制以及终端对面向传输的错误的处理,在逻辑上保证终端和卡片之间能够正确可靠地通讯。采用上述的字符帧,终端与卡之间进行数据将交换,字符之间有严格的时序,时序是通过汇编程序语句的执行时间来控制的。从终端到卡发送的连续字符的起始位下降沿之间的最小时间间隔由复位应答信息通知终端,其值在12etu~266etu之间。从卡发送到终端的连续字符的起始位下降沿之间的最小时间间隔应为12etu。如果字符接收不正确或字符接收正确但校验位不正确,接收端需要在字符起始位下降沿后的(10.5±0.2个etu时刻将i/o线置为低电平约1~2个etu,见图4,用于向发送端指明错误;发送端在(11±0.2)个etu时刻检测i/o线。如为高电平则表示字符已经正确接收;如果发送端检测到错误,则在检测到错误那一刻起,2个etu后重发该字符,但重复发送同一字符的次数不得超过3次。如果最后一次发送失败,当终端是接收端时,则终端应该在无效字符的起始位下降沿后的960个etu时间范围内启动释放序列;当终端是发送端时,在卡片检测到字符的偶校验错误后960个etu时间范围内,终端启动释放序列。命令的执行总是由终端应用层(tal)启动,通过终端传输层(ttl)送给卡片。ttl与卡片进行命令字节和数据字节交换时,要保证能够有序正确地进行。 因此,在数据交换过程中,TTL和卡应该在任何时候隐式地知道哪一方是发送方,哪一方是接收方。当卡收到5字节的命令字节时,需要将一个进程字节或两个状态字节返回到TTL。具

文档评论(0)

132****0657 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档

相关课程推荐