chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

STM32串口接收不定長數(shù)據(jù):采用標(biāo)志位(比如0X0D,0X0A)結(jié)束法

RXL111 ? 來源:RXL111 ? 作者:RXL111 ? 2022-09-23 14:06 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

缺點(diǎn):有些情況下會(huì)導(dǎo)致數(shù)據(jù)丟失(可能返回?cái)?shù)據(jù)中0x0d、0a本身為有效數(shù)據(jù))
適用:約定協(xié)議的數(shù)據(jù)幀(發(fā)送數(shù)據(jù)的設(shè)備必須以相應(yīng)的約定字節(jié)作為一次數(shù)據(jù)結(jié)束)


void USART1_IRQHandler(void)                	//串口中斷服務(wù)程序(函數(shù))
	{
	u8 Res;	//定義Res,用于Res =USART_ReceiveData(USART1);中存儲(chǔ)串口1發(fā)送的數(shù)據(jù)(這里的數(shù)據(jù)按位發(fā)送)
#if SYSTEM_SUPPORT_OS  //如果SYSTEM_SUPPORT_OS為真,則需要支持OS		
	OSIntEnter();    
#endif
	if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)  //接收中斷(接收到的數(shù)據(jù)必須是0x0d 0x0a結(jié)尾)
		{
		Res =USART_ReceiveData(USART1);	//讀取接收到的數(shù)據(jù)
		
		if((USART_RX_STA&0x8000)==0)//接收未完成    1000 0000 0000 0000
//判斷USART_RX_STA的第一位是否為0,這時(shí)因?yàn)閁SART_RX_STA的初始值為0,所以我們進(jìn)入if(USART_RX_STA&0x4000)。
			{
			if(USART_RX_STA&0x4000)//接收到了0x0d	0100 0000 0000 0000
//判斷USART_RX_STA的第二位是否為1,所以我們進(jìn)入else //還沒收到0X0D。
				{
				if(Res!=0x0a)USART_RX_STA=0;//接收錯(cuò)誤,重新開始
				else USART_RX_STA|=0x8000;	//接收完成了 
				}
			else //還沒收到0X0D
				{	
				if(Res==0x0d)USART_RX_STA|=0x4000;//再次判斷這次接收到的是不是0x0d,判斷了Res是否0x0d, 即Res是否為回車,這里如果串口有輸入數(shù)據(jù)的話明顯可以判斷的,所以我們進(jìn)入下面的else.
				else
					{
					USART_RX_BUF[USART_RX_STA&0X3FFF]=Res ;  // 0011 1111 1111 1111
					USART_RX_STA++;
					if(USART_RX_STA>(USART_REC_LEN-1))USART_RX_STA=0;//接收數(shù)據(jù)錯(cuò)誤,重新開始接收	  
					}		 
				}
			}   		 
     } 
#if SYSTEM_SUPPORT_OS 	
	OSIntExit();  											 
#endif
}

OSIntEnter()和OSIntExit()兩者必須成對(duì)出現(xiàn)。
進(jìn)入中斷時(shí)調(diào)用OSIntEnter(),退出中斷時(shí)調(diào)用OSIntExit()。
OSIntEnter 是進(jìn)?中斷服務(wù)函數(shù),?來記錄中斷嵌套層數(shù)(OSIntNesting增加 1);
OSIntEnter()應(yīng)該在中斷關(guān)閉后調(diào)用,所以函數(shù)里面沒有使用OS_ENTER_CRITICAL() and OS_EXIT_CRITICAL(),如此在調(diào)用OSIntEnter()前需關(guān)閉中斷。
OSIntExit():所有中斷結(jié)束后進(jìn)行任務(wù)調(diào)度,使系統(tǒng)更加實(shí)時(shí)。
OSIntExit 是退出中斷服務(wù)函數(shù),該函數(shù)可能觸發(fā)?次任務(wù)切換(當(dāng) OSIntNesting==0&&調(diào)度器未上鎖&&就緒表最?優(yōu)先級(jí)任務(wù) != 被中斷的任務(wù)優(yōu)先級(jí)時(shí)),否則繼續(xù)返回原來的任務(wù)執(zhí)?代碼(如果 OSIntNesting 不為 0,則減 1)。
OS_Sched():uCOS進(jìn)行任務(wù)調(diào)度,不在中斷調(diào)用。
OSIntNesting:統(tǒng)計(jì)中斷嵌套數(shù),最多255。在OSIntExit()和OS_Sched()中都有判別。
OS_ENTER_CRITICAL():保存中斷狀態(tài),關(guān)中斷。uCOS將無法再執(zhí)行任務(wù)調(diào)度,硬件中斷也被屏蔽。

void  OSIntEnter (void)

{

if (OSRunning == OS_TRUE) {

if (OSIntNesting < 255u) {

OSIntNesting++;                      /* Increment ISR nesting level                        */

}

}

}

這個(gè)函數(shù)的作用是對(duì)全局變量OSIntNesting增1,OSIntNesting為中斷嵌套深度。

void  OSIntExit (void)

{

#if OS_CRITICAL_METHOD == 3u                               /* Allocate storage for CPU status register */

OS_CPU_SR  cpu_sr = 0u;

#endif

if (OSRunning == OS_TRUE) {

OS_ENTER_CRITICAL();

if (OSIntNesting > 0u) {                           /* Prevent OSIntNesting from wrapping       */

OSIntNesting--;

}

if (OSIntNesting == 0u) {                          /* Reschedule only if all ISRs complete ... */

if (OSLockNesting == 0u) {                     /* ... and not locked.                      */

OS_SchedNew();

OSTCBHighRdy = OSTCBPrioTbl[OSPrioHighRdy];

if (OSPrioHighRdy != OSPrioCur) {          /* No Ctx Sw if current task is highest rdy */

#if OS_TASK_PROFILE_EN > 0u

OSTCBHighRdy->OSTCBCtxSwCtr++;         /* Inc. # of context switches to this task  */

#endif

OSCtxSwCtr++;                          /* Keep track of the number of ctx switches */

OSIntCtxSw();                          /* Perform interrupt level ctx switch       */

}

}

}

OS_EXIT_CRITICAL();

}

}

函數(shù)的前面部分對(duì)OSIntNesting減1,剛好與OSIntEnter() 相對(duì)應(yīng);后面部分則進(jìn)行任務(wù)調(diào)度。

總結(jié):任何中斷服務(wù)函數(shù),我們都應(yīng)該加上 OSIntEnter 和 OSIntExit 函數(shù),UCOSII 是?個(gè)可剝奪型的內(nèi)核,中斷服務(wù)?程序運(yùn)?之后,系統(tǒng)會(huì)根據(jù)情況進(jìn)??次任務(wù)調(diào)度去運(yùn)?優(yōu)先級(jí)別最?的就緒任務(wù),?并不?定接著運(yùn)?被中斷的任務(wù)!


#if...#endif是C++中的條件編譯預(yù)處理命令 有兩種格式:

1:#ifdef 標(biāo)示符

程序段1

#else

程序段2

#endif

表示:如果標(biāo)示符已經(jīng)被#define命令定義過,則編譯程序段1,否則編譯程序段2。期中else部分可以沒有。

2:#if 表達(dá)式

程序段1

#else

程序段2

#endif

表示:如果表達(dá)式為真,則編譯程序段1,否則編譯程序段2.
if((USART_RX_STA&0x8000)==0) //0x8000,即二進(jìn)制1000 0000 0000 0000,與變量USART_RX_STA,按位與(&),并與0比較,作用是判斷USART_RX_STA數(shù)值第16位是否為0。
USART_RX_STA&0x8000有兩種可能:
第一種1××× ×××× ×××× ××××&1000 0000 0000 0000=1000 0000 0000 0000
第二種0××× ×××× ×××× ××××&1000 0000 0000 0000=0000 0000 0000 0000
由此可以判斷USART_RX_STA第16位是否為0


USART_RX_STA的作用,USART_RX_STA一共有16位,前兩位為標(biāo)記位,后14位記錄了串口發(fā)送的數(shù)的位數(shù)。第一位標(biāo)記位標(biāo)記了Res是否為0x0a,第二位標(biāo)記位標(biāo)記了Res是否為0x0d。
知識(shí)點(diǎn):0x0d是回車的ASCLL碼,0x0a是換行的ASCLL碼

USART_RX_BUF這個(gè)是用來保存接收到的數(shù)據(jù)的可以看到每次結(jié)束判斷會(huì)有
USART_RX_BUF[USART_RX_STA&0X3FFF]=Res ;
USART_RX_STA=0; //接收狀態(tài)標(biāo)記
USART_RX_STA的作用就是在全部函數(shù)之間實(shí)現(xiàn)一個(gè)消息傳遞,自己設(shè)置,自己管理,自己識(shí)別。
bit15 bit14 bit13~0
接收完成標(biāo)志0x0a 接收到0X0d標(biāo)志 接收到的有效數(shù)據(jù)個(gè)數(shù)

USART_RX_STA|=0x4000;將第二位狀態(tài)標(biāo)志位置為1;在倒數(shù)第1次循環(huán)中使用USART_RX_STA|=0x8000;將第一位狀態(tài)標(biāo)志位也置為1,;而后串口數(shù)據(jù)接收結(jié)束,所有從串口接收的數(shù)據(jù)保存在USART_RX_BUF[ ]數(shù)組中,串口所發(fā)送的數(shù)據(jù)長度保存在USART_RX_STA的后14位中。

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • STM32
    +關(guān)注

    關(guān)注

    2301

    文章

    11073

    瀏覽量

    369386
  • 串口
    +關(guān)注

    關(guān)注

    15

    文章

    1597

    瀏覽量

    81382
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    Labview讀取二進(jìn)制文件(有的時(shí)候會(huì)自動(dòng)添加0X0D0x0A前面)

    我是利用Labview開發(fā)TCP/IP通信的,需要把接收的網(wǎng)絡(luò)數(shù)據(jù)保存為二進(jìn)制文件。用UltraEdit查看保存的文件里面有好多二進(jìn)制值,0x00~0xFF,里面會(huì)有
    發(fā)表于 05-02 14:48

    stm32串口怎么用DMA接收不定長數(shù)據(jù)?

    stm32串口怎么用DMA接收不定長數(shù)據(jù),求大神點(diǎn)播1. 網(wǎng)上查到,空閑中斷+DMA可以接收
    發(fā)表于 08-21 09:21

    串口接收,0x0a0x0d表示的什么?

    void USART1_IRQHandler(void){ u8 res; if(USART1->SR&(163)USART_RX_STA=0;//接收數(shù)據(jù)錯(cuò)誤,重新開始接收 }}}
    發(fā)表于 08-19 03:09

    stm32識(shí)別TC35短信有兩個(gè)“0x0d 0x0a”怎么解決?

    原子哥的串口代碼里,遇到0x0d 0x0a就停止接收,但是從TC35模塊讀取短信時(shí),前面的短信息說明,會(huì)有兩個(gè)“0x0d
    發(fā)表于 08-28 08:00

    Labview串口時(shí)候數(shù)據(jù)中的0x0A與換行符沖突怎么解決?

    串口數(shù)據(jù)傳輸時(shí)候,含有0x0A與換行符沖突,如果關(guān)閉終止符,那樣就無法識(shí)別串口數(shù)據(jù)結(jié)束,無法識(shí)別
    發(fā)表于 12-06 21:33

    STM32串口接收不定長數(shù)據(jù)原理是什么

    STM32串口接收不定長數(shù)據(jù)原理是什么
    發(fā)表于 12-08 07:29

    STM32串口接收不定長數(shù)據(jù)的實(shí)現(xiàn)方法

    STM32串口接收不定長數(shù)據(jù)的實(shí)現(xiàn)方法
    發(fā)表于 12-09 06:17

    針對(duì)接收一幀含有多個(gè)字節(jié)的不定長數(shù)據(jù)接收方式進(jìn)行討論

    (比如0X0D,0X0A)結(jié)束 非常常見的一種接收方式,正點(diǎn)原子的例程便是
    發(fā)表于 12-09 07:16

    如何利用STM32串口去解析json命令呢

    STM32串口解析json命令(使用HAL庫)串口接收中斷處理(0x0D 0x0A作為結(jié)尾)測(cè)試
    發(fā)表于 01-21 10:07

    STM32串口接收不定長數(shù)據(jù)的程序免費(fèi)下載

    本文檔的主要內(nèi)容詳細(xì)介紹的是STM32串口接收不定長數(shù)據(jù)的程序免費(fèi)下載。
    發(fā)表于 08-26 08:00 ?62次下載
    <b class='flag-5'>STM32</b><b class='flag-5'>串口</b><b class='flag-5'>接收</b><b class='flag-5'>不定長</b><b class='flag-5'>數(shù)據(jù)</b>的程序免費(fèi)下載

    STM32串口通信 (采用鏈表接收不定長數(shù)據(jù)幀)

    STM32串口接收不定長數(shù)據(jù)幀->鏈表數(shù)據(jù)幀說明二級(jí)目錄三級(jí)目錄
    發(fā)表于 11-23 18:07 ?31次下載
    <b class='flag-5'>STM32</b><b class='flag-5'>串口</b>通信 (<b class='flag-5'>采用</b>鏈表<b class='flag-5'>接收</b><b class='flag-5'>不定長</b><b class='flag-5'>數(shù)據(jù)</b>幀)

    STM32串口接收不定長數(shù)據(jù)的幾種方法

    (比如0X0D,0X0A)結(jié)束 非常常見的一種接收方式,正點(diǎn)原子的例程便是
    發(fā)表于 11-26 13:21 ?20次下載
    <b class='flag-5'>STM32</b><b class='flag-5'>串口</b><b class='flag-5'>接收</b><b class='flag-5'>不定長</b><b class='flag-5'>數(shù)據(jù)</b>的幾種方法

    stm32 串口接收不定長度數(shù)據(jù)及黏包處理 + 串口DMA接收

    ,那么stm32串口是如何實(shí)現(xiàn)接收不定長度數(shù)據(jù)的呢? 串口接收
    發(fā)表于 12-23 19:09 ?27次下載
    <b class='flag-5'>stm32</b> <b class='flag-5'>串口</b><b class='flag-5'>接收</b><b class='flag-5'>不定長度數(shù)據(jù)</b>及黏包處理 + <b class='flag-5'>串口</b>DMA<b class='flag-5'>接收</b>

    STM32 DMA串口接收不定長數(shù)據(jù)

    STM32 DMA串口接收不定長數(shù)據(jù)
    發(fā)表于 12-24 18:50 ?41次下載
    <b class='flag-5'>STM32</b>  DMA<b class='flag-5'>串口</b><b class='flag-5'>接收</b><b class='flag-5'>不定長</b><b class='flag-5'>數(shù)據(jù)</b>

    RM0451_超低功耗 STM32L0x0 先進(jìn)的基于 Arm? 的 32 MCU

    RM0451_超低功耗 STM32L0x0 先進(jìn)的基于 Arm? 的 32 MCU
    發(fā)表于 11-23 08:20 ?2次下載
    RM0451_超低功耗 <b class='flag-5'>STM32L0x0</b> 先進(jìn)的基于 Arm? 的 32 <b class='flag-5'>位</b> MCU