版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、精品文檔 STM8的C語言編程1根本程序與啟動代碼分析 現(xiàn)在幾乎所有的單片機都能用C語言編程了,采用C語言編程確實能帶來很多好處,至少可讀性比匯編語言強多了。在STM8的開發(fā)環(huán)境中
2、,可以通過新建一個工程,自動地建立起一個C語言的框架,生成后開發(fā)環(huán)境會自動生成2個C語言的程序,一個是main.c,另一個是stm8_interrupt_vector.c。main.c中就是一個空的main()函數(shù),如下所示: /* MAIN.C file * * Copyright (c) 2002-2005 STMicroelectronics */ main() while (1); 而在stm8_interrupt_vector.c中,就是聲
3、明了對應(yīng)該芯片的中斷向量,如下所示:/* BASIC INTERRUPT VECTOR TABLE FOR STM8 devices * Copyright (c) 2007 STMicroelectronics */ typedef void far (*interrupt_handler_t)(void); struct interrupt_vector unsigned char interrupt_instruct
4、ion; interrupt_handler_t interrupt_handler; far interrupt void NonHandledInterrupt (void) /* in order to detect unexpected events during development, it is recommended to se
5、t a breakpoint on the following instruction */ return; extern void _stext(); /* startup routine */ struct interrupt_vector const _vectab = 0x82, (interrupt_h
6、andler_t)_stext, /* reset */ 0x82, NonHandledInterrupt, /* trap */ 0x82, NonHandledInterrupt, /* irq0 */ 0x82, NonHandledInterrupt, /* irq1 */
7、160; 0x82, NonHandledInterrupt, /* irq2 */ 0x82, NonHandledInterrupt, /* irq3 */ 0x82, NonHandledInterrupt, /* irq4 */ 0x82, NonHandledInterrupt, /* irq5 */
8、 0x82, NonHandledInterrupt, /* irq6 */ 0x82, NonHandledInterrupt, /* irq7 */ 0x82, NonHandledInterrupt, /* irq8 */ 0x82, NonHandledInterrupt, /* irq9&
9、#160; */ 0x82, NonHandledInterrupt, /* irq10 */ 0x82, NonHandledInterrupt, /* irq11 */ 0x82, NonHandledInterrupt, /* irq12 */ 0x82, NonHandledInterrupt, /*
10、irq13 */ 0x82, NonHandledInterrupt, /* irq14 */ 0x82, NonHandledInterrupt, /* irq15 */ 0x82, NonHandledInterrupt, /* irq16 */ 0x82, NonHandledInterrupt, /*
11、irq17 */ 0x82, NonHandledInterrupt, /* irq18 */ 0x82, NonHandledInterrupt, /* irq19 */ 0x82, NonHandledInterrupt, /* irq20 */ 0x82, NonHandledInterrupt, /*
12、irq21 */ 0x82, NonHandledInterrupt, /* irq22 */ 0x82, NonHandledInterrupt, /* irq23 */ 0x82, NonHandledInterrupt, /* irq24 */ 0x82, NonHandledInterrupt, /*
13、irq25 */ 0x82, NonHandledInterrupt, /* irq26 */ 0x82, NonHandledInterrupt, /* irq27 */ 0x82, NonHandledInterrupt, /* irq28 */ 0x82, NonHandledInterrupt, /*
14、irq29 */;在stm8_interrupt_vector.c中,除了定義了中斷向量表外,還定義了空的中斷效勞程序,用于那些不用的中斷。當(dāng)然在自動建立時,所有的中斷效勞都是空的,因此,除了第1個復(fù)位的向量外,其它都指向那個空的中斷效勞函數(shù)。生成框架后,就可以用Build菜單下的Rebuild All對工程進行編譯和連接,生成所需的目標文件,然后就可以加載到STM8的芯片中,這里由于main()函數(shù)是一個空函數(shù),因此沒有任何實際的功能。不過我們可以把這個框架對應(yīng)的匯編代碼反出來,看看C語言生成的代碼,這樣可以更深入地了解C語言編程的特點。生成的代碼包括4個局部,如圖1、圖2、圖3、圖4所示。
15、 圖1
16、60; 圖2 圖3 圖4 圖1顯示的是從內(nèi)存地址8000H開始的中斷向
17、量表,中斷向量表中的第1行82021083H為復(fù)位后單片機運行的第1跳指令的地址。從表中可以看出,單片機復(fù)位后,將從8083H開始運行。其它行的中斷向量都指向同一個位置的中斷效勞程序80D0H。 圖2顯示的是3個字節(jié),前2個字節(jié)8083H為復(fù)位后的第1條指令的地址,第3個字節(jié)是一個常量0,后面的啟動代碼要用到。 圖3顯示的是啟動代碼,啟動代碼中除了初始化堆棧指針外,就是初始化RAM單元。由于目前是一個空的框架,因此在初始化完堆棧指針設(shè)置成0FFFH后,由于8082H單元的內(nèi)容為0,因此程序就跳到了80B1H,此處是一個循環(huán),將RAM單元從0到5初
18、始化成0。然后由于存放器X設(shè)置成0100H,就直接通過CALL main進入C的main()函數(shù)。 圖4顯示的是main()函數(shù)和中斷效勞函數(shù),main()函數(shù)對應(yīng)的代碼就是一個無限的循環(huán),而中斷效勞函數(shù)就一條指令,即中斷返回指令。 通過分析,可以看出用C語言編程時,比匯編語言編程時,就是多出了一段啟動代碼。 &
19、#160; STM8的C語言編程2 變量空間的分配 采用C這樣的高級語言,其實可以不用關(guān)心變量在存儲器空間中是如何具體分配的。但如果了解如何分配,對編程還是有好處的,尤其是在調(diào)試時。例如下面的程序定義了全局變量數(shù)組buffer和一個局部變量i,在RAM中如何分配的呢?/* MAIN.C file * * Copyright (c) 2002-2005 STMicroelectronics
20、0;*/ unsigned char buffer10; / 定義全局變量 main() unsigned char i; / 定義局部變量 for(i=0;i<10;i+)
21、; bufferi = 0x55; 我們可以通過DEBUG中的反匯編窗口,看到如下的對應(yīng)代碼: 從這段代碼中可以看到,全局變量buffer被分配到空間從地址0000H到0009H。而局部變量i那么在堆??臻g中分配,通過PUSH A指令,將堆棧指針減1,騰出一個字節(jié)的空間,而SP+1指向的空間就是分配給局部變量使用的空間。由此可以得出初步的結(jié)論,對于全局變量,內(nèi)存分配是從低地址0000H開始向上分配的。而局部變量那么是
22、在堆棧空間中分配。另外從上一篇文章中,可以知道堆棧指針初始化時為0FFFH。而根據(jù)PUSH指令的定義,當(dāng)壓棧后堆棧指針減1。因此堆棧是從上往下使用的。因此根據(jù)內(nèi)存分配和堆棧使用規(guī)那么,我們在程序設(shè)計時,不能定義過多的變量,免得沒有空間給堆棧使用。換句話說,當(dāng)定義變量時,一定要考慮到堆??臻g,尤其是那些復(fù)雜的系統(tǒng),程序調(diào)用層數(shù)多,這樣就會占用大量的堆??臻g??傊趩纹瑱C的程序設(shè)計時,由于RAM空間非常有限,要充分考慮到全局變量、局部變量、程序調(diào)用層數(shù)和中斷效勞調(diào)用對空間的占用。
23、0; STM8的C語言編程3 GPIO輸出 與前些日子寫的用匯編語言進行的實驗一樣,從今天開始,要在ST的三合一開發(fā)板上,用C語言編寫程序,進行一系列的實驗。首先當(dāng)然從最簡單的LED指示燈閃爍的實驗開始。開發(fā)板上的LED1接在STM8的PD3上,因此要將PD3設(shè)置成輸出模式,為了提高高電平時的輸出電流,要將其設(shè)置成推挽輸出方式。這主要通過設(shè)置對應(yīng)的DDR/CR1/CR2存放器實現(xiàn)。利用ST的開發(fā)工具,先生成一個C語言程序的框架,然后修改其中的main.c,修改后的代碼
24、如下。編譯通過后,下載到開發(fā)板,運行程序,可以看到LED1在閃爍,且閃爍的頻率為5HZ。 /* MAIN.C file * * Copyright (c) 2002-2005 STMicroelectronics */ #include "STM8S207C_S.h" / 函數(shù)功能:延時函數(shù)/ 輸入?yún)?shù):ms - 要延時的毫秒數(shù),這里假設(shè)CPU的主頻為2MHZ/ 輸出參數(shù):無/ 返 回 值:無/ 備 注:無void DelayMS(unsigned int ms)
25、unsigned char i; while(ms != 0) for(i=0;i<250;i+) for(i=0;i<75;i+) ms-; / 函數(shù)功能:主函數(shù)/
26、 初始化GPIO端口PD3,驅(qū)動PD3為高電平和低電平/ 輸入?yún)?shù):ms - 要延時的毫秒數(shù),這里假設(shè)CPU的主頻為2MHZ/ 輸出參數(shù):無/ 返 回 值:無/ 備 注:無main() PD_DDR = 0x08; PD_CR1 = 0x08; / 將PD3設(shè)置成推挽輸出 PD_CR2 = 0x00
27、; while(1) PD_ODR = PD_ODR | 0x08; / 將PD3的輸出設(shè)置成1 DelayMS(100); / 延時100MS PD_ODR = PD_ODR & 0xF7; / 將PD3的輸出設(shè)置成0 Dela
28、yMS(100); / 延時100MS 需要注意的是,
29、當(dāng)生成完框架后,為了能方便使用STM8的存放器名字,必須包括STM8S207C_S.h,最好將該文件拷貝到C:Program FilesSTMicroelectronicsst_toolsetinclude目錄下,拷貝到工程目錄下?;蛘邔⒃撀窂教顚懙皆摴こ痰腟ettings中的C Compiler選項Preprocessor的Additional include中,這樣編譯時才會找到該文件。
30、 STM8的C語言編程4 GPIO輸出和輸入 今天要進行的實驗,是利用GPIO進行輸入和輸出。在ST的三合一開發(fā)板上,按鍵接在GPIO的PD7上,LED接在GPIO的PD3上,因此我們要將GPIO的PD7初始化成輸入,PD3初始化成輸出。關(guān)于GPIO的引腳設(shè)置,主要是要初始化方向存放器DDR,控制存放器1CR1和控制存放器2CR2,存放器的每一位對應(yīng)GPIO的每一個引腳。具體的設(shè)置功能定義如下:DDR CR1 CR2 引腳設(shè)置0
31、160; 0 0 懸浮輸入0 0 1 上拉輸入0 1 0
32、160; 中斷懸浮輸入0 1 1 中斷上拉輸入1 0 0 開漏輸出1 1
33、 0 推挽輸出1 X 1 輸出最快速度為10MHZ另外,輸出引腳對應(yīng)的存放器為ODR,輸入引腳對應(yīng)的存放器為IDR。下面的程序是檢測按鍵的狀態(tài),當(dāng)按鍵按下時,點亮LED,當(dāng)按鍵抬起時,熄滅LED。同樣也是利用ST的開發(fā)工具,先生成一個C語言程序的框架,然后修改其中的main.c,修改后的
34、代碼如下。編譯通過后,下載到開發(fā)板,運行程序,按下按鍵,LED就點亮,抬起按鍵,LED就熄滅了。另外,要注意,將STM8S207C_S.h拷貝到當(dāng)前工程的目錄下。 / 程序描述:檢測開發(fā)板上的按鍵,假設(shè)按下,那么點亮LED,假設(shè)抬起,那么熄滅LED/ 按鍵接在MCU的GPIO的PD7上/ LED接在MCU的GPIO的PD3上 #inclu
35、de "STM8S207C_S.h" main() PD_DDR = 0x08; PD_CR1 = 0x08; / 將PD3設(shè)置成推挽輸出 PD_CR2 = 0x00; while(1)
36、 / 進入無限循環(huán) if(PD_IDR & 0x80) = 0x80) / 讀入PD7的引腳信號 PD_ODR = PD_ODR & 0xF7; / 如果PD7為1,那么將PD3的輸出設(shè)置成0,熄滅LED else &
37、#160; PD_ODR = PD_ODR | 0x08; / 否那么,將PD3的輸出設(shè)置成1,點亮LED
38、60; STM8的C語言編程58位定時器應(yīng)用之一 在STM8單片機中,有多種定時器資源,既有8位的定時器,也有普通的16位定時器,還有高級的定時器。今天的實驗是用最簡單的8位定時器TIM4來進行延時,然后驅(qū)動LED閃爍。為了簡單起見,這里是通過程序查詢定時器是否產(chǎn)生更新事件,來判斷定時器的延時是否結(jié)束。同樣還是利用ST的開發(fā)工具,生成一個C程序的框架,然后修改其中的main.c,修改后的代碼如下。編譯通過后,下載到開發(fā)板,運行程序,可以看到LED在閃爍,或者用示波器可以在LED引腳上看到方波。在這里要特別提醒的是,從ST給的手冊上看,這個定時器中的計數(shù)器是一個
39、加1計數(shù)器,但本人在實驗過程中感覺不太對,經(jīng)過反復(fù)的實驗,我認為應(yīng)該是一個減1計數(shù)器也許是我拿的手冊不對,或許是理解上有誤。例如,當(dāng)給定時器中的自動裝載存放器裝入255時,產(chǎn)生的方波頻率最小,就象下面代碼中計算的那樣,產(chǎn)生的方波頻率為30HZ左右。假設(shè)初始化時給自動裝載存放器裝入1,那么產(chǎn)生的方波頻率最大,大約為3.9K左右。也就是說實際的分頻數(shù)為ARR存放器的值+1。 / 程序描述:通過初始化定時器4,進行延時,驅(qū)動LED閃爍/ LED接在
40、MCU的GPIO的PD3上 #include "STM8S207C_S.h" main() / 首先初始化GPIO PD_DDR = 0x08; PD_CR1 = 0x08; / 將PD3設(shè)置成推挽輸出 PD_CR2 = 0x00; / 然后初始化定時器4
41、160; TIM4_IER = 0x00; / 禁止中斷 TIM4_EGR = 0x01;
42、160; / 允許產(chǎn)生更新事件 TIM4_PSCR = 0x07; / 計數(shù)器時鐘=主時鐘/128=2MHZ/128
43、160; / 相當(dāng)于計數(shù)器周期為64uS TIM4_ARR
44、 = 255; / 設(shè)定重裝載時的存放器值,255是最大值 TIM4_CNTR = 255; / 設(shè)定計數(shù)器的初值
45、160; / 定時周期=(ARR+1)*64=16320uS TIM4_CR1 = 0x01; / b0 = 1,允許計數(shù)器工作
46、60; / b1 = 0,允許更新 / 設(shè)置控制器,啟動定時器
47、; while(1) / 進入無限循環(huán) while(TIM4_SR1 & 0x81) = 0x00); / 等待更新標志 TIM4_SR1 = 0x00;
48、160; / 去除更新標志 PD_ODR = PD_ODR 0x08; / LED驅(qū)動信號取反 &
49、#160; / LED閃爍頻率=2MHZ/128/255/2=30.63
50、; STM8的C語言編程68位定時器應(yīng)用之二 今天進行的實驗依然是用定時器4,只不過改成了用中斷方式來實現(xiàn),由定時器4的中斷效勞程序來驅(qū)動LED的閃爍。實現(xiàn)中斷方式的關(guān)鍵點有幾個,第一個關(guān)鍵點就是要翻開定時器4的中斷允許位,在定時器4的IER存放器中有定義。第二個關(guān)鍵點,就是翻開CPU的全局中斷允許位,在匯編語言中,就是執(zhí)行RIM指令,在C語言中,用以下語句實
51、現(xiàn):_asm("rim");第3個關(guān)鍵點就是中斷效勞程序的框架或?qū)懛?,中斷效勞程序的寫法如下:far interrupt void TIM4_UPD_OVF_IRQHandler (void) / 下面是中斷效勞程序的實體
52、; 第4個關(guān)鍵點就是要設(shè)置中斷向量,即將中斷效勞程序的入口填寫到中斷向量表中,如下所示,將IRQ23對應(yīng)的中斷效勞程序的入口填寫成TIM4_UPD_OVF_IRQHandlerstruct interrupt_vector const _vectab = 0x82, (interrupt_handler_t)_stext, /* reset */ 0x82, NonHandledInterrupt, /* trap */
53、60; 0x82, NonHandledInterrupt, /* irq0 */ 0x82, NonHandledInterrupt, /* irq1 */ 0x82, NonHandledInterrupt, /* irq2 */ 0x82, NonHandledInterrupt, /* irq3 */ &
54、#160; 0x82, NonHandledInterrupt, /* irq4 */ 0x82, NonHandledInterrupt, /* irq5 */ 0x82, NonHandledInterrupt, /* irq6 */ 0x82, NonHandledInterrupt, /* irq7 */
55、; 0x82, NonHandledInterrupt, /* irq8 */ 0x82, NonHandledInterrupt, /* irq9 */ 0x82, NonHandledInterrupt, /* irq10 */ 0x82, NonHandledInterrupt, /* irq11 */ 0x82,
56、NonHandledInterrupt, /* irq12 */ 0x82, NonHandledInterrupt, /* irq13 */ 0x82, NonHandledInterrupt, /* irq14 */ 0x82, NonHandledInterrupt, /* irq15 */ 0x82, NonHandledInterrupt, /*
57、irq16 */ 0x82, NonHandledInterrupt, /* irq17 */ 0x82, NonHandledInterrupt, /* irq18 */ 0x82, NonHandledInterrupt, /* irq19 */ 0x82, NonHandledInterrupt, /* irq20 */
58、0; 0x82, NonHandledInterrupt, /* irq21 */ 0x82, NonHandledInterrupt, /* irq22 */ 0x82, TIM4_UPD_OVF_IRQHandler,/* irq23 */ 0x82, NonHandledInterrupt, /* irq24 */ 0x82, NonHandledInterrup
59、t, /* irq25 */ 0x82, NonHandledInterrupt, /* irq26 */ 0x82, NonHandledInterrupt, /* irq27 */ 0x82, NonHandledInterrupt, /* irq28 */ 0x82, NonHandledInterrupt, /* irq29 */;解決了以上4個關(guān)鍵
60、點,我們就能很輕松地用C語言實現(xiàn)中斷效勞了。同樣還是利用ST的開發(fā)工具,生成一個C程序的框架,然后修改其中的main.c,修改后的代碼如下。另外還要修改stm8_interrupt_vector.c。編譯通過后,下載到開發(fā)板,運行程序,可以看到LED在閃爍,或者用示波器可以在LED引腳上看到方波。 修改后的main.c如下:/ 程序描述:通過初始化定時器4,以中斷方式驅(qū)動LED閃爍/ LED接在MCU的GPIO的PD3上
61、0;#include "STM8S207C_S.h" main() / 首先初始化GPIO PD_DDR = 0x08; PD_CR1 = 0x08; / 將PD3設(shè)置成推挽輸出 PD_CR2 = 0x00; / 然后初始化定時器4 &
62、#160; TIM4_IER = 0x00; / 禁止中斷 TIM4_EGR = 0x01; &
63、#160; / 允許產(chǎn)生更新事件 TIM4_PSCR = 0x07; / 計數(shù)器時鐘=主時鐘/128=2MHZ/128 &
64、#160; / 相當(dāng)于計數(shù)器周期為64uS TIM4_ARR = 255;
65、0; / 設(shè)定重裝載時的存放器值,255是最大值 TIM4_CNTR = 255; / 設(shè)定計數(shù)器的初值
66、160; / 定時周期=(ARR+1)*64=16320uS TIM4_CR1 = 0x01; / b0 = 1,允許計數(shù)器工作
67、160; / b1 = 0,允許更新 / 設(shè)置控制器,啟動定時器 TIM4_IER = 0x01;
68、; / 允許更新中斷 _asm("rim"); / 允許CPU全局中斷 while(1)
69、 / 進入無限循環(huán) / 函數(shù)功能:定時器4的更新中斷效勞程序/ 輸入?yún)?shù):無/ 輸出參數(shù):無/ 返 回 值:無far interrupt void TI
70、M4_UPD_OVF_IRQHandler (void) TIM4_SR1 = 0x00; / 去除更新標志 PD_ODR = PD_ODR 0x08; / LED驅(qū)動信號取反
71、160; /LED閃爍頻率=2MHZ/128/255/2=30.63 &
72、#160; 修改后的stm8_interrupt_vector.c如下:/* BASIC INTERRUPT VECTOR TABLE FOR STM8 devices * Copyright (c) 2007 STMicroelectronics */ typedef void far (*interrupt_handler_t)(void); struct interrupt_vector
73、60; unsigned char interrupt_instruction; interrupt_handler_t interrupt_handler; far interrupt void NonHandledInterrupt (void) /* in order to detect unexpected events during development, &
74、#160; it is recommended to set a breakpoint on the following instruction */ return; extern void _stext(); /* startup routine */extern far interrupt void TIM4_UPD_OVF_IR
75、QHandler (void); struct interrupt_vector const _vectab = 0x82, (interrupt_handler_t)_stext, /* reset */ 0x82, NonHandledInterrupt, /* trap */ 0x82, NonHandledInterrupt, /* irq0
76、0; */ 0x82, NonHandledInterrupt, /* irq1 */ 0x82, NonHandledInterrupt, /* irq2 */ 0x82, NonHandledInterrupt, /* irq3 */ 0x82, NonHandledIn
77、terrupt, /* irq4 */ 0x82, NonHandledInterrupt, /* irq5 */ 0x82, NonHandledInterrupt, /* irq6 */ 0x82, NonHandledInterrupt, /* irq7 */
78、; 0x82, NonHandledInterrupt, /* irq8 */ 0x82, NonHandledInterrupt, /* irq9 */ 0x82, NonHandledInterrupt, /* irq10 */ 0x82, NonHandledInterrupt, /* irq11 */ &
79、#160; 0x82, NonHandledInterrupt, /* irq12 */ 0x82, NonHandledInterrupt, /* irq13 */ 0x82, NonHandledInterrupt, /* irq14 */ 0x82, NonHandledInterrupt, /* irq15 */ &
80、#160; 0x82, NonHandledInterrupt, /* irq16 */ 0x82, NonHandledInterrupt, /* irq17 */ 0x82, NonHandledInterrupt, /* irq18 */ 0x82, NonHandledInterrupt, /* irq19 */ &
81、#160; 0x82, NonHandledInterrupt, /* irq20 */ 0x82, NonHandledInterrupt, /* irq21 */ 0x82, NonHandledInterrupt, /* irq22 */ 0x82, TIM4_UPD_OVF_IRQHandler,/* irq23 */ 0x8
82、2, NonHandledInterrupt, /* irq24 */ 0x82, NonHandledInterrupt, /* irq25 */ 0x82, NonHandledInterrupt, /* irq26 */ 0x82, NonHandledInterrupt, /* irq27 */ 0x8
83、2, NonHandledInterrupt, /* irq28 */ 0x82, NonHandledInterrupt, /* irq29 */; STM8的C語言編程716位定時器的中斷應(yīng)用 在STM8中,除了有8位的定時器外,還有16位的定時器。今天進行的實驗就是針對16位定時器2來進行的。除了計數(shù)單元為16位的,其
84、它設(shè)置與前面8位的定時器根本一樣。下面的程序也是采樣中斷方式,由定時器2的中斷效勞程序來驅(qū)動LED的閃爍。具體的程序代碼如下,其它注意點見上一篇,另外要注意別忘了修改相應(yīng)的中斷向量。 / 程序描述:通過初始化定時器2,以中斷方式驅(qū)動LED閃爍/ LED接在MCU的GPIO的PD3上 #include "STM8S207C_S.h" main() / 首先初始化GPIO PD_DD
85、R = 0x08; PD_CR1 = 0x08; / 將PD3設(shè)置成推挽輸出 PD_CR2 = 0x00; / 然后初始化定時器4 &
86、#160; TIM2_IER = 0x00; / 禁止中斷 TIM2_EGR = 0x01; / 允許產(chǎn)生更新事件 TIM2_PSCR = 0x01;
87、160; / 計數(shù)器時鐘=主時鐘/128=2MHZ/2
88、160; / 相當(dāng)于計數(shù)器周期為1uS
89、;
90、;
91、; / 設(shè)定重裝載時的存放器值
92、160;
93、160;
94、160; / 注意必須保證先寫入高8位,再寫入低8位 TIM2_ARRH = 0xEA; / 設(shè)定重裝載時的存放器的高
95、8位 TIM2_ARRL = 0x60; TIM2_CNTRH = 0xEA; / 設(shè)定計數(shù)器的初值 TIM2_CNTRL = 0x60;
96、 / 定時周期=1*60000=60000uS=60ms
97、160; TIM2_CR1 = 0x01; / b0 = 1,允許計數(shù)器工作 / b1 = 0,允許更新&
98、#160; / 設(shè)置控制器,啟動定時器 TIM2_IER = 0x01; / 允許更新中斷 _asm(&qu
99、ot;rim"); / 允許CPU全局中斷 while(1) / 進入無限循環(huán)
100、160; / 函數(shù)功能:定時器4的更新中斷效勞程序/ 輸入?yún)?shù):無/ 輸出參數(shù):無/ 返 回 值:無far interrupt void TIM2_UPD_IRQHandler (void) TIM2_SR1 = 0x00;
101、160; / 去除更新標志 PD_ODR = PD_ODR 0x08; / LED驅(qū)動信號取反 /LED閃爍頻率=2MHZ/2/60
102、000/2=8.3
103、160; STM8的C語言編程8 UART應(yīng)用 串口通訊也是單片機應(yīng)用中經(jīng)常要用到,今天的實驗就是利用STM8的UART資源,來進行串口通訊的實驗。實驗程序的功能是以中斷方式接收串口數(shù)據(jù),然后將接收到的數(shù)據(jù)以查詢方式發(fā)送到串口。程序代碼如下,首先要對STM8的UART進行初始化,初始化時要注意的是波特率存放器的設(shè)置,當(dāng)求出一個波特率的分頻系數(shù)一個16位的數(shù)后,要將高4位和低4位寫到BRR2中,而將中間的8位寫到BRR1中,并且必須是先寫B(tài)RR2,再寫B(tài)RR1。同樣也是利用ST的開發(fā)工具,生成一個C語言的
104、框架,然后修改其中的main.c,同時由于需要用到中斷效勞,因此還要修改stm8_interrupt_vector.c。修改后,編譯連接,然后下載到開發(fā)板上,再做一根與PC機相連的線,把開發(fā)板的串口與PC機的串口連接起來,注意,2、3腳要交叉。在PC機上運行超級終端,設(shè)置波特率為9600,然后每按下一個按鍵,屏幕上就顯示對應(yīng)的字符。修改后的main.c和stm8_interrupt_vector.c如下:/ 程序描述:初始化UART,以中斷方式接收字符,以查詢方式發(fā)送/
105、60; UART通訊參數(shù):9600bps,8位數(shù)據(jù),1位停止位,無校驗 #include "STM8S207C_S.h" / 函數(shù)功能:初始化UART/ 輸入?yún)?shù):無/ 輸出參數(shù):無/ 返 回 值:無/ 備 注:無void UART3_Init(void) LINUART_CR2 = 0; / 禁止UART發(fā)送和接收
106、; LINUART_CR1 = 0; / b5 = 0,允許UART / b2 = 0,禁止校驗
107、 LINUART_CR3 = 0; / b5,b4 = 00,1個停止位
108、; / 設(shè)置波特率,必須注意以下幾點:/ (1) 必須先寫B(tài)RR2/ (2) BRR1存放的是分頻系數(shù)的第11位到第4位,/ (3) BRR2存放的是分頻系數(shù)的第15位到第12位,和第3位到第
109、0位/ 例如對于波特率位9600時,分頻系數(shù)=2000000/9600=208/ 對應(yīng)的十六進制數(shù)為00D0,BBR1=0D,BBR2=00 LINUART_BRR2 = 0; LINUART_BRR1 = 0x0d; / 實際的波特率分頻系數(shù)為00D0(208)
110、
111、; / 對應(yīng)的波特率為2000000/208=9600 LINUART_CR2 = 0x2C;
112、 / b3 = 1,允許發(fā)送 / b2 = 1,允許接收
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 保健品批發(fā)商的社區(qū)健康宣傳效果評估考核試卷
- 2025年信息安全技術(shù)協(xié)議
- 2025年婚慶策劃特許經(jīng)營合同
- 2025年室外海灘保險協(xié)議
- 二零二五年度影視行業(yè)模特肖像權(quán)與隱私保護合同樣本4篇
- 二零二五年度抖音與生活方式品牌合作合同9篇
- 二零二五年度船舶制造設(shè)備采購與安裝合同
- 2025年沙石零售行業(yè)深度研究分析報告
- 二零二五年度出借信息咨詢與金融科技解決方案合同4篇
- 2024年金融科技產(chǎn)品創(chuàng)新與推廣合同
- 我的家鄉(xiāng)瓊海
- (2025)專業(yè)技術(shù)人員繼續(xù)教育公需課題庫(附含答案)
- 《互聯(lián)網(wǎng)現(xiàn)狀和發(fā)展》課件
- 【MOOC】計算機組成原理-電子科技大學(xué) 中國大學(xué)慕課MOOC答案
- 2024年上海健康醫(yī)學(xué)院單招職業(yè)適應(yīng)性測試題庫及答案解析
- 2024年湖北省武漢市中考語文適應(yīng)性試卷
- 非新生兒破傷風(fēng)診療規(guī)范(2024年版)解讀
- EDIFIER漫步者S880使用說明書
- 皮膚惡性黑色素瘤-疾病研究白皮書
- 從心理學(xué)看現(xiàn)代家庭教育課件
- C語言程序設(shè)計PPT(第7版)高職完整全套教學(xué)課件
評論
0/150
提交評論