|
前言 本篇LAT的内容简介了STM32F0中关于USART中Smartcard模式的Guard Time的设置 问题 客户使用STM32F091的USART工作于smartcard模式用于7816通讯,发现不正常。 分析 用示波器观察波形,发现每个数据之间有较长时间的空闲电平。对比文档,这段时间应当是Guard time. 经查看代码,程序中设置Guard time (寄存器USARTx_GTPR中GT[7:0]位)为14。 那么7816协议里面是怎么定义Guard time的呢? 经查,协议里定义为” The minimum delay between the leading edges of two consecutive characters is named “guard time””。这就是说,规范里定义的Guard time实质上是包含了当前字符的时间长度。 那么寄存器里Guard time又是怎么定义的呢? 在Reference Manual中,有这样的描述:“In transmission, the USART inserts the Guard Time (as programmed in the Guard Time register) between two successive characters.”这就是说,对于STM32F091来说,其规定的Guard time不包含当前字符的时间长度。 结论 由上述分析可以看出,芯片和7816规范对于Guard time的定义略有差别,因此在程序中需要据此作出相应调整。 那么是否是芯片对此的定义有问题呢?恐怕也不能这么说。从芯片端来看,发送一个字符的时间长度其实已经由波特率决定了,能够单独进行设置的只是在字符发送完成之后插入的那一小段时间。于是,就将这个时间叫Guard time。可见,它实质上是为了实现7816协议的要求,两者本质上没有区别。 如果仔细看文档,里面已经特意说明:“As the Guard Time is measured after the stop bit of the previous character, the GT[7:0] register must be programmed to the desired CGT (Character Guard Time, as defined by the 7816-3 specification) minus 12 (the duration of one character).” 再对照文档中相关的图(如下图),这个问题就很清楚了。 详细解答请下载文档:https://www.stmcu.org.cn/document/detail/index/id-216739 更多实战经验文档请见:https://www.stmcu.org.cn/document/list/index/category-657 |
STM32
超强工具——STM32CubeMX 你会用吗?
集结出发! STM32全国研讨会系列之一:ST智能门铃中国首秀
关于STM32启动文件的几个小问题
【银杏科技ARM+FPGA双核心应用】STM32H7系列35——USB_VCP_FS
【银杏科技ARM+FPGA双核心应用】STM32H7系列28——USB_HID
粉丝分享 | 图说CRC原理应用及STM32硬件CRC外设
STM32L151进入低功耗,并由RTC唤醒的故事
[转]stm32控制NFC模块(PN532)源码(P2P,模拟卡,读写卡等
STM32G070RB+LVGL移植
微信公众号
手机版