2019-08-13 21:51发布
ADS1993 发表于 2017-8-3 14:53 发送完成,要设置成接收模式 调试看一下 切换 的延时时间 如果开启中断,看看有没有进入中断,
守候ocean 发表于 2017-8-3 14:59 我直接把发送的程序屏蔽了 现在初始化里就是接收模式 主程序里就跑个灯 我觉得是信号强度太小单片机不识 ...
最多设置5个标签!
[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]
我直接把发送的程序屏蔽了 现在初始化里就是接收模式 主程序里就跑个灯 我觉得是信号强度太小单片机不识别也不知道对不对 中断一直没进去 缓存里没数据
发送数据的同时 用示波器 测量 A B 电压, 看一下 A B 差值
一周热门 更多>