专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
STM32
请教下485通讯的问题
2019-08-13 21:51
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
STM32/STM8
5840
14
1182
485通讯 用单片机与PC通讯,PC端串口助手可以接受到信号;但通过串口助手给单片机发送数据,单片机却接收不到,用示波器看了下485发送数据到单片机的引脚,数据信号电压只有500mV左右
请问这个电压太小是不是导致单片机接收不到串口助手发出的数据?
单片机用的STM32F103,使用的串口2,max3485芯片
求大神解惑啊!!!
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
14条回答
ADS1993
2019-08-13 22:40
两个电阻 1K 换成 4.7k
[mw_shl_code=c,true]GPIO_InitTypeDef GPIO_InitStructure;// 定义一个GPIO_InitTypeDef类型的变量
USART_InitTypeDef USART_InitStructure;// 定义一个USART_InitTypeDef类型的变量
NVIC_InitTypeDef NVIC_InitStructure;
/* 允许GPIOA和USART2的时钟 */
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);//使能GPIOA,G时钟
RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2,ENABLE);//使能USART2时钟
RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO, ENABLE);
/*485 EN AND POWER */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1 | GPIO_Pin_4 ; // 选择PIN1
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; // 推挽输出
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; // 50MHz速度
GPIO_Init(GPIOA, &GPIO_InitStructure);// 把参数带进函数配置
//GPIO_SetBits (GPIOA,GPIO_Pin_1);
GPIO_ResetBits(GPIOA,GPIO_Pin_1);
GPIO_ResetBits(GPIOA,GPIO_Pin_4);
// GPIO_ResetBits(GPIOA,GPIO_Pin_12);
/* 配置USART2 */
/* 配置PA2(TXD) */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2; // 选择PIN2
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; // 复用推挽输出
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; // 50MHz速度
GPIO_Init(GPIOA, &GPIO_InitStructure);// 把参数带进函数配置
/* 配置PA3(RXD) */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3;// 选择PIN3
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;// 选择浮空输入
GPIO_Init(GPIOA, &GPIO_InitStructure); // 把参数带进函数配置
/* 配置串口USART2的模式 */
USART_InitStructure.USART_BaudRate = 19200;//115200; // 波特率1152009600
USART_InitStructure.USART_WordLength = USART_WordLength_8b;// 8个数据位
USART_InitStructure.USART_StopBits = USART_StopBits_1; // 1个停止位
USART_InitStructure.USART_Parity = USART_Parity_No ; // 无奇偶校验
USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;// 无硬件流控制
USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
USART_Init(USART2, &USART_InitStructure); //把上面配置的参数带进函数里面初始化串口
/* 打开空闲中断 */
USART_ITConfig(USART2, USART_IT_IDLE, ENABLE);
/* 打开接收中断 */
USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);
/* 配置NVIC优先级组 */
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);
/* 允许UART2中断 */
NVIC_InitStructure.NVIC_IRQChannel = USART2_IRQn;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
USART_ClearFlag(USART2,USART_FLAG_TC);
USART_Cmd(USART2, ENABLE);// 打开串口2[/mw_shl_code]
[mw_shl_code=c,true]void USART2_Send_byte(uint8_t val)
{
__set_FAULTMASK(1);/*关闭总中断*/
USART_SendData(USART2, val);
while (USART_GetFlagStatus(USART2, USART_FLAG_TC) == RESET); //等待发送完成
__set_FAULTMASK(0);/*关闭总中断*/
}
// 发送len个字节
void Uart2_Send(char* data, int len)
{ GPIO_SetBits(GPIOA,GPIO_Pin_1);
GPIO_SetBits(GPIOA,GPIO_Pin_4);
Delay_ms(10);
__set_FAULTMASK(1);/*关闭总中断*/
while (len--)
{
while (!USART_GetFlagStatus(USART2, USART_FLAG_TXE));
USART2_Send_byte(*data++);
}
__set_FAULTMASK(0);/*开启总中断*/
Delay_ms(10);
GPIO_ResetBits(GPIOA,GPIO_Pin_4);
GPIO_ResetBits(GPIOA,GPIO_Pin_1);
}[/mw_shl_code]
[mw_shl_code=c,true]void USART2_IRQHandler(void)
{
// SysTick_Init();
if(USART_GetITStatus(USART2, USART_IT_RXNE) != RESET) // 如果接收到1个字节
{
aRxBuffer[RxCounter++] = USART2->DR;// 把接收到的字节保存,数组地址加1
}
else if(USART_GetITStatus(USART2, USART_IT_IDLE) != RESET)// 如果接收到1帧数据
{
u8 Clear=USART2->SR;// 读SR寄存器
Clear=USART2->DR;// 读DR寄存器(先读SR再读DR,就是为了清除IDLE中断)
ReceiveState=1;// 标记接收到了1帧数据
}[/mw_shl_code]
加载中...
查看其它14个回答
一周热门
更多
>
相关问题
STM32F4上I2C(在PROTEUS中模拟)调试不通的问题
6 个回答
芯片供应紧张,准备换个MCU,MM32L系列替换STM32L系列的怎么样?
7 个回答
STM32同时使用两个串口进行数据收发时数据丢包的问题
5 个回答
STM32F103串口通信死机问题
4 个回答
STM32WLE5CC连接SX1268在LoRa模式下能与 SX1278互通吗?
2 个回答
相关文章
ST公司第一款无线低功耗单片机模块有效提高物联网设计生产效率
0个评论
如何实现对单片机寄存器的访问
0个评论
通过USB用STM32片内自带Bootloader下载程序及注意事项
0个评论
欲练此功必先自宫之STM32汇编启动,放慢是为了更好的前行
0个评论
×
关闭
采纳回答
向帮助了您的知道网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
STM32
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
×
付费偷看金额在0.1-10元之间
确定
×
关闭
您已邀请
0
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
[mw_shl_code=c,true]GPIO_InitTypeDef GPIO_InitStructure;// 定义一个GPIO_InitTypeDef类型的变量
USART_InitTypeDef USART_InitStructure;// 定义一个USART_InitTypeDef类型的变量
NVIC_InitTypeDef NVIC_InitStructure;
/* 允许GPIOA和USART2的时钟 */
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);//使能GPIOA,G时钟
RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2,ENABLE);//使能USART2时钟
RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO, ENABLE);
/*485 EN AND POWER */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1 | GPIO_Pin_4 ; // 选择PIN1
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; // 推挽输出
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; // 50MHz速度
GPIO_Init(GPIOA, &GPIO_InitStructure);// 把参数带进函数配置
//GPIO_SetBits (GPIOA,GPIO_Pin_1);
GPIO_ResetBits(GPIOA,GPIO_Pin_1);
GPIO_ResetBits(GPIOA,GPIO_Pin_4);
// GPIO_ResetBits(GPIOA,GPIO_Pin_12);
/* 配置USART2 */
/* 配置PA2(TXD) */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2; // 选择PIN2
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; // 复用推挽输出
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; // 50MHz速度
GPIO_Init(GPIOA, &GPIO_InitStructure);// 把参数带进函数配置
/* 配置PA3(RXD) */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3;// 选择PIN3
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;// 选择浮空输入
GPIO_Init(GPIOA, &GPIO_InitStructure); // 把参数带进函数配置
/* 配置串口USART2的模式 */
USART_InitStructure.USART_BaudRate = 19200;//115200; // 波特率1152009600
USART_InitStructure.USART_WordLength = USART_WordLength_8b;// 8个数据位
USART_InitStructure.USART_StopBits = USART_StopBits_1; // 1个停止位
USART_InitStructure.USART_Parity = USART_Parity_No ; // 无奇偶校验
USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;// 无硬件流控制
USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
USART_Init(USART2, &USART_InitStructure); //把上面配置的参数带进函数里面初始化串口
/* 打开空闲中断 */
USART_ITConfig(USART2, USART_IT_IDLE, ENABLE);
/* 打开接收中断 */
USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);
/* 配置NVIC优先级组 */
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);
/* 允许UART2中断 */
NVIC_InitStructure.NVIC_IRQChannel = USART2_IRQn;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
USART_ClearFlag(USART2,USART_FLAG_TC);
USART_Cmd(USART2, ENABLE);// 打开串口2[/mw_shl_code]
[mw_shl_code=c,true]void USART2_Send_byte(uint8_t val)
{
__set_FAULTMASK(1);/*关闭总中断*/
USART_SendData(USART2, val);
while (USART_GetFlagStatus(USART2, USART_FLAG_TC) == RESET); //等待发送完成
__set_FAULTMASK(0);/*关闭总中断*/
}
// 发送len个字节
void Uart2_Send(char* data, int len)
{ GPIO_SetBits(GPIOA,GPIO_Pin_1);
GPIO_SetBits(GPIOA,GPIO_Pin_4);
Delay_ms(10);
__set_FAULTMASK(1);/*关闭总中断*/
while (len--)
{
while (!USART_GetFlagStatus(USART2, USART_FLAG_TXE));
USART2_Send_byte(*data++);
}
__set_FAULTMASK(0);/*开启总中断*/
Delay_ms(10);
GPIO_ResetBits(GPIOA,GPIO_Pin_4);
GPIO_ResetBits(GPIOA,GPIO_Pin_1);
}[/mw_shl_code]
[mw_shl_code=c,true]void USART2_IRQHandler(void)
{
// SysTick_Init();
if(USART_GetITStatus(USART2, USART_IT_RXNE) != RESET) // 如果接收到1个字节
{
aRxBuffer[RxCounter++] = USART2->DR;// 把接收到的字节保存,数组地址加1
}
else if(USART_GetITStatus(USART2, USART_IT_IDLE) != RESET)// 如果接收到1帧数据
{
u8 Clear=USART2->SR;// 读SR寄存器
Clear=USART2->DR;// 读DR寄存器(先读SR再读DR,就是为了清除IDLE中断)
ReceiveState=1;// 标记接收到了1帧数据
}[/mw_shl_code]
一周热门 更多>