32f4,串口1,usart.c.h2025

usart.c

#include "sys.h"
#include "usart.h"	
#include "led.h"	
//
#include "stdlib.h"
#include "stdarg.h"
#include "stdio.h"
//加入以下代碼,支持printf函數,而不需要選擇use MicroLIB	  
#if 1#pragma import(__use_no_semihosting)             //標準庫需要的支持函數                 struct __FILE { int handle; }; FILE __stdout;       //定義_sys_exit()以避免使用半主機模式    _sys_exit(int x) { x = x; } //重定義fputc函數 int fputc(int ch, FILE *f){ 	while((USART1->SR&0X40)==0);//循環發送,直到發送完畢   USART1->DR = (u8) ch;      return ch;}//	printf("HEllo")  printf("i=%d\r\n",i) ;
#endif//串口1中斷服務程序
//注意,讀取USARTx->SR能避免莫名其妙的錯誤   	
char USART1_RX_BUF[USART1_REC_LEN];     //接收緩沖,最大USART_REC_LEN個字節.
//接收狀態
//bit15,	接收完成標志
//bit14,	接收到0x0d
//bit13~0,	接收到的有效字節數目
u16 USART_RX_STA=0;       //接收狀態標記	
u16 USART1_Rec_Byte_Length=0;//接收長度,最大是200,在接收數組空間范圍內?
u8  USART1_Rec_Frame_Flag=0;//接收完整一幀標記//初始化IO 串口1 
//bound:波特率
void uart1_init(u32 baudRate)
{//GPIO端口設置GPIO_InitTypeDef    GPIO_InitStructure;USART_InitTypeDef   USART_InitStructure;RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA,ENABLE); //使能GPIOA時鐘DISABLERCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);//使能USART1時鐘//串口1對應引腳復用映射GPIO_PinAFConfig(GPIOA,GPIO_PinSource9,GPIO_AF_USART1); //GPIOA9復用為USART1GPIO_PinAFConfig(GPIOA,GPIO_PinSource10,GPIO_AF_USART1); //GPIOA10復用為USART1//USART1端口配置GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9 | GPIO_Pin_10; //GPIOA9與GPIOA10GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;//復用功能GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;	//速度50MHzGPIO_InitStructure.GPIO_OType = GPIO_OType_PP; //推挽復用輸出GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP; //上拉GPIO_Init(GPIOA,&GPIO_InitStructure); //初始化PA9,PA10//USART1 初始化設置USART_InitStructure.USART_BaudRate = baudRate;//波特率設置USART_InitStructure.USART_WordLength = USART_WordLength_8b;//字長為8位數據格式USART_InitStructure.USART_StopBits = USART_StopBits_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(USART1, &USART_InitStructure); //初始化串口1USART_Cmd(USART1, ENABLE);  //使能串口1 USART_ClearFlag(USART1, USART_FLAG_TC);USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);//開啟相關中斷,接收一個字節,就發生中斷
}void USART1_IRQHandler(void)                	//串口1中斷服務程序
{u8 Res;//接收中斷(接收到的數據必須是0x0a結尾)if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)  {Res =USART_ReceiveData(USART1);//(USART1->DR);	//讀取接收到的數據USART1_RX_BUF[USART1_Rec_Byte_Length]=Res;//將數據放到緩沖區中if(USART1_RX_BUF[USART1_Rec_Byte_Length]==DIY_END_CODE) //如果接收到的最后的數據是約定好的幀尾{if(USART1_RX_BUF[USART1_Rec_Byte_Length-1]==DIY_END_CODE_Before){USART1_Rec_Frame_Flag=1;//接收標記等于1,在哪里清0?在判斷里面清0}//USART1_Rec_Byte_Length=0;//長度清零,給下次使用}else{USART1_Rec_Byte_Length++;//遞增座位號,不斷放到數組中if(USART1_Rec_Byte_Length>USART1_REC_LEN-1) USART1_Rec_Byte_Length=0;}} } 
void Clear_Uart1_RecBuf(void)//清空接收緩沖區
{char *p;u8 i;p=USART1_RX_BUF;for(i=0;i<USART1_REC_LEN;i++){*p++=0;}USART1_Rec_Byte_Length=0;USART1_Rec_Frame_Flag=0;
}//#include "stdlib.h"
//#include "stdarg.h"
//#include "stdio.h"  
//#include "string.h"  //str函數
//帶不定長度參數的函數
u8 Judge_Usart1_Response(char* fmt,...)
{char p[30];va_list ap;//如果串口1沒接收到一幀數據,那么返回0,結束本函數if(!USART1_Rec_Frame_Flag) return 0;//如果接收到一幀數據,到下面將需要判斷的數據數據復制到p數組中va_start(ap,fmt);vsprintf((char*)p,fmt,ap);va_end(ap); //結束ap指針,必須結束//用strstr函數,將接收到的字符串和我們的數據進行對比,如果沒有相等的那么返回0并結束函數,否則返回1說明判斷有效if(strstr((char*)USART1_RX_BUF,p)==NULL) return 0;else return 1;
}//獲取指定格式字符串的部分數據
//x=12,y=12.5  \r\n
u8 Get_Usart1_Data(int *x,float *y)
{int xtemp;float ytemp;if(!USART1_Rec_Frame_Flag) return 0;//第一個字符,第二個字符。else if(USART1_RX_BUF[0]=='x' && USART1_RX_BUF[1]=='='){sscanf((const char *)USART1_RX_BUF,"x=%d,y=%f",&xtemp,&ytemp);*x=(int)xtemp;*y=(float)ytemp;return 1;}else return 0;	
}
//https://www.cnblogs.com/zhanxiaohong0303/p/zz_2020_10_1.html//*******************************
//int main(void)
//{ 
// 
//	u8 t;
//	u8 len;	
//	u16 times=0;  
//	NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//設置系統中斷優先級分組2
//	delay_init(168);		//延時初始化 
//	uart_init(115200);	//串口初始化波特率為115200
//	LED_Init();		  		//初始化與LED連接的硬件接口  
//	while(1)
//	{
//		if(USART_RX_STA&0x8000)
//		{					   
//			len=USART_RX_STA&0x3fff;//得到此次接收到的數據長度
//			printf("\r\n您發送的消息為:\r\n");
//			for(t=0;t<len;t++)
//			{
//				USART_SendData(USART1, USART_RX_BUF[t]);         //向串口1發送數據
//				while(USART_GetFlagStatus(USART1,USART_FLAG_TC)!=SET);//等待發送結束
//			}
//			printf("\r\n\r\n");//插入換行
//			USART_RX_STA=0;
//		}else
//		{
//			times++;
//			if(times%5000==0)
//			{
//				printf("\r\nALIENTEK 探索者STM32F407開發板 串口實驗\r\n");
//				printf("正點原子@ALIENTEK\r\n\r\n\r\n");
//			}
//			if(times%200==0)printf("請輸入數據,以回車鍵結束\r\n");  
//			if(times%30==0)LED0=!LED0;//閃爍LED,提示系統正在運行.
//			delay_ms(10);   
//		}
//	}
//}//void Clear_Openmv_Rxbuff(void)
//{
//	u8 *p,i;
//	p=openmv_rx_data;
//	for(i=0;i<Rx_Length;i++)
//	{
//		*p++=0;
//	}
//	length=0;
//	rx_flag=0;
//}//u8 Judge_Openmv_Response(char* fmt,...)
//{
//	char p[30];
//	if(!rx_flag) return 0;
//	va_list ap;
//	va_start(ap,fmt);
//	vsprintf((char*)p,fmt,ap);
//	va_end(ap); 
//	if(strstr((char*)openmv_rx_data,p)==NULL) return 0;
//	else return 1;
//}//		if(Judge_Openmv_Response("OK"))
//		{
//			Clear_Openmv_Rxbuff();
//			LCD_ShowString(0,16,"OK");
//		}

usart.h

#ifndef __USART_H
#define __USART_H#include "stdio.h"	
#include "stm32f4xx_conf.h"
#include "sys.h" //********************************************************************************
#define USART1_REC_LEN  			   256  	     //定義最大接收字節數 200
#define DIY_END_CODE_Before      0x0D  //每次發送的幀尾\n
#define DIY_END_CODE             0x0A  //每次發送的幀尾\nextern char  USART1_RX_BUF[USART1_REC_LEN]; //接收緩沖,最大USART_REC_LEN個字節.末字節為換行符 
extern u16   USART1_RX_STA;         		//接收狀態標記	extern  u16    USART1_Rec_Byte_Length;//接收長度,最大是200,在接收數組空間范圍內?
extern  u8     USART1_Rec_Frame_Flag;//接收完整一幀標記=0,沒接收完,=1接收完void uart1_init(u32 baudRate);//設置串口1的波特率,以及初始化
void Clear_Uart1_RecBuf(void);//清空接收緩沖區
u8 Judge_Usart1_Response(char* fmt,...);//判斷串口1接受到的字符串,比對
//if(Judge_Usart1_Response("OK"))只要存在OK連續兩個就行,分大小寫
//uyyOKoo
//https://www.cnblogs.com/zhanxiaohong0303/p/zz_2020_10_1.html
//將按照指定格式接收的數據賦值
u8 Get_Usart1_Data(int *x,float *y);u8 Get_Usart1_Data2(float *x,float *y);#endif

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/74405.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/74405.shtml
英文地址,請注明出處:http://en.pswp.cn/web/74405.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

C語言:一組位操作宏

解析協議時&#xff0c;取得位域的值是一種常見操作&#xff0c;這些宏可以輔助我們工作。 /* ** 將x的第n位置1 ** ** x 0x00000000 ** BIT_SET(x, 7) 0x00000080 */ #define BIT_SET(x, n) ((x) | (1 << (n)))/* ** 將x的第n位置為0 ** ** x 0x00000080 ** …

記一個使用BigDecimal所有類型變為整數的問題

場景 通過 Excel 導入數據&#xff0c;數據中包含金額。數據庫類型 decimal(18, 6) 問題 Excel 導入后所有的金額列都被四舍五入。經過測試&#xff0c;只有數據有整數時所有數據才會被四舍五入&#xff0c;全部為浮點類型沒有問題。 解決 強制設置小數位數 // RoundingM…

nodejs、socket.io、express + 實時線上聊天系統(自用筆記)

留個鏈接給自己參考用&#xff1a; socket.io官方文檔&#xff1a;介紹 | Socket.IO nodejs基礎語法&#xff1a;大前端技能講解&#xff1a;NodeJS、Npm、Es6、Webpack_nodejs webpack-CSDN博客 socket.io教學&#xff1a;半小時學會socket.io【中英字幕】Learn Socket.Io …

配置網絡編輯器

網絡斷開的原因 1.由于網絡未連接的情況 解決方法 方法1&#xff1a;檢查網卡配置 cd /etc/syscongfig/network_scripts vi ifcfg_ens31 方法2&#xff1a;打開虛擬機編輯--- 虛擬網絡編輯器 查看ip地址是否在可用的網段范圍內 修改后重啟網絡 systemctl restart netwo…

vscode代碼片段的設置與使用

在 Visual Studio Code (VS Code) 中&#xff0c;可以通過自定義**代碼片段&#xff08;Snippets&#xff09;**快速插入常用代碼模板。以下是詳細設置步驟&#xff1a; 步驟 1&#xff1a;打開代碼片段設置 按下快捷鍵 Ctrl Shift P&#xff08;Windows/Linux&#xff09;或…

基于S函數的simulink仿真

基于S函數的simulink仿真 S函數可以用計算機語言來描述動態系統。在控制系統設計中&#xff0c;S函數可以用來描述控制算法、自適應算法和模型動力學方程。 S函數中使用文本方式輸入公式和方程&#xff0c;適合復雜動態系統的數學描述&#xff0c;并且在仿真過程中可以對仿真…

做題記錄:和為K的子數組

來自leetcode 560 前言 自己只會暴力&#xff0c;這里就是記錄一下前綴和哈希表的做法&#xff0c;來自靈神的前綴和哈希表&#xff1a;從兩次遍歷到一次遍歷&#xff0c;附變形題 正文 首先&#xff0c;這道題無法使用滑動窗口&#xff0c;因為滑動窗口需要滿足單調性&am…

淺淺嘗試Numpy的函數:

1.numpy.empty: numpy.empty方法用來創建一個指定形狀&#xff08;shape&#xff09;&#xff0c;數據類型&#xff08;dtype&#xff09;且未被初始化的數組&#xff1a; numpy.empty(shape,dtype float,order C) 參數說明&#xff1a; shape:數組形狀。 dtype:數據類型&am…

IM基本設計思路與有序ID的重要性

文章目錄 概要問題解析思考問題數據基礎讀取寫入總結 概要 說起IM程序我們都不陌生&#xff0c;本篇文章我們就為如何實現一個IM做一個簡單的整體方案設計以及基本的數據結構 問題解析 我們先不上一大堆牛逼哄哄的中間件。 我們先從實現角度&#xff0c;來講講設計思路。 從…

數據結構學習

鏈表 單鏈表 頭插 將x插到下標是k的點后面 將下標是k的點后面的點刪掉 代碼 // head 表示頭結點的下標 // e[i] 表示節點i的值 // ne[i] 表示節點i的next指針是多少 // idx 存儲當前已經用到了哪個點// 初始化 void init() {head -1;idx 0; }// 將x插到頭結點 void add_to_…

0.DJI-PSDK開發準備及資料說明(基于DJI經緯M300RTK和M350RTK無人機上使用)

0.DJI-PSDK開發準備及資料說明&#xff08;基于DJI經緯M300RTK和M350RTK無人機上使用&#xff09; 【資料名稱】 DJI經緯M300RTK和M350RTK無人機二次開發資料包。資料包在最下方的百度網盤 一、引言 在進行大疆無人機負載開發的過程中&#xff0c;我整理出一系列有價值的資…

Linux內核TCP/IP協議棧中的設計模式:從面向對象到系統級軟件的跨界實踐

引言 設計模式(Design Patterns)自GoF(Gang of Four)在1994年提出以來,已成為軟件工程領域的核心概念。盡管其經典定義基于面向對象編程(OOP),但設計模式的本質是解決復雜問題的經驗總結,而非局限于特定編程范式。本文以Linux內核的TCP/IP協議棧為例,探討設計模式在…

第十四屆藍橋杯大賽軟件賽省賽C/C++ 大學 B 組(部分題解)

文章目錄 前言日期統計題意&#xff1a; 冶煉金屬題意&#xff1a; 島嶼個數題意&#xff1a; 子串簡寫題意&#xff1a; 整數刪除題意&#xff1a; 總結 前言 一年一度的&#x1f3c0;杯馬上就要開始了&#xff0c;為了取得更好的成績&#xff0c;好名字寫了下前年2023年藍橋…

處理JWT Token失效需求

JWT 本身是無狀態的&#xff0c;這意味著服務器不會保存任何關于 Token 的狀態信息。但為了支持 JWT 的狀態管理&#xff08;例如&#xff1a;強制使某些 Token 失效&#xff09;&#xff0c;可以借助 Redis 這樣的外部存儲來維護一個黑名單或白名單。 安裝必要的 NuGet 包 首…

PHP代碼審計-01

&#x1f338; 連接方式 PHP Mysql連接方式&#xff1a; Mysql&#xff08;廢棄&#xff09;MysqliPDO &#x1f338; 常見過濾 intval/addslashes/mysql_real_escape mysqli_escape_string/mysqli_real_escape_string/mysqli::escape_string PDO::quote 參數化查詢 a…

SpringKafka錯誤處理:重試機制與死信隊列

文章目錄 引言一、Spring Kafka錯誤處理基礎二、配置重試機制三、死信隊列實現四、特定異常的處理策略五、整合事務與錯誤處理總結 引言 在構建基于Kafka的消息系統時&#xff0c;錯誤處理是確保系統可靠性和穩定性的關鍵因素。即使設計再完善的系統&#xff0c;在運行過程中也…

藍橋杯2024JavaB組的一道真題的解析

文章目錄 1.問題描述2.問題描述3.思路分析4.代碼分析 1.問題描述 這個是我很久之前寫的一個題目&#xff0c;當時研究了這個題目好久&#xff0c;發布了一篇題解&#xff0c;后來很多人點贊&#xff0c;我都沒有意識到這個問題的嚴重性&#xff0c;我甚至都在懷疑自己&#xf…

性能比拼: Go標準庫 vs Python FastAPI(第二輪)

本內容是對知名性能評測博主 Anton Putra Python (FastAPI) vs Go (Golang) (Round 2) Performance Benchmark 內容的翻譯與整理, 有適當刪減, 相關指標和結論以原作為準 介紹 這是第二輪關于 FastAPI 和 Golang 的對比測試。我幾天前運行了前一次的基準測試&#xff0c;到目…

DeepSeek與ChatGPT的優勢對比:選擇合適的工具來提升工作效率

選DeepSeek還是ChatGPT&#xff1f;這就像問火鍋和披薩哪個香&#xff01; "到底該用DeepSeek還是ChatGPT?” 這個問題最近在互聯網圈吵翻天!其實這就跟選手機系統-樣&#xff0c;安卓黨iOS黨都能說出一萬條理由&#xff0c;但真正重要的是你拿它來干啥&#xff01;&am…

Python爬蟲第4節-請求庫urllib的request模塊使用

目錄 前言&#xff1a;基本庫urllib的使用 一、urlopen方法 二、Request類 三、高級用法 前言&#xff1a;基本庫urllib的使用 開始學習爬蟲時&#xff0c;第一步就是要模擬瀏覽器給服務器發送請求。這個時候&#xff0c;你可能會有很多問題&#xff1a;該從哪里開始做呢&a…