STM32F407VET6+CCE4503学习笔记---IOLINK server

背景:最近在调试瑞萨 CCE4503 IOLINK芯片,期间调试遇到了一些串口相关的基础知识,各家对串口底层的数据位停止位的描述不一致,故在此作笔记一篇。

一、IOLINK通信规定,串口配置模式为8bit数据位+1bit偶校验位

1、ST家的芯片配置时,USART_InitStructure.USART_WordLength = USART_WordLength_9b;

此处的9bit包含了8bit的数据位与1bit校验位

复制代码
    USART_InitTypeDef USART_InitStructure;
    RCC_APB1PeriphClockCmd(RCC_APB1Periph_UART4, ENABLE);
    USART_InitStructure.USART_BaudRate = 115200;
    USART_InitStructure.USART_WordLength = USART_WordLength_9b;
    USART_InitStructure.USART_StopBits = USART_StopBits_1;
    USART_InitStructure.USART_Parity = USART_Parity_Even;
    //USART_Parity_No	    USART_Parity_Even	USART_Parity_Odd
    USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
    USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
    USART_Init(UART4, &USART_InitStructure);

2、Renesas 旗下E² stidio配置界面,此处的数据位与校验位分开描述,与ST配置时不一样,避免混淆

3、调试过程中用到了逻辑分析仪,DSView对数据位、校验位描述时与Renesas一致,也是分开描述

二、关于lsb-first与msb-first与实际波形关联关系

0xAA:10101010 0x55:01010101

lsb-first下代表0xAA

msb-first下代表0x55

其实lsb-first优先传输低位数据,msb-first优先传输高位数据,这也阐释了为什么波形一样,数据不一样,而我们ST芯片内部一般都为lsb-first。

三、关于串口奇偶校验位数据计算

简单来讲,此帧中,1的个数为偶数个,偶检验下检验位为0,奇校验下校验为1;1的个数为奇数个,偶检验下检验位为1,奇校验下校验为0;

四、补充第二节波形无对停止位标明

总结:当前进度硬件基础通信基本已完成,协议栈还需自己搭建,以参考Renesas DEMO代码的方式去了解与移植IOLINK通信逻辑方法不可取,时间周期太长,移植后因不熟悉代码与握手逻辑调试时会很吃力,对于第一次接触IOLINK通信以这种方式想必会事倍功半,优先找到相关文章书籍,自己搭建握手逻辑。

相关推荐
94621931zyn63 小时前
关于应用 - Cordova 与 OpenHarmony 混合开发实战
笔记·python
Andy121384 小时前
网页笔记插件(chrome)开发记录
chrome·笔记·mfc
做cv的小昊8 小时前
计算机图形学:【Games101】学习笔记05——着色(插值、高级纹理映射)与几何(基本表示方法)
笔记·opencv·学习·计算机视觉·图形渲染·几何学
车载测试工程师8 小时前
CAPL学习-CAN相关函数-统计API函数
网络·网络协议·学习·capl·canoe
好奇龙猫9 小时前
【AI学习-comfyUI学习-第二十四节-open(contorlnet多重处理)+图生图openpose-各个部分学习】
人工智能·学习
一路往蓝-Anbo9 小时前
【第13期】中断机制详解 :从向量表到ISR
c语言·开发语言·stm32·单片机·嵌入式硬件
易水寒陈10 小时前
使用J-Link RTT Viewer
stm32·单片机
wanzhong233310 小时前
CUDA学习5-矩阵乘法(共享内存版)
深度学习·学习·算法·cuda·高性能计算
xingzhemengyou111 小时前
STM32 内存空间中的选项字节
stm32·单片机
PNP Robotics12 小时前
PNP机器人受邀参加英业达具身智能活动
大数据·人工智能·python·学习·机器人