杰发科技AC7840——SENT数据解析及软件Sent发送的实现

0. 测试环境

AC7840官方Demo板;

图莫斯0503

DSlogic U2Basic

使用引脚 输出脚:PB1 时钟:PB2,其他引脚可以不初始化,不接线

1. 数据解析

以下是SENT数据的格式(1tick以3us为例):

  1. 最小脉冲周期为12个时钟节拍=36us
  2. 每个脉冲,低电平持续时间最少为4个时钟节拍=12us
  3. 数据脉冲最低脉冲周期为12个时钟节拍/36us(对应半字节值0)
  4. 数据脉冲最低脉冲周期为27个时钟节拍/81us(对应半字节值15)
  5. Sync 同步脉冲,固定的56Ticks
  6. Status/Com 状态及通讯字段,12~27Ticks,即1个Nibble(4bit)
  7. Data 数据段,12~162Ticks,即1~6个Nibble
  8. CRC 校验字段,12~27Ticks,即1个Nibble
  9. Pause 暂停脉冲 12-768TICKs,早期的SENT协议无此字段或者一个周定长度TCKS,SENT2010之后,部分通讨此功能可以动态条件TICKS的个数,实现整个SENT协议是同一个固定长度TICKS

逻辑分析仪测试发送数据0符合上述数据

发送数据1如下所示

发送数据2如下所示

发送数据3如下所示

发送数据15如下所示

综上所述,主要区别在数据帧的高电平长度。

以下是发送0123456的数据格式,可以看到,数据位的长度为(21+3*N)

同步脉冲:格式固定为15uS+152uS=167uS的数据

2. SPI数据结构

测试在110K波特率的情况下,SPI发送一个位的时间为1uS。

以此为基准生成Sent的数据帧

SPI生成Sent数据

可以看到上面和我们用图莫斯发出来的波形一模一样。

最后一个FF是用来拉高电平,否则第一个从高到低的数据出不来。

可以看到,其中从F0开始是数据位,到第28个数据FE是数据位,后面是每个脉冲必须的4个tick的低电平,即12us

以下是0-F的校验码

发送2个字节

cpp 复制代码
    while (1)
    {
        g_spiTxBuff1[0] = 0;
        g_spiTxBuff1[1] = 0x3;
        for (int i = 0; i < 18; i++)
        {
            g_spiTxBuff1[i + 2] = 0xff;
        }

        g_spiTxBuff1[20] = 0;
        g_spiTxBuff1[21] = 0x1;
        g_spiTxBuff1[22] = 0xff;
        g_spiTxBuff1[23] = 0xff;
        g_spiTxBuff1[24] = 0xf0;
        g_spiTxBuff1[25] = 0;
        g_spiTxBuff1[26] = 0x1f; // 00011111后5位参与数据位高电平
        g_spiTxBuff1[27] = 0xff; // 参与数据位高电平
        g_spiTxBuff1[28] = 0xfe; // 参与数据位高电平
        g_spiTxBuff1[29] = 0x00;
        g_spiTxBuff1[30] = 0x03;
        g_spiTxBuff1[31] = 0xff;
        g_spiTxBuff1[32] = 0xff;
        g_spiTxBuff1[33] = 0xf8;
        g_spiTxBuff1[34] = 0x00;
        g_spiTxBuff1[35] = 0x0f;
        g_spiTxBuff1[36] = 0xff;

        SPI_DRV_MasterTransfer(SPI_INSTANCE, g_spiTxBuff1, g_spiRxBuff1, 37); /*! SPI通信 */
        OSIF_TimeDelay(100);
    }

能识别到,就是校验码还需要再优化下

相关推荐
范纹杉想快点毕业14 小时前
ZYNQ芯片,SPI驱动开发自学全解析个人笔记【FPGA】【赛灵思
stm32·单片机·嵌入式硬件·mcu·架构·51单片机·proteus
猫猫的小茶馆2 天前
【STM32】FreeRTOS 任务的创建(二)
stm32·单片机·嵌入式硬件·mcu·c#·智能硬件
易硅4 天前
AG32 mcu+cpld 联合编程(概念及流程)
vscode·单片机·嵌入式硬件·mcu·fpga开发
liu_endong5 天前
杰发科技AC7840——硬件crc使用
mcu·国产·杰发科技·autochips·车规芯片
网易独家音乐人Mike Zhou7 天前
【Linux应用】在PC的Linux环境下通过chroot运行ARM虚拟机镜像img文件(需要依赖qemu-aarch64、不需要重新安装iso)
linux·c语言·stm32·mcu·物联网·嵌入式·iot
S,D8 天前
锁步核,为什么叫锁步核?
驱动开发·单片机·嵌入式硬件·mcu·iso26262·锁步核·车规mcu
S,D8 天前
MBIST - Memory BIST会对memory进行清零吗?
驱动开发·mcu·memory·功能安全·iso26262·mbist·bist
S,D10 天前
MCU进入低功耗模式前的引脚处理原则和方法 --> 以最小化低功耗电流
驱动开发·stm32·单片机·嵌入式硬件·mcu·standby·低功耗引脚处理
千帐灯无此声10 天前
iw 命令 -- linux 无线管理
linux·运维·服务器·mcu
切糕师学AI13 天前
MCU中的系统控制器(System Controller)是什么?
嵌入式硬件·mcu