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

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

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

STM32的串口中斷配置

電子工程師 ? 2018-04-06 07:24 ? 次閱讀

STM32的串口中斷配置,也是很簡單的.

首先是配置UART的GPIO口

首先是配置UART的GPIO口

/**********************************************

* Name : UART1_GPIO_Configuration

* Deion : Configures the uart1 GPIO ports.

* Input : None

* Output : None

* Return : None

**********************************************************/

void UART1_GPIO_Configuration(void)

{

GPIO_InitTypeDef GPIO_InitStructure;

// Configure USART1_Tx as alternate push-pull

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);

// Configure USART1_Rx as input floating

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;

GPIO_Init(GPIOA, &GPIO_InitStructure);

}

然后是配置串口參數(shù)

/*******************************************************

* Name : UART1_Configuration

* Deion : Configures the uart1

* Input : None

* Output : None

* Return : None

*********************************************/

void USART_Configuration(void)

{

USART_InitTypeDef USART_InitStructure;

USART_ClockInitTypeDef USART_ClockInitStructure;

Uart1_GPIO_Configuration();

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;

/* Configure the USART1 synchronous paramters */

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_HardwareFlowControl = USART_HardwareFlowControl_None;

USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;

/* Configure USART1 basic and asynchronous paramters */

USART_Init(USART1, &USART_InitStructure);

/* Enable USART1 Receive interrupts */

USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);

/* Enable USART1 */

USART_Cmd(USART1, ENABLE);

}

然后是在中斷設(shè)置,需要修改stm32f10x_it.c 中的串口中斷函數(shù) 并且需要修改void NVIC_Configuration(void)函數(shù)

修改NVIC_Configuration函數(shù)

/***********************************************************

* Name : NVIC_Configuration

* Deion : Configures NVIC and Vector Table base location.

* Input : None

* Output : None

* Return : None

***************************************************/

void NVIC_Configuration(void)

{

NVIC_InitTypeDef NVIC_InitStructure;

#ifdef VECT_TAB_RAM

/* Set the Vector Table base location at 0x20000000 */

NVIC_SetVectorTable(NVIC_VectTab_RAM, 0x0);

#else /* VECT_TAB_FLASH */

/* Set the Vector Table base location at 0x08000000 */

NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0);

#endif

/* Configure the NVIC Preemption Priority Bits */

NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);

/* Enable the USART1 Interrupt */

NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQChannel;

NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;

NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;

NVIC_Init(&NVIC_InitStructure);

}

//串口中斷

void USART1_IRQHandler(void)

{

//處理接收到的數(shù)據(jù)

if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)

{

/* Clear the USART1 Receive interrupt */

USART_ClearITPendingBit(USART1, USART_IT_RXNE);

}

//發(fā)送中斷

if (USART_GetITStatus(USART1, USART_IT_TXE) != RESET)

{

USART_SendData(USART1, Send_Data[Send_Length++]);

if (Send_Length==SEND_LENGTH)

{

//發(fā)送字節(jié)結(jié)束

USART_ClearITPendingBit(USART1,USART_IT_TXE);

USART_ITConfig(USART1, USART_IT_TXE, DISABLE);

USART_ITConfig(USART1, USART_IT_TC, ENABLE);

}

}

//發(fā)送完成

if (USART_GetITStatus(USART1, USART_IT_TC) != RESET)

{

USART_ClearITPendingBit(USART1,USART_IT_TC);

USART_ITConfig(USART1, USART_IT_TC, DISABLE);

}

}

在需要發(fā)送的程序里Send_Data[SEND_LENGTH]和發(fā)送長度設(shè)置好,

void Send_to_PC(void)

{

//設(shè)置好Send_Data[SEND_LENGTH]數(shù)組

//打開發(fā)送中斷

USART_ITConfig(USART1, USART_IT_TXE, ENABLE);

}

至此 串口就可以工作起來了!~

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

    關(guān)注

    2270

    文章

    10915

    瀏覽量

    356753
收藏 人收藏

    評論

    相關(guān)推薦

    stm32 GPIO中斷配置教程

    在嵌入式開發(fā)中,STM32微控制器因其高性能和豐富的外設(shè)而廣受歡迎。GPIO(通用輸入/輸出)中斷STM32微控制器中常用的功能之一,它允許開發(fā)者在特定引腳上檢測到外部信號變化時(shí)快速響應(yīng)。 1.
    的頭像 發(fā)表于 11-19 15:53 ?1039次閱讀

    stm32怎樣觸發(fā)軟件中斷

    了解STM32中斷系統(tǒng) STM32微控制器具有豐富的中斷系統(tǒng),包括NVIC(嵌套向量中斷控制器)和SYSTICK定時(shí)器。NVIC可以處理多達(dá)
    的頭像 發(fā)表于 09-02 09:32 ?986次閱讀

    stm32串口燒錄怎么設(shè)置

    準(zhǔn)備工作 確保您擁有STM32開發(fā)板和相應(yīng)的硬件設(shè)備,如USB轉(zhuǎn)串口模塊。 安裝STM32CubeMX和STM32CubeProgrammer軟件,這些是ST官方提供的工具,用于
    的頭像 發(fā)表于 08-22 09:33 ?1717次閱讀

    STM32G030F6串口空閑中斷配置卡死怎么解決?

    本人在用STM32G030F6 串口空閑中斷+DMA接受的時(shí)候,CubeMX配置完成,在mian函數(shù)while(1)前初始化,使能空閑中斷_
    發(fā)表于 07-22 06:51

    NON_OS sdkv2.0.0的mqtt demo里串口中斷沒反應(yīng)是怎么回事?

    NON_OS的mqtt后我看了串口中斷的回調(diào)函數(shù)是接收到啥就發(fā)送啥,但是實(shí)際我發(fā)送啥反應(yīng)都沒有,好像8266的串口中斷沒有執(zhí)行
    發(fā)表于 07-12 08:21

    STM32G030F6用串口中斷函數(shù)接收數(shù)據(jù),發(fā)送數(shù)據(jù)就死機(jī)怎么解決?

    平臺介紹: 芯片是使用的STM32G030F6,系統(tǒng)是rt-thread nano-v3.1.5, 使用rtthread studio + cubemx生成工程項(xiàng)目 問題描述:想使用串口中斷方式去
    發(fā)表于 07-11 06:44

    STM32G030不能再次進(jìn)入串口中斷的原因?

    在使用串口時(shí)數(shù)據(jù)發(fā)送完畢 將串口設(shè)置為外部中斷,然后MCU進(jìn)入停止模式。在觸發(fā)外部喚醒后,進(jìn)入外部觸發(fā)中斷 ,再次初始化串口后,再接收
    發(fā)表于 05-17 10:38

    請問Arduino Due是如何進(jìn)入串口中斷的呢?

    今天在移植Arduino的時(shí)候,一直不明白Due是如何進(jìn)入串口中斷的。Due是在串口中斷中接收字符,并將其存儲。有下面的代碼: void USARTClass::IrqHandler( void
    發(fā)表于 05-17 07:16

    求助,關(guān)于串口中斷問題求解

    串口中斷問題 int main (void) { I2C_EE_Init(); /* 串口1初始化 */ USART1_Config(); NVIC_Configuration(); while
    發(fā)表于 05-15 06:55

    STM32CubeMX串口中斷自收自發(fā)怎么寫?

    核心板主控芯片是STM32F103ZET6,開發(fā)環(huán)境是EWARM 6.40.1 用STM32CubeMX配置好芯片的相關(guān)功能和管腳,各個模塊初始化代碼是自動生成
    發(fā)表于 05-13 08:52

    stm32的modbus.c文件,如何觸發(fā)串口發(fā)送中斷?

    寫錯了,這算是個串口發(fā)送函數(shù),不應(yīng)該放在串口中斷里. 完整函數(shù)如下: /*oˉêy1|?ü£oó?óúModbus
    發(fā)表于 05-10 06:50

    stm32cubemx的串口中斷接收時(shí),過一段時(shí)間串口中斷不進(jìn)了怎么解決?

    個小時(shí)多串口中斷進(jìn)不去了,我用兩根線掛在總線上在電腦上用串口助手監(jiān)聽收發(fā)的數(shù)據(jù),發(fā)送和應(yīng)答的過程還在持續(xù),其他功能也都正常只是cubemx的程序認(rèn)為沒有收到數(shù)據(jù)。很難定位是哪里的問題。
    發(fā)表于 04-17 06:48

    STM32L051使用HAL庫串口中斷的疑問求解

    使用STM32CUB生成原始代碼,然后采用串口中斷接收 L051有兩個串口,串口1,串口2,以及一個低功耗
    發(fā)表于 04-08 07:17

    STM32G030在使用串口中斷接收時(shí),發(fā)現(xiàn)串口接收一次數(shù)據(jù)后,第二次進(jìn)不去中斷的原因?

    在使用串口中斷接收時(shí),發(fā)現(xiàn)串口接收一次數(shù)據(jù)后,第二次進(jìn)不去中斷了,初始化開啟了中斷且在回調(diào)函數(shù)里面也再次開啟了中斷,但是效果依舊只能接收一次
    發(fā)表于 03-08 07:40

    stm32串口接收中斷觸發(fā)原理

    配置串口接收中斷使能:在初始化串口時(shí),需要設(shè)置相應(yīng)的控制寄存器來使能串口接收中斷。這通??梢酝ㄟ^
    發(fā)表于 01-17 15:42 ?8007次閱讀
    <b class='flag-5'>stm32</b><b class='flag-5'>串口</b>接收<b class='flag-5'>中斷</b>觸發(fā)原理