RS422一主多从MAX3490

RS422一主多从MAX3490

最近项目用到了RS422一主多从,一个主机4个从机。芯片用的MAX3490,几经折腾,最终只能从一拖4改为一拖2。
主机发送端,从机4个接收端都是正常的,没有问题。波形非常完美,没有太大变形
主机端发送TX+TX-波形信号
然而从机发送端TX+TX-波形就有很大的问题,TX+TX-波形没有了交会点,经分析原理应该是TX端几个从机电平相互干扰了,基于这个怀疑,我们在TX端加了二极管,使信号单相导通不至于相互干扰。
从机端发送TX+TX-波形信号
加了二极管后的波形
在这里插入图片描述
然后经过原理分析,发现二极管只管正向导通,不管下降沿,就是通信速率太快了二极管没办法传递信号了。所以还是有问题。
加了二极管后信号两端的波形
很明显的看到信号下降沿时二极管内部电容就起作用了,下降缓冲比较慢,只要通信速率起来了信号就没办法传递。
基于此,我们又想了一个新的方案:想办法让TX+TX-没办法交会的电平交会起来,那么就是TX+加上拉,TX-加下拉。效果如下
在这里插入图片描述
这下就有了交会了,经分析max规格书,只要交汇处电平宽度有0.2V,就能解析信号,至此,RS422告一段落。

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
以下是基于STM32F4的串口1(PA9、PA10)接MAX3490,实现RS422通信的示例程序: ```c #include "stm32f4xx.h" #include "stm32f4xx_conf.h" UART_HandleTypeDef UART_HandleStruct; void InitializeUART(void) { GPIO_InitTypeDef GPIO_InitStructure; // Enable GPIOA clock RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA, ENABLE); // Enable USART1 clock RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE); // Configure USART1 Tx (PA9) as alternate function push-pull GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP; GPIO_Init(GPIOA, &GPIO_InitStructure); // Configure USART1 Rx (PA10) as input floating GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_OType = GPIO_OType_OD; GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL; GPIO_Init(GPIOA, &GPIO_InitStructure); // Connect USART1 pins to AF7 GPIO_PinAFConfig(GPIOA, GPIO_PinSource9, GPIO_AF_USART1); GPIO_PinAFConfig(GPIOA, GPIO_PinSource10, GPIO_AF_USART1); // Configure USART1 UART_HandleStruct.Instance = USART1; UART_HandleStruct.Init.BaudRate = 115200; UART_HandleStruct.Init.WordLength = UART_WORDLENGTH_8B; UART_HandleStruct.Init.StopBits = UART_STOPBITS_1; UART_HandleStruct.Init.Parity = UART_PARITY_NONE; UART_HandleStruct.Init.HwFlowCtl = UART_HWCONTROL_NONE; UART_HandleStruct.Init.Mode = UART_MODE_TX_RX; HAL_UART_Init(&UART_HandleStruct); } void InitializeMAX3490(void) { GPIO_InitTypeDef GPIO_InitStructure; // Enable GPIOB clock RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOB, ENABLE); // Configure MAX3490 /RE (PB12) as output push-pull GPIO_InitStructure.GPIO_Pin = GPIO_Pin_12; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP; GPIO_Init(GPIOB, &GPIO_InitStructure); // Configure MAX3490 /DE (PB13) as output push-pull GPIO_InitStructure.GPIO_Pin = GPIO_Pin_13; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP; GPIO_Init(GPIOB, &GPIO_InitStructure); // Enable MAX3490 transmit mode GPIO_ResetBits(GPIOB, GPIO_Pin_12); GPIO_SetBits(GPIOB, GPIO_Pin_13); } int main(void) { uint8_t txData[] = "Hello, world!\r\n"; uint8_t rxData[32]; // Initialize UART and MAX3490 InitializeUART(); InitializeMAX3490(); while(1) { // Send data HAL_UART_Transmit(&UART_HandleStruct, txData, sizeof(txData), HAL_MAX_DELAY); // Switch to receive mode GPIO_SetBits(GPIOB, GPIO_Pin_12); GPIO_ResetBits(GPIOB, GPIO_Pin_13); // Receive data HAL_UART_Receive(&UART_HandleStruct, rxData, sizeof(rxData), HAL_MAX_DELAY); // Switch back to transmit mode GPIO_ResetBits(GPIOB, GPIO_Pin_12); GPIO_SetBits(GPIOB, GPIO_Pin_13); } } ``` 在此示例程序中,我们首先初始化了UART和MAX3490的GPIO口。在主循环中,我们先使用UART发送了一个字符串,然后将MAX3490切换到接收模式,等待接收数据。当接收完成后,再将MAX3490切换回发送模式,继续发送数据。 需要注意的是,MAX3490的DE和RE引脚需要通过GPIO控制,用于切换发送和接收模式。在发送模式下,RE为高电平,DE为低电平;在接收模式下,RE为低电平,DE为高电平。在代码中,我们通过GPIO_SetBits和GPIO_ResetBits函数实现了引脚的电平控制。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值