查看: 585|回复: 0

CPU卡的软件设计

[复制链接]

该用户从未签到

发表于 2020-12-1 18:20:05 | 显示全部楼层 |阅读模式
分享到:
CPU卡在数据传输方式上与存储卡是不同的,它采用的是串行异步半双工方式,所以在对CPU卡进行读写设计时,首先应计算出在I/O线上数据的位宽,以保证通信的正确;其次,由于采用的是MSP430F系列单片机,它采用了DCO技术,其向系统提供的时钟频率是可调的,故应根据系统要求的时钟频率对基础时钟模块进行设置,以得到准确的时钟信号;在设计读写程序时,一定要按照ISO7816标准规定的流程进行编程,其编制成功的标志是能正确的接收复位信号,能发送命令,并根据每条命令的格式接收到正确的返回数据或状态标志。

I/O口线上所用的数据位宽度被确定为基本时间单位ETU(elementary time unit),计算公式为:ETU=372/f。

其中f为时钟频率,一般在1-5MHz之间选择,当时钟频率为3.75MHz时,传输的速率为9600波特率。

在实际单片机编程时,必须将ETU计算准确,否则将不能保证单片机与IC卡通讯的正确性和稳定性。

由于CPU卡是采用串行异步半双工方式和终端通信,由终端向CPU卡提供时钟信号,并以此来控制交易的时序,所以在程序设计前应先计算出准确的ETU(基本时间单位)。ETU即I/O口线上所用的数据位宽度,ETU的计算可采用延时子程序的方式,在C语言环境下,可以在模拟仿真环境下,观察延时子程序所用的时钟周期,从而得到精确的ETU。

系统时钟MCLK的设置终端和CPU卡的时钟都是由MCLK提供,MCLK的时钟源来自DCO(数字控制振荡器)。MSP430F系列单片机的DCO振荡器被集成在FLL+时钟模块中,它产生的时钟信号可作为MCLK或SMCLK。

CPU卡和终端的时钟信号是由MCLK提供的,外接晶体的频率为32.768KHz,MCLX的频率设置为2MHz,以充分利用MSP430和CPU卡的高速性能。

另外,要想使MCLK信号能够输出,还必须将PJ.1口设置为MCLK输出模式。这样CPU卡的CLK端才能得到正确的时钟信号。
字节接收程序设计


2.jpg


字节发送程序设计
3.jpg
回复

使用道具 举报

您需要登录后才可以回帖 注册/登录

本版积分规则

关闭

站长推荐上一条 /4 下一条



手机版|小黑屋|与非网

GMT+8, 2024-11-22 16:54 , Processed in 0.107535 second(s), 16 queries , MemCache On.

ICP经营许可证 苏B2-20140176  苏ICP备14012660号-2   苏州灵动帧格网络科技有限公司 版权所有.

苏公网安备 32059002001037号

Powered by Discuz! X3.4

Copyright © 2001-2024, Tencent Cloud.