久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 18514|回復: 3
收起左側

基于STM32F103C8T6的USART串行通信(PC與STM32)

[復制鏈接]
ID:468597 發表于 2019-1-31 18:43 | 顯示全部樓層 |閱讀模式
基于STM32F103C8T6USART串行通信(PCSTM32
一、功能要求及通信協議設計
    通過PC控制STM32最小系統上的LED。采用中斷接收法,當串口接收到數據即進入中斷函數,接收該數據。接收和發送的數據幀長度可變,但不超過255字節。
    通信協議設計如下:
1.  PC
(1)  數據幀頭為0xEA,數據幀尾為0x55。
(2)  如果數據幀中間數據為0x01,表示要點亮相對應的LED。
(3)  如果數據幀中間數據為0x02,表示要關閉相對應的LED。
2.  STM32實驗系統端
(1)  正確點亮LED,則STM32回發:“LED in STM32 has been turnon!”,否則回發:“LED in STM32 has been on!”。
(2)  正確關閉LED,則STM32回發:“LED in STM32 has been turnoff!”,否則回發:“LED in STM32 has been off!”。
二、程序算法
1.  算法設計
上位機(這里采用PC)按通信協議要求發送一幀數據給STM32實驗系統(下位機),下位機以中斷方式接收數據幀,如果是有效數據幀則設置標志,否則清除標志;如果接收到有效數據幀,STM32實驗系統(下位機)對數據幀進行分析并進行相應處理。如果命令是0x01,則點亮LED;如果命令是0x02,則關閉LED。
2.  程序框架
由于采用中斷方式,因此工程模板中的兩個中斷相關文件均必須被使用:stm32f10x_it.h和stm32f10x_it.c,前者主要是進行全局變量說明、中斷函數說明,后者主要是中斷函數的定義。另外設計的文件是:main.c,stm32f10x_conf.h,前者是主函數所在文件,后者是功能模塊頭文件設置文件。其它自定義文件有:UserDefine.h和User.c,前者是用戶類型定義及函數聲明所在文件,后者是用戶函數定義所在文件。因此,涉及工程模板中的文件有4個,分別是:
(1)      stm32f10x_it.h;
(2)      stm32f10x_it.c;
(3)      stm32f10x_conf.h;
(4)      main.c;
(5)      UserDefine.h;
(6)      User.c。
三、工程配置
1.  選擇設備為STM32F103C8
1.png

2.       修改晶振頻率為8.0
2.png
       STM32F103C8的內部晶振頻率為8MHz
3.       設置預處理宏定義符號:USE_STDPERIPH_DRIVER,STM32F10X_MD
3.png
       USE_STDPERIPH_DRIVER表示要使用固件庫,STM32F10X_MD表示選用的是中等容量的STM32芯片。
4.   設置IncludePath路徑
4.png
該項配置是為了將STM32的啟動文件及官方庫包含進項目中,這樣能加快開發速度,而且使用官方庫開發相較于其他方式而言更淺顯易懂。
5.   設置調試方式
5.png
       此項為PCSTM32芯片的連接方式,具體請自行調整
6.   設置啟動方式
6.png
       此項設置為程序下載后及啟動,免去了手動啟動的環節。
四、源程序
1.    文件1——stm32f10x_it.h
#ifndef __STM32F10x_IT_H
#define __STM32F10x_IT_H
#include "stm32f10x.h"
#include "UserDefine.h"
void NMI_Handler(void);
void HardFault_Handler(void);
void MemManage_Handler(void);
void BusFault_Handler(void);
void UsageFault_Handler(void);
void SVC_Handler(void);
void DebugMon_Handler(void);
void PendSV_Handler(void);
void SysTick_Handler(void);
void USART1_IRQHandler(void);
#endif /* __STM32F10x_IT_H */

2.    文件2——stm32f10x_it.c
#include "stm32f10x_it.h"
extern RxTxBuffer_t Data;
void NMI_Handler(void)
{
}
void HardFault_Handler(void)
{
/* Go to infinite loop when Hard Faultexception occurs */
while (1)
{
}
}
void MemManage_Handler(void)
{
/* Go to infinite loop when Memory Manageexception occurs */
while (1)
{
}
}

void BusFault_Handler(void)
{
/* Go to infinite loop when Bus Fault exception occurs */
while (1)
{
}
}

void UsageFault_Handler(void)
{
/* Go to infinite loop when Usage Faultexception occurs */
while (1)
{
  }
}

void SVC_Handler(void)
{
}
void DebugMon_Handler(void)
{
}
void PendSV_Handler(void)
{
}
void SysTick_Handler(void)
{
}
void USART1_IRQHandler(void)
{
if(USART_GetFlagStatus(USART1,USART_IT_RXNE)!=RESET)
{
USART_ClearITPendingBit(USART1, USART_IT_RXNE);
Data.RxBuffer[Data.RxCount++]=USART_ReceiveData(USART1);
//Data.RxCount &= 0xFF;
}
if (Data.RxBuffer[Data.RxCount - 1] == 0xEA)
Data.RxHeader = Data.RxCount - 1;
if(Data.RxBuffer[Data.RxHeader]==0xEA&&Data.RxBuffer[Data.RxCount -1] == 0x55)
{
Data.RxLen = Data.RxCount-1-Data.RxHeader;
Data.RxOK = 1;
}
if(USART_GetFlagStatus(USART1, USART_IT_ORE) == SET)
{
USART_ClearFlag(USART1, USART_IT_ORE);
USART_ReceiveData(USART1);
}
}

3.    文件3——stm32f10x_conf.h
#ifndef __STM32F10x_CONF_H
#define __STM32F10x_CONF_H
#include "stm32f10x_gpio.h"
#include "stm32f10x_rcc.h"
#include"stm32f10x_usart.h"
#include "misc.h"
#endif /* __STM32F10x_CONF_H */

4.   文件4——main.c
#include "UserDefine.h"
RxTxBuffer_t Data;
int main(void)
{
u8 kcnt = 0;
u8 cmd1, cmd2;
SystemInit();
GPIO_Configure();
USART_Configure();
NVIC_Configure();
EmptyRxBuffer(BufferMAX);
SendString((u8 *)("Welcome to my STM32!!!\n"));
while (true)
  {
if (Data.RxOK)
  {
cmd1 = Data.RxBuffer[Data.RxHeader + 1];
cmd2 = Data.RxBuffer[Data.RxHeader + 2];
switch (cmd1)
   {
case 0x01:   LED_ON;
Data.RxOK = 0;
Data.RxCount = 0;
EmptyRxBuffer(BufferMAX);
break;
case 0x02:   LED_OFF;
Data.RxOK = 0;
Data.RxCount = 0;
EmptyRxBuffer(BufferMAX);
break;
}
}
}
}

5.    文件5——UserDefine.h
#ifndef __USERDEFINE_H__
#define __USERDEFINE_H__
#include <stm32f10x.h>
#include <stdbool.h>
#include <string.h>
#include <stdio.h>
#define BufferMAX 255
#define LED_ON    GPIO_ResetBits(GPIOB, GPIO_Pin_12)
#define LED_OFF   GPIO_SetBits(GPIOB, GPIO_Pin_12)
typedef struct
{
u8 RxBuffer[BufferMAX];
u8 TxBuffer[BufferMAX];
vu8 RxCount;
vu8 TxCount;
vu8 RxHeader;
vu8 RxOK;
vu8 RxLen;
}
RxTxBuffer_t;
typedef enum { ERR = 0, OK = !ERR } RxTxState_t;
void GPIO_Configure();
void USART_Configure();
void NVIC_Configure();
void DelayNms(u16 time);
RxTxState_t SendOneByte(u8 dat);
void SendString(u8 *Message);
void EmptyRxBuffer(u8 len);
#endif /* __USERDEFINE_H__ */

6.  文件6——User.c
#include "UserDefine.h"
extern RxTxBuffer_t Data;
void GPIO_Configure()
{
GPIO_InitTypeDef GPIO_InitStructure;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_12;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOB, &GPIO_InitStructure);
GPIO_ResetBits(GPIOB, GPIO_Pin_12);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1|RCC_APB2P
eriph_GPIOA, ENABLE);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
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);
}
void USART_Configure()
{
USART_InitTypeDef USART_InitStructure;
USART_InitStructure.USART_BaudRate = 115200;
USART_InitStructure.USART_HardwareFlowControl=USART_
HardwareFlowControl_None;
USART_InitStructure.USART_Mode=USART_Mode_Rx|USART_Mode
_Tx;
USART_InitStructure.USART_Parity = USART_Parity_No;
USART_InitStructure.USART_StopBits = USART_StopBits_1;
USART_InitStructure.USART_WordLength=USART_WordLength
_8b;
USART_Init(USART1, &USART_InitStructure);
USART_Cmd(USART1, ENABLE);
}
void NVIC_Configure()
{
NVIC_InitTypeDef NVIC_InitStructure;
NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=0;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
NVIC_Init(&NVIC_InitStructure);
USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);
}
void DelayNms(u16 time)
{
u16 i = 0;
while (time--)
{
i = 12000;
while (i--) ;
}
}
RxTxState_t SendOneByte(u8 dat)
{
vu32 cnt = 0;
USART_SendData(USART1, dat);
while(USART_GetFlagStatus(USART1,USART_FLAG_TXE)==
RESET)
{
cnt++;
if (cnt == 100000)
return ERR;
}
return OK;
}
void SendString(u8 *Message)
{
while (*Message != '\0')
SendOneByte(*Message++);
}
void EmptyRxBuffer(u8 len)
{
u8 i;
for(i = 0; i < len; i++)
Data.RxBuffer = 0;
}

如有錯誤,歡迎指出討論
如果感興趣的的話,也歡迎關注我們的公眾號,我們會定期更新一些技術類文章
qrcode_for_gh_4475599e75b5_258.jpg

回復

使用道具 舉報

ID:501249 發表于 2019-10-22 18:05 | 顯示全部樓層
我下載了這個程序是挺有用的,謝謝大神分享這么好的筆記
回復

使用道具 舉報

ID:515985 發表于 2019-10-26 10:41 | 顯示全部樓層
怎么下載
回復

使用道具 舉報

ID:93341 發表于 2021-6-22 09:46 | 顯示全部樓層
我下載了這個程序是挺有用的,謝謝大神分享這么好的筆記
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 亚洲精品视频免费观看 | 成人在线视频免费观看 | 亚洲综合视频在线 | 黄色片观看 | www久久久| www.伊人网| 黄色一级毛片 | 激情91 | 久久成人免费视频 | 亚洲欧美精品 | 天天做天天爽 | 成人深夜福利 | 黄色影院在线观看 | 第一福利视频 | 亚洲精品www久久久久久广东 | 欧美在线播放视频 | 国产午夜在线观看 | 久久国产99 | 国产黄a三级三级三级看三级男男 | 中文字幕一区二区三区视频 | 青青草福利视频 | 日韩精品在线一区二区 | 免费一级毛片免费播放 | 亚洲视频一区二区三区四区 | 国产激情久久久 | 日本综合久久 | 精品天堂 | 国产九九热 | 国产视频a | 欧美国产在线观看 | 精品视频在线观看免费 | 99色综合 | 一级特黄视频 | 午夜天堂网 | 中国av在线播放 | 欧美精品一级片 | 久久久久国产一区二区三区 | av一区二区三区在线观看 | 最新日韩av | 精东影业一区二区三区 | 一区在线观看视频 |