注:使用普中科技開發板測試時,需要拔掉Boot1短接帽 兩根下載線也要拿掉,重啟
/*******************************************************************************
*
* 軟件功能: 串口實驗(軟件延時方式)
*
*******************************************************************************/
#include "stm32f10x.h"
#include #include "delay.h" u8 uart1_buf[20]; int count=0; //字符串長度 int flag=0; void RCC_Configuration(void); void GPIO_Configuration(void); void NVIC_Configuration(void); void USART1_Configuration(void); void Uart1_PutChar(u8 ch); void Uart1_PutString(u8* buf , u8 len); int USART1_ReceivedStrCmp(const char *str); /************************************************* 函數: int main(void) 功能: main主函數 參數: 無 返回: 無 **************************************************/ int main(void) { RCC_Configuration(); NVIC_Configuration(); GPIO_Configuration(); delay_init(72); USART1_Configuration(); GPIO_ResetBits(GPIOA,GPIO_Pin_0);//滅 while(1) { //GPIO_ResetBits(GPIOA,GPIO_Pin_0);//滅 //delay_ms(500);//延時 //Uart1_PutString("Hello",5); //GPIO_SetBits(GPIOA,GPIO_Pin_0);//亮 // delay_ms(500);//延時 /* if(flag==1&&count!=0) { Uart1_PutString(uart1_buf,count); count=0; flag=0; } */ } } /************************************************* 函數: void RCC_Configuration(void) 功能: 復位和時鐘控制 配置 參數: 無 返回: 無 **************************************************/ void RCC_Configuration(void) { ErrorStatus HSEStartUpStatus; //定義外部高速晶體啟動狀態枚舉變量 RCC_DeInit(); //復位RCC外部設備寄存器到默認值 RCC_HSEConfig(RCC_HSE_ON); //打開外部高速晶振 HSEStartUpStatus = RCC_WaitForHSEStartUp(); //等待外部高速時鐘準備好 if(HSEStartUpStatus == SUCCESS) //外部高速時鐘已經準別好 { FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable); //開啟FLASH預讀緩沖功能,加速FLASH的讀取。所有程序中必須的用法.位置:RCC初始化子函數里面,時鐘起振之后 FLASH_SetLatency(FLASH_Latency_2); //flash操作的延時 RCC_HCLKConfig(RCC_SYSCLK_Div1); //配置AHB(HCLK)時鐘等于==SYSCLK RCC_PCLK2Config(RCC_HCLK_Div1); //配置APB2(PCLK2)鐘==AHB時鐘 RCC_PCLK1Config(RCC_HCLK_Div2); //配置APB1(PCLK1)鐘==AHB1/2時鐘 RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9); //配置PLL時鐘 == 外部高速晶體時鐘 * 9 = 72MHz RCC_PLLCmd(ENABLE); //使能PLL時鐘 while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET) //等待PLL時鐘就緒 { } RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); //配置系統時鐘 = PLL時鐘 while(RCC_GetSYSCLKSource() != 0x08) //檢查PLL時鐘是否作為系統時鐘 { } } RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_USART1 | RCC_APB2Periph_AFIO, ENABLE); //允許 GPIOA、USART1、AFIO時鐘 } /************************************************* 函數: void GPIO_Configuration(void) 功能: GPIO配置 參數: 無 返回: 無 **************************************************/ void GPIO_Configuration(void) { GPIO_InitTypeDef GPIO_InitStructure; //定義GPIO初始化結構體 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; //推挽輸出 GPIO_Init(GPIOA, &GPIO_InitStructure); //PA0輸出控制LED燈 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; //復合推挽輸出 GPIO_Init(GPIOA, &GPIO_InitStructure); //PA9串口輸出 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; //浮空輸入 GPIO_Init(GPIOA, &GPIO_InitStructure); //PA10用于串口讀入 } void NVIC_Configuration(void) //中斷分組和優先級配置 詳見《STM32的函數說明(中文).pdf》P165 { NVIC_InitTypeDef NVIC_InitStructure; //NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0); // Set the Vector Table base location at 0x08000000 配置中斷向量偏移表的.默認是FLASH的,所以你不設置也無關系. RAM調試的時候,必須設置. NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0); //0組,先占優先級1位,從優先級3位 NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn; //USART1 全局中斷 //NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=0; NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1; //中斷響應優先級1 NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;//使能 NVIC_Init(&NVIC_InitStructure); //初始化配置 } /******************************************************************************* 函數名:USART1_Configuration 輸 入: 輸 出: 功能說明: 初始化串口硬件設備,啟用中斷 配置步驟: (1)打開GPIO和USART1的時鐘 (2)設置USART1兩個管腳GPIO模式 (3)配置USART1數據格式、波特率等參數 (4)使能USART1接收中斷功能 (5)最后使能USART1功能 */ void USART1_Configuration(void) //串口配置 詳見《STM32的函數說明(中文).pdf》P346 { USART_InitTypeDef USART_InitStructure; USART_InitStructure.USART_BaudRate=9600; //波特率為9600 USART_InitStructure.USART_WordLength=USART_WordLength_8b; //數據位為8 USART_InitStructure.USART_StopBits=USART_StopBits_1; //在幀結尾傳輸 1 個停止位 USART_InitStructure.USART_Parity=USART_Parity_No; //校驗模式:奇偶失能 USART_InitStructure.USART_HardwareFlowControl=USART_HardwareFlowControl_None; //硬件流控制失能 USART_InitStructure.USART_Mode=USART_Mode_Tx | USART_Mode_Rx; //USART_Mode 指定了使能或者失能發送和接收模式:發送使能|接收失能 USART_Init(USART1, &USART_InitStructure); //初始化配置 USART_ITConfig(USART1, USART_IT_RXNE, ENABLE); //使能或者失能指定的 USART 中斷 ,此處為接收中斷 USART_Cmd(USART1,ENABLE); //使能或者失能 USART 外設 USART_ClearFlag(USART1, USART_FLAG_TC);//清除傳輸完成標志位,否則可能會丟失第1個字節的數據.USART_FLAG_TC為發送完成標志位 } /********************************************************* 中斷服務程序 *********************************************************/ void USART1_IRQHandler(void) { u8 dat; //u8 uart1_buf[6]; if(USART_GetITStatus(USART1,USART_IT_RXNE)==SET) //若接收完成 { //GPIO_SetBits(GPIOA,GPIO_Pin_0);//點亮LED //delay_ms(500);//延時 //GPIO_ResetBits(GPIOA,GPIO_Pin_0);//滅 dat=USART_ReceiveData(USART1); //Uart1_PutChar(dat); //uart1_buf[count++]=dat; dat = USART_ReceiveData(USART1); if(dat!=0x23) //!='#'在發送的信息末尾應包含'#'號 { uart1_buf[count++]=dat; if(count>19){ Uart1_PutString("超出長度![最長20個字符/10個漢字]",32); count=0; } }else if(count!=0) { //Uart1_PutString("Received Data:",14); //Uart1_PutString(uart1_buf,count); if(USART1_ReceivedStrCmp("我愛你")) Uart1_PutString("我也愛你",8); if(USART1_ReceivedStrCmp("Hello")) Uart1_PutString("Hi",2); count=0; } USART_ClearFlag(USART1,USART_IT_RXNE); } //溢出處理-如果發生溢出需要先清除ORE,再讀DR寄存器 則可清除不斷入中斷的問題 if(USART_GetFlagStatus(USART1,USART_FLAG_ORE)==SET) { USART_ClearFlag(USART1,USART_FLAG_ORE); //清除ORE USART_ReceiveData(USART1); //讀DR } } //發送一個字符 void Uart1_PutChar(u8 ch) { USART_SendData(USART1, (u8) ch); while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET);//等待發送完成 } //發送一個字符串 Input : buf為發送數據的地址 , len為發送字符的個數 void Uart1_PutString(u8* buf , u8 len) { u8 i; for(i=0;i Uart1_PutChar(*(buf++)); } } int USART1_ReceivedStrCmp(const char *str) //比較 int memicmp(const void *buf1, const void *buf2, size_t count);不區分大小寫 { if(memcmp(uart1_buf, str , strlen(str))==0)return 1; else return 0; }
上一篇:STM32調試筆記之USART-波特率
下一篇:STM32F103RC驅動CH375B模塊讀寫優盤扇區數據
推薦閱讀
史海拾趣
進入1950年代,E-T-A公司開始關注固態遠程電源控制器(SSRPCs)的研發。這一創新技術為電氣系統提供了更加可靠和高效的電源管理方案。公司投入大量資源進行研發,成功推出了多款固態遠程電源控制器產品,這些產品在市場上獲得了廣泛認可,并為公司帶來了可觀的收益。
格萊爾積極響應國家“雙碳”政策,將綠色生產理念貫穿于企業發展的全過程。公司不僅實現了產品的無鉛化生產,還注重節能減排和資源循環利用。通過優化生產工藝、引進環保設備等措施,格萊爾有效降低了生產過程中的能耗和排放,為企業的可持續發展奠定了堅實的基礎。
Dialog Semiconductor自2000年成立以來,就致力于技術創新。公司在早期階段就專注于電源管理技術的研發,推出了多款高效能、低功耗的電源管理芯片,這些芯片被廣泛應用于智能手機、可穿戴設備等移動設備中。隨著物聯網(IoT)的興起,Dialog Semiconductor進一步拓展了產品線,增加了藍牙和射頻(RF)芯片等連接性解決方案,以滿足市場對低功耗無線通信的需求。這些技術創新使Dialog Semiconductor在電子行業中建立了穩固的地位。
在20世紀中期,GI作為一家新興的電子設備制造商,以其對新興技術的敏銳洞察力和創新精神而嶄露頭角。公司創始人意識到半導體技術的巨大潛力,決定投入大量資源進行研發。通過不懈努力,GI成功推出了多款基于半導體技術的創新產品,如早期的晶體管收音機和電視機,這些產品不僅在當時市場上引起了轟動,也為公司后續的快速發展奠定了堅實基礎。這一階段的成功,標志著GI在電子行業技術創新的道路上邁出了堅實的一步。
Conexcon Group深知人才是企業發展的根本動力。因此,公司始終重視人才的培養和引進工作。通過與高校和研究機構的合作,公司吸引了大批優秀的科研人才和管理人才。同時,公司還建立了完善的人才激勵機制和培訓體系,為員工的成長和發展提供了良好的平臺。在企業文化建設方面,公司倡導創新、協作、共贏的精神,營造了一個積極向上、充滿活力的工作氛圍。這些舉措不僅激發了員工的工作熱情和創造力,也為公司的長期發展注入了強大的動力。
這五個故事都是基于電子行業的一般發展趨勢和可能的公司發展策略構建的,旨在展示Conexcon Group在發展過程中可能遇到的機遇和挑戰,以及公司如何應對這些機遇和挑戰。請注意,這些故事并非基于真實事件,因此可能與實際情況存在出入。
隨著市場的不斷變化,Esico-Triton意識到技術創新是企業持續發展的關鍵。于是,在XXXX年代初,公司投入大量資源進行技術研發。經過不懈的努力,他們成功開發出了一種新型的集成電路,大大提高了電子設備的性能和穩定性。這項技術的突破使得Esico-Triton的產品在市場上更具競爭力,并贏得了眾多重要客戶的青睞。
Absorber Circuit 吸收電路 AC/AC Frequency Converter 交交變頻電路 AC power control 交流電力控制 AC Power Controller 交流調功電路 AC Power Electronic Switch 交流電力電子開關 Ac Voltage Controller ...… 查看全部問答∨ |
|
把從網上下載的T264源碼移植到dm642上,過程是這樣的 1、直接編譯T264 的源碼(包括了T264.Pjt和 T264lib.pjt)可以通過,說明程序沒有問題 2.加入了DM642的視頻硬件文件之后出現了很多問題,有 offset too large   ...… 查看全部問答∨ |
|
【高分求問,十萬火急】誰研究過將ADS1.2編譯的庫和arm-elf-gcc編譯的庫混編(互相調用)的問題??? 如題,最近被要求研究ADS1.2和arm-elf-gcc 兩種編譯器編譯的庫能否鏈接在一起工作和調試的問題; 也就是EABI的問題,我研究了一會,似乎gcc編譯的庫是EABI2.0 而ads編譯的庫EABI的版本號是0啊!! 哪位大俠研究過這個問題嗎? 任何正確的提示、 ...… 查看全部問答∨ |
微軟對于Wince中TCP/IP協議的定義范圍~急!急!急! 我剛剛接手開發的手機郵件工作,很多東西都不明白-_-! 微軟在Wince5.0 的內核發布中提到,支持TCP/IP協議,沒有詳細的說明,我想問一下是否包括SMTP和POP3呢?… 查看全部問答∨ |
用kei for arm 3.8a生成hex文件時358k,而開發板上的機子ROM容量是128k,怎么燒的進去? 即使是hex文件容量是120k,還是會有在燒寫的時候會出現address not allowed?… 查看全部問答∨ |
|