完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
扫一扫,分享给好友
代码如下:
#include "STM32f10x_lib.h" //*************************************// void RCC_Configuration(void); void GPIO_Configuration(void); void USART_Configuration(void); //**************************************// void delay(u32 k) { while(k--); } //**********主函数************// int main(void) { RCC_Configuration(); GPIO_Configuration(); USART_Configuration(); while(1); } //***********RCC寄存器级配置******************// void RCC_Configuration(void) { ErrorStatus HSEStartStatus; RCC_DeInit(); RCC_HSEConfig(RCC_HSE_ON); HSEStartStatus=RCC_WaitForHSEStartUp(); if(HSEStartStatus==SUCCESS) { RCC_HCLKConfig(RCC_SYSCLK_Div1); RCC_PCLK2Config(RCC_HCLK_Div1); RCC_PCLK1Config(RCC_HCLK_Div2); FLASH_SetLatency(FLASH_Latency_2); FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable); RCC_PLLConfig(RCC_PLLSource_HSE_Div1,RCC_PLLMul_9); RCC_PLLCmd(ENABLE); while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY)==RESET); RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); while(RCC_GetSYSCLKSource()!=0x08); } RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA,ENABLE); } //***********GPIO配置****************// void GPIO_Configuration(void) { GPIO_InitTypeDef GPIO_InitStructure; GPIO_InitStructure.GPIO_Pin=GPIO_Pin_9; GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_Mode=GPIO_Mode_AF_PP; GPIO_Init(GPIOA,&GPIO_InitStructure); GPIO_InitStructure.GPIO_Pin=GPIO_Pin_10; GPIO_InitStructure.GPIO_Mode=GPIO_Mode_IN_FLOATING; GPIO_Init(GPIOA,&GPIO_InitStructure); } //*************USART1*******************// void USART_Configuration(void) { USART_InitTypeDef USART_InitStructure; USART_ClockInitTypeDef USART_ClockInitStructure; USART_ClockInitStructure.USART_Clock=USART_Clock_Disable; USART_ClockInitStructure.USART_CPOL=USART_CPOL_Low; USART_ClockInitStructure.USART_CPHA=USART_CPHA_2Edge; USART_ClockInitStructure.USART_LastBit=USART_LastBit_Disable; USART_ClockInit(USART1,&USART_ClockInitStructure); USART_InitStructure.USART_BaudRate=9600; USART_InitStructure.USART_WordLength=USART_WordLength_8b; USART_InitStructure.USART_StopBits=USART_StopBits_1; USART_InitStructure.USART_Parity=USART_Parity_No; USART_InitStructure.USART_Mode=USART_Mode_Rx | USART_Mode_Tx; USART_InitStructure.USART_HardwareFlowControl=USART_HardwareFlowControl_None; USART_Init(USART1,&USART_InitStructure); USART_ITConfig(USART1,USART_IT_RXNE, ENABLE); USART_ITConfig(USART1, USART_IT_TXE, DISABLE); USART_Cmd(USART1,ENABLE); } 中断函数如下: vu16 RxBuffer; void USART1_IRQHandler(void) { if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET) { RxBuffer = USART_ReceiveData(USART1); USART_ITConfig(USART1, USART_IT_TXE, ENABLE); USART_ITConfig(USART1, USART_IT_RXNE, DISABLE); } if(USART_GetITStatus(USART1, USART_IT_TXE) != RESET) { USART_SendData(USART1, RxBuffer); USART_ITConfig(USART1, USART_IT_TXE, DISABLE); USART_ITConfig(USART1, USART_IT_RXNE, ENABLE); } } //*******************************************// 函数实现功能很简单,只要接收一字节数据再发给PC, 网上查到说只有中断处理才能接收数据,所以使用中断来接收,但不成功, 期待解答与指导,先行谢过! |
|
相关推荐
20个回答
|
|
没有回复,自占沙发
|
|
|
|
你的GPIO的引脚配置模式配置不对吧,
------ GPIO_InitStructure.GPIO_Mode=GPIO_Mode_IN_FLOATING; ---- 模式也是 GPIO_Mode_AF_PP |
|
|
|
移步群 157556544一起学习下
|
|
|
|
190471306 发表于 2014-12-6 11:04 PA9是Tx引脚,设置没有问题 |
|
|
|
|
|
|
|
用的是普中科技的STM32,低电平触发RTS就会引起接收正常,可并没有使用RTS功能,具体问题还是有待研究
|
|
|
|
|
|
|
|
USART_ClockInitStructure.USART_Clock=USART_Clock_Disable;
USART_ClockInitStructure.USART_CPOL=USART_CPOL_Low; USART_ClockInitStructure.USART_CPHA=USART_CPHA_2Edge; USART_ClockInitStructure.USART_LastBit=USART_LastBit_Disable; USART_ClockInit(USART1,&USART_ClockInitStructure); 程序好复杂 |
|
|
|
我编程 很差 来学习学习
|
|
|
|
void USART_SendData(USART_TypeDef* USARTx, u8 Data)
u8 USART_ReceiveData(USART_TypeDef* USARTx) vu16 RxBuffer; 不知道 有没有影响 |
|
|
|
我想请教个 问题 电脑 通过 串口 发送 数据 给单片机 单片机 再通过 另一个 出口 发送给 另一个设备
能不能 用dma 完成 这个 电脑 ---uarta---单片机 ----uartb----其他设备 |
|
|
|
理论上没什么不可以,实际上为什么不直接用PC发数据给另一个设备,用STM32做桥梁,意义何在 |
|
|
|
这是我在用的一个串口中断收发代码,你可以参考一下
if (USART_GetITStatus(USART1, USART_IT_RXNE) == SET) { USART_ClearITPendingBit(USART1,USART_IT_RXNE); Uart1RcvArray[Uart1RcvIndex] = USART_ReceiveData(USART1); Uart1RcvIndex ++; } if (USART_GetITStatus(USART1, USART_IT_TXE) == SET) { USART_ClearITPendingBit(USART1,USART_IT_TXE); if (Uart1SenIndex < Uart1SenCount) { USART_SendData(USART1, Uart1SenArray[Uart1SenIndex]); Uart1SenIndex ++; } else { USART_ITConfig(USART1, USART_IT_TXE, DISABLE); } } |
|
|
|
弱弱地问一句,楼主你有配置NVIC吗。。。
|
|
|
|
不知道楼主有没有解决,调试了一天了,还是接收不了,用的是CH430转串口
|
|
|
|
是不是没有配置NVIC,我配置了NVIC,结果给我报了个 hard fault。精了,接收BUFF里东西都来了,进不去中断
|
|
|
|
同样的问题在我这里出现了,请问是什么原因?
|
|
|
|
请问你的问题解决没有呢,我的就是USART1串口通信,只能发送不能接收,就是普中科技的PZ6806L那个板子 |
|
|
|
代码贴出来 |
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
2136 浏览 1 评论
AD7686芯片不传输数据给STM32,但是手按住就会有数据。
1970 浏览 3 评论
4566 浏览 0 评论
如何解决MPU-9250与STM32通讯时,出现HAL_ERROR = 0x01U
2116 浏览 1 评论
hal库中i2c卡死在HAL_I2C_Master_Transmit
2629 浏览 1 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-24 03:06 , Processed in 1.143487 second(s), Total 80, Slave 74 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号