大家好,我是痞子衡,是正经搞技术的痞子。今天痞子衡给大家讲的是嵌入式里数据差错控制技术 - 重复校验。
在嵌入式应用里,除了最核心的数据处理外,我们还会经常和数据传输打交道。数据传输需要硬件传输接口的支持,串行接口由于占用引脚少的优点目前应用比并行接口广泛,常用的串行接口种类非常多,比如 UART,SPI,I2C,USB 等,在使用这些接口传输数据时避不可免会遇到一个问题,如果传输过程中遇到未知硬件干扰发生 bit 错误怎么办?
痞子衡今天给大家讲的就是数据传输过程中用于差错检测的最简单的方法,即重复校验法。
一、重复校验法基本原理
1.1 校验依据
重复校验法的校验依据就是判断重复传输的 q 组 n bits 二进制数据是否一致。
1.2 重复校验位
为了实现重复校验,就是不断重复传输这组 n bits 原始数据 q 次即可,一次校验的 q*n bits 数据块中,仅有 n bits 数据是原始有效数据,校验位就是那些重复的(q-1)*n bits 数据。是不是觉得简单又粗暴?
1.3 校验方法
假设原始数据块是 X[n-1:0]共 n bits,重复次数为 q(q 一般为奇数),按重复传输方式,可分为两个子类:
按 bit 重复:发送数据序列为,q 个 X0(X0X0...),q 个 X1(