【認識STM32】
F1 代表了基礎型,基于 Cortex-M3 內核,主頻為72MHZ,F4 代表了高性能,基于 Cortex-M4 內核,主頻 180M。
?
?
【GPIO外設】
一、GPIO的八種工作模式
1、上拉輸入:IO口在無輸入的情況下,保持高電平。
2、下拉輸入:IO口在無輸入的情況下,保持低電平。
3、浮空輸入:浮空輸入狀態下,IO的電平狀態是不確定的,完全由外部輸入決定,如果在該引腳懸空的情況下,讀取該端口的電平是不確定的。
4、模擬輸入:輸入信號不經施密特觸發器直接接入,輸入信號為模擬量而非數字量,其余輸入方式輸入數字量。
5、推挽輸出:可以輸出高、低電平,連接數字器件;推挽結構一般是指兩個三極管分別受兩個互補信號的控制,總是在一個三極管導通的時候另一個截止。高低電平由IC的電源決定。導通損耗小、效率高。輸出既可以向負載灌電流,也可以從負載抽取電流。推拉式輸出級既提高電路的負載能力,又提高開關速度。
6、開漏輸出:輸出端相當于三極管的集電極,要得到高電平狀態需要上拉電阻才行。適合于做電流型的驅動,其吸收電流的能力相對強(一般20mA以內)。開漏形式的電路有以下幾個特點:
(1)利用外部電路的驅動能力,減少IC內部的驅動。當IC內部MOSFET導通時,驅動電流是從外部的VCC流經上拉電阻、MOSFET到GND。IC內部僅需很小的柵極驅動電流。
(2)一般來說,開漏是用來連接不同電平的器件,匹配電平用的,因為開漏引腳不連接外部的上拉電阻時,只能輸出低電平,如果需要同時具備輸出高電平的功能,則需要接上拉電阻,很好的一個優點是通過改變上拉電源的電壓,便可以改變傳輸電平。比如加上上拉電阻就可以提供TTL/CMOS電平輸出等。(上拉電阻的阻值決定了邏輯電平轉換的速度。阻值越大,速度越低功耗越小,所以負載電阻的選擇要兼顧功耗和速度。)
(3)開漏輸出提供了靈活的輸出方式,但是也有其弱點,就是帶來上升沿的延時。因為上升沿是通過外接上拉無源電阻對負載充電,所以當電阻選擇小時延時就小,但功耗大;反之延時大功耗小。所以如果對延時有要求,則建議用下降沿輸出。
(4)可以將多個開漏輸出連接到一條線上。通過一只上拉電阻,在不增加任何器件的情況下,形成“與邏輯”關系,即“線與”。可以簡單的理解為:在所有引腳連在一起時,外接一上拉電阻,如果有一個引腳輸出為邏輯0,相當于接地,與之并聯的回路“相當于被一根導線短路”,所以外電路邏輯電平便為0,只有都為高電平時,與的結果才為邏輯1。
7、復用推挽輸出:此時IO受內部外設控制,比如定時器的PWM,比如SPI的MOSI,MISO等。而普通的推挽輸出,則IO受ODR控制。
8、復用開漏輸出:參考復用推挽。
二、總結在STM32中選用IO模式
1、浮空輸入GPIO_IN_FLOATING ——浮空輸入,可以做KEY識別,RX1。
2、帶上拉輸入GPIO_IPU——IO內部上拉電阻輸入。
3、帶下拉輸入GPIO_IPD—— IO內部下拉電阻輸入。
4、模擬輸入GPIO_AIN ——應用ADC模擬輸入,或者低功耗下省電。
5、開漏輸出GPIO_OUT_OD ——IO輸出0接GND,IO輸出1,懸空,需要外接上拉電阻,才能實現輸出高電平。當輸出為1時,IO口的狀態由上拉電阻拉高電平,但由于是開漏輸出模式,這樣IO口也就可以由外部電路改變為低電平或不變。可以讀IO輸入電平變化,實現C51的IO雙向功能。
6、推挽輸出GPIO_OUT_PP ——IO輸出0-接GND, IO輸出1 -接VCC,讀輸入值是未知的。
7、復用功能的推挽輸出GPIO_AF_PP ——片內外設功能(I2C的SCL,SDA)。
8、復用功能的開漏輸出GPIO_AF_OD——片內外設功能(TX1,MOSI,MISO.SCK.SS)。
【RCC時鐘】
RCC時鐘的主要作用:設置系統時鐘 SYSCLK 、設置 AHB 分頻因子(決定 HCLK 等于多少)、設置 APB2 分頻因子(決定 PCLK2 等于多少)、設置 APB1 分頻因子(決定 PCLK1 等于多少)、設置各個外設的分頻因子;控制 AHB 、 APB2 和 APB1 這三條總線時鐘的開啟、控制每個外設的時鐘的開啟。對于 SYSCLK、HCLK、PCLK2、PCLK1 這四個時鐘的配置一般是:PCLK2 = HCLK = SYSCLK=PLLCLK = 72M, PCLK1=HCLK/2 = 36M。(以stm32f103vet6為例)
使用HSE時,設置系統時鐘的步驟
* 1、開啟HSE ,并等待 HSE 穩定
* 2、設置 AHB、APB2、APB1的預分頻因子
* 3、設置PLL的時鐘來源,和PLL的倍頻因子,設置各種頻率主要就是在這里設置
* 4、開啟PLL,并等待PLL穩定
* 5、把PLLCK切換為系統時鐘SYSCLK
* 6、讀取時鐘切換狀態位,確保PLLCLK被選為系統時鐘
【NVIC是嵌套向量中斷控制器】
一、優先級定義
在 NVIC 有一個專門的寄存器:中斷優先級寄存器 NVIC_IPRx,用來配置外部中斷的優先級,IPR 寬度為 8bit,原則上每個外部中斷可配置的優先級為 0~255,數值越小,優先級越高。但是絕大多數 CM3 芯片都會精簡設計,以致實際上支持的優先級數減少,在 F103 中,只使用了高 4bit,用于表達優先級的這 4bit,又被分組成搶占優先級和子優先級。如果有多個中斷同時響應,搶占 優先級高的就會搶占搶占優先級低的優先得到執行,如果搶占優先級相同,就比較子優先級。如果搶占優先級和子優先級都相同的話,就比較他們的硬件中斷編號,編號越小,優先級越高。
二、優先級分組
優先級的分組由內核外設 SCB 的應用程序中斷及復位控制寄存器 AIRCR 的 PRIGROUP[10:8] 位 決定,F103 分為了 5 組,具體如下:主優先級 = 搶占優先級。
【EXTI外部中斷/事件控制器】
EXTI(External interrupt/event controller)—外部中斷/事件控制器,管理了控制器的 20 個中斷/事 件線。每個中斷/事件線都對應有一個邊沿檢測器,可以實現輸入信號的上升沿檢測和下降沿的檢測。EXTI 可以實現對每個中斷/事件線進行單獨配置,可以單獨配置為中斷或者事件,以及觸 發事件的屬性。
【SysTick系統定時器】
SysTick—系統定時器是屬于 CM3 內核中的一個外設,內嵌在 NVIC 中。系統定時器是一個 24bit 的向下遞減的計數器,計數器每計數一次的時間為 1/SYSCLK,一般我們設置系統時鐘 SYSCLK 等于 72M。當重裝載數值寄存器的值遞減到 0 的時候,系統定時器就產生一次中斷,以此循環往 復。
【通訊的基本概念】
一、串行通訊與并行通訊
按數據傳送的方式,通訊可分為串行通訊與并行通訊,串行通訊是指設備之間通過少量數據信號線 (一般是 8 根以下),地線以及控制信號線,按數據位形式一位一位地傳輸數據的通訊方式。而并行通訊一般是指使用 8、16、32 及 64 根或更多的數據線進行傳輸的通訊方式。
二、全雙工、半雙工及單工通訊
根據數據通訊的方向,通訊又分為全雙工、半雙工及單工通訊,它們主要以信道的方向來區。
三、同步通訊與異步通訊
根據通訊的數據同步方式,又分為同步和異步兩種,可以根據通訊過程中是否有使用到時鐘信號。
在同步通訊中,收發設備雙方會使用一根信號線表示時鐘信號,在時鐘信號的驅動下雙方進行協 調,同步數據,見圖同步通訊 。通訊中通常雙方會統一規定在時鐘信號的上升沿或下降沿對數 據線進行采樣。
在異步通訊中不使用時鐘信號進行數據同步,它們直接在數據信號中穿插一些同步用的信號位, 或者把主體數據進行打包,以數據幀的格式傳輸數據,見圖某種異步通訊 ,某些通訊中還需要雙方約定數據的傳輸速率,以便更好地同步。
在同步通訊中,數據信號所傳輸的內容絕大部分就是有效數據,而異步通訊中會包含有幀的各種標識符,所以同步通訊的效率更高,但是同步通訊雙方的時鐘允許誤差較小,而異步通訊雙方的時鐘允許誤差較大。
四、通訊速率
衡量通訊性能的一個非常重要的參數就是通訊速率,通常以比特率 (Bitrate) 來表示,即每秒鐘傳輸的二進制位數,單位為比特每秒 (bit/s)。容易與比特率混淆的概念是“波特率”(Baudrate),它表示每秒鐘傳輸了多少個碼元。通訊中常用時間間隔相同的符號來表示一個二進制數字,這樣的信號稱為碼元。
例:常見的通訊傳輸中,用 0V 表示數字 0,5V 表示數字 1,那么一個碼元可以表示兩種狀態 0 和 1,所以一個碼元等于一個二進制比特位,此時波特率的大小與比特率一致;如果在通訊傳輸中,有 0V、2V、4V 以及 6V 分別表示二進制數 00、01、10、11,那么每個碼元可以表示四種狀態,即兩個二進制比特位,所以碼元數是二進制比特位數的一半,這個時候的波特率為比特率的一半。因為很多常見的通訊中一個碼元都是表示兩種狀態,人們常常直接以波特率來表示比特率。
【串口通訊】
一、物理層:
串口通訊的物理層有很多標準及變種,我們主要講解 RS-232 標準。
根據通訊使用的電平標準不同,串口通訊可分為 TTL 標準及 RS-232 標準。
TTL 的電平標準,理想狀態下,使用 5V 表示二進制邏輯 1,使用 0V 表示邏輯 0;而為了增加串口通訊的遠距離傳輸及抗干擾能力,它使用-15V 表示邏輯 1,+15V 表示邏輯 0,即RS232。
因為控制器一般使用 TTL 電平標準,所以常常會使用 MA3232 芯片對 TTL 及 RS-232 電平的信號進行互相轉換。
在目前的其它工業控制使用的串口通訊中,一般只使用 RXD、TXD 以及 GND 三條信號線,直接傳輸數據信號,而 RTS、CTS、DSR、DTR 及 DCD 信號都被裁剪掉了。
二、協議層
串口通訊的數據包由發送設備通過自身的 TXD 接口傳輸到接收設備的 RXD 接口。在串口通訊的協議層中,規定了數據包的內容,它由啟始位、主體數據、校驗位以及停止位組成,通訊雙方的數據包格式要約定一致才能正常收發數據。
波特率:串口異步通訊,異步通訊中由于沒有時鐘信號 (如前面講解的 DB9 接口中是 沒有時鐘信號的),所以兩個通訊設備之間需要約定好波特率,即每個碼元的長度,以便對信號 進行解碼,圖串口數據包的基本組成 中用虛線分開的每一格就是代表一個碼元。常見的波特率為 4800、9600,115200 等。
通訊的起始和停止信號:串口通訊的一個數據包從起始信號開始,直到停止信號結束。數據包的起始信號由一個邏輯 0 的數據位表示,而數據包的停止信號可由 0.5、1、1.5 或 2 個邏輯 1 的數據位表示。
有效數據:在數據包的起始位之后緊接著的就是要傳輸的主體數據內容,也稱為有效數據,有效數據的長度常被約定為 5、6、7 或 8 位長。
數據校驗:在有效數據之后,有一個可選的數據校驗位。由于數據通信相對更容易受到外部干擾導致傳輸數據出現偏差,可以在傳輸過程加上校驗位來解決這個問題。校驗方法有奇校驗 (odd)、偶校驗 (even)、0 校驗 (space)、1 校驗 (mark) 以及無校驗 (noparity)。
【I2C】
I2C 通訊協議 (Inter - Integrated Circuit) 是由 Phiilps 公司開發的,由于它引腳少,硬件實現簡單, 可擴展性強,不需要 USART、CAN 等通訊協議的外部收發設備。
一、物理層
1、I2C 通訊設備之間的常用連接方式:
它的物理層有如下特點:
(1) 它是一個支持設備的總線。“總線”指多個設備共用的信號線。在一個 I2C 通訊總線中,可連接多個 I2C 通訊設備,支持多個通訊主機及多個通訊從機。
(2) 一個 I2C 總線只使用兩條總線線路,一條雙向串行數據線 (SDA) ,一條串行時鐘線 (SCL)。數 據線即用來表示數據,時鐘線用于數據收發同步。
(3) 每個連接到總線的設備都有一個獨立的地址,主機可以利用這個地址進行不同設備之間的訪問。
(4) 總線通過上拉電阻接到電源。當 I2C 設備空閑時,會輸出高阻態,而當所有設備都空閑,都 輸出高阻態時,由上拉電阻把總線拉成高電平。
(5) 多個主機同時使用總線時,為了防止數據沖突,會利用仲裁方式決定由哪個設備占用總線。
(6) 具有三種傳輸模式:標準模式傳輸速率為 100kbit/s ,快速模式為 400kbit/s ,高速模式下可達 3.4Mbit/s,但目前大多 I2C 設備尚不支持高速模式。
(7) 連接到相同總線的 IC 數量受到總線的最大電容 400pF 限制。
二、協議層
1、I2C 基本讀寫過程
2、通訊的起始和停止信號
當 SCL 線是高電平時 SDA 線從高電平向低電平切換,這個情況表示通訊的起始。當 SCL 是高電平時 SDA 線由低電平向高電平切換,表示通訊的停止。起始和停止信號一般由主機產生。
2、 數據有效性
SDA 數據線在 SCL 的每個時鐘周期傳輸一位數據。傳輸時,SCL 為高電平的時候 SDA 表示的數據有效,即此時的 SDA 為高電平時表示數據“1”,為低電平時表示數據“0”。當 SCL 為低電平時,SDA的數據無效,一般在這個時候 SDA 進行電平切換,為下一次表示數據做好準備。
每次數據傳輸都以字節為單位,每次傳輸的字節數不受限制。
3、地址及數據方向
I2C 協議規定設備地址可以是 7 位或 10 位,實際中 7 位的地址應用比較廣泛。緊跟設備地址的一個數據位用來表示數據傳輸方向,它是數據方向位 (R/),第 8 位或第 11 位。數據方向位為“1”時表示主機由從機讀數據,該位為“0”時表示主機向從機寫數據。
讀數據方向時,主機會釋放對 SDA 信號線的控制,由從機控制 SDA 信號線,主機接收信號,寫 數據方向時,SDA 由主機控制,從機接收信號。
4、響應
作為數據接收端時,當設備 (無論主從機) 接收到 I2C 傳輸的一個字節數據或地址后,若希望對方繼續發送數據,則需要向對方發送“應答 (ACK)”信號,發送方會繼續發送下一個數據;若接收端 希望結束數據傳輸,則向對方發送“非應答 (NACK)”信號,發送方接收到該信號后會產生一個 停止信號,結束信號傳輸。
傳輸時主機產生時鐘,在第 9 個時鐘時,數據發送端會釋放 SDA 的控制權,由數據接收端控制 SDA,若 SDA 為高電平,表示非應答信號 (NACK),低電平表示應答信號 (ACK)。
【SPI】
SPI 協議是由摩托羅拉公司提出的通訊協議 (Serial Peripheral Interface),即串行外圍設備接口,是 一種高速全雙工的通信總線。它被廣泛地使用在 ADC、LCD 等設備與 MCU 間,要求通訊速率 較高的場合。
一、SPI物理層
SPI 通訊設備之間的常用連接方式:SPI 通訊使用 3 條總線及片選線,3 條總線分別為 SCK、MOSI、MISO,片選線NSS。(SPI 通訊以 NSS 線置低電平為開始信號,以 NSS 線被拉高作為結束信號)
二、協議層
1、SPI 通訊的通訊時序
2、通訊的起始和停止信號
NSS 信號線由高變低,是 SPI 通訊的起始信號。NSS 是每個從機各自獨占的信號線,當從機在自己的 NSS 線檢測到起始信號后,就知道自己被主機選中了,開始準備與主機通訊。NSS 信號由低變高,是 SPI 通訊的停止信號,表示本次通訊結束,從機的選中狀態被取消。
3、數據有效性
MOSI 及 MISO 的數據在 SCK 的上升沿期間變化輸出,在 SCK 的下降沿時被采樣。即在 SCK 的下降沿時刻,MOSI 及 MISO 的數據有效,高電平時表示數據“1”,為低電平時表示數據“0”。在其它時刻,數據無效,MOSI 及 MISO 為下一次表示數據做準備。
SPI 每次數據傳輸可以 8 位或 16 位為單位,每次傳輸的單位數不受限制。
數據傳輸時,MSB先行或 LSB 先行并沒有作硬性規定,但要保證兩個 SPI 通訊設備之間使用同樣的協定,一般都會采用圖 SPI 通訊時序 中的 MSB 先行模式。
4、CPOL/CPHA 及通訊模式
時鐘極性 CPOL 是指 SPI 通訊設備處于空閑狀態時,SCK 信號線的電平信號 (即 SPI 通訊開始前、 NSS 線為高電平時 SCK 的狀態)。CPOL=0 時,SCK 在空閑狀態時為低電平,CPOL=1 時,則相反。
時鐘相位 CPHA 是指數據的采樣的時刻,當 CPHA=0 時,MOSI 或 MISO 數據線上的信號將會在 SCK 時鐘線的“奇數邊沿”被采樣。當 CPHA=1 時,數據線在 SCK 的“偶數邊沿”采樣。
由 CPOL 及 CPHA 的不同狀態,SPI 分成了四種模式,見表 SPI 的四種模式 ,主機與從機需要工 作在相同的模式下才可以正常通訊,實際中采用較多的是“模式 0”與“模式 3”
【DMA直接存儲區訪問】
DMA(Direct Memory Access)—直接存儲器存取,是單片機的一個外設,它的主要功能是用來搬數 據,但是不需要占用 CPU,即在傳輸數據的時候,CPU 可以干其他的事情,好像是多線程一樣。數據傳輸支持從外設到存儲器或者存儲器到存儲器。
DMA 控制器包含了 DMA1 和 DMA2,其中 DMA1 有 7 個通道,DMA2 有 5 個通道,這里的通道 可以理解為傳輸數據的一種管道。要注意的是 DMA2 只存在于大容量的單片機中。
【常用存儲器】
一、存儲器種類
存儲器按其存儲介質特性主要分為“易失性存儲器”和“非易失性存儲器”兩大類。其中的“易失/非易失”是指存儲器斷電后,它存儲的數據內容是否會丟失的特性。
二、易失性存儲器——RAM 存儲器
RAM 是“Random Access Memory”的縮寫,被譯為隨機存儲器。所謂“隨機存取”,指的是當存 儲器中的消息被讀取或寫入時,所需要的時間與這段信息所在的位置無關。
1、DRAM動態隨機存儲器
DRAM 的存儲單元以電容的電荷來表示數據,有電荷代表 1,無電荷代表 0。但時間一長,代表 1 的電容會放電,代表 0 的電容會吸收電荷,因此它需要定期刷新操作,這就是“動態 (Dynamic)”一詞所形容的特性。
2、SRAM靜態隨機存儲器
靜態隨機存儲器 SRAM 的存儲單元以鎖存器來存儲數據,見圖 SRAM 存儲單元 。這種電路結構 不需要定時刷新充電,就能保持狀態 (當然,如果斷電了,數據還是會丟失的),所以這種存儲器 被稱為“靜態 (Static)”RAM。
三、非易失性存儲器
1、ROM 存儲器:ROM 是“Read Only Memory”的縮寫,意為只能讀的存儲器。由于技術的發展,后來設計出了可以方便寫入數據的 ROM,而這個“Read Only Memory”的名稱被沿用下來了。
MASK ROM:MASK(掩膜) ROM 就是正宗的“Read Only Memory”,存儲在它內部的數據是在出廠時使用特殊工藝固化的,生產后就不可修改,其主要優勢是大批量生產時成本低。
OTPROM:OTPROM(One Time Programable ROM) 是一次可編程存儲器。這種存儲器出廠時內部并沒有資料,用戶可以使用專用的編程器將自己的資料寫入,但只能寫入一次,被寫入過后,它的內容也不可再修改。
EPROM:EPROM(Erasable Programmable ROM) 是可重復擦寫的存儲器,它解決了 PROM 芯片只能寫入一次的問題。這種存儲器使用紫外線照射芯片內部擦除數據,擦除和寫入都要專用的設備。現在這種存儲器基本淘汰,被 EEPROM 取代。
EEPROM:EEPROM(Electrically Erasable Programmable ROM) 是電可擦除存儲器。EEPROM 可以重復擦寫,它的擦除和寫入都是直接使用電路控制,不需要再使用外部設備來擦寫。而且可以按字節為單位修改數據,無需整個芯片擦除。
2、FLASH 存儲器
FLASH 存儲器又稱為閃存,它也是可重復擦寫的儲器,部分書籍會把 FLASH 存儲器稱為 FLASH ROM,但它的容量一般比 EEPROM 大得多,且在擦除時,一般以多個字節為單位。根據存儲單元電路的不同,FLASH 存儲器又分為 NOR FLASH 和 NAND FLASH。
【ADC】
STM32f103 系列有 3 個 ADC,精度為 12 位,每個 ADC 最多有 16 個外部通道。其中 ADC1 和 ADC2 都有 16 個外部通道,ADC3 根據 CPU 引腳的不同通道數也不同,一般都有 8 個外部通道。
【DAC】
STM32 具有片上 DAC 外設,它的分辨率可配置為 8 位或 12 位的數字輸入信號,具有兩個 DAC 輸出通道,這兩個通道互不影響,每個通道都可以使用 DMA 功能,都具有出錯檢測能力,可外 部觸發。
【TIM】
一、定時器的分類
STM32F1 系列中,除了互聯型的產品,共有 8 個定時器,分為基本定時器,通用定時器和高級 定時器。
【IWDG獨立看門狗/WWDG窗口看門狗】
一、獨立看門狗定義及使用場景
獨立看門狗:是一個 12 位的遞減計數器,當計數器的值從某個值一直減到 0 的時候,系統就會產生一個復位信號,即 IWDG_RESET。如果在計數沒減到 0 之前,刷新了計數器的值的話,那么就不會產生復位信號,這個動作就是我們經常說的喂狗。
獨立看門狗的時鐘由獨立的 RC 振蕩器 LSI 提供,即使主時鐘發生故障它仍然有效,非常獨立。LSI 的頻率一般在 30~60KHZ 之間,根據溫度和工作場合會有一定的漂移,我們一般取 40KHZ, 所以獨立看門狗的定時時間并一定非常精確,只適用于對時間精度要求比較低的場合。
二、窗口看門狗定義及使用場景
窗口看門狗:跟獨立看門狗一樣,也是一個遞減計數器不斷的往下遞減計數,當減到一個固定值 0X40 時還不喂狗的話,產生復位,這個值叫窗口的下限,是固定的值,不能改變。這個是跟獨立看門狗類似的地方,不同的地方是窗口看門狗的計數器的值在減到某一個數之前喂狗的話也會產生 復位,這個值叫窗口的上限,上限值由用戶獨立設置。窗口看門狗計數器的值必須在上窗口和下 窗口之間才可以喂狗。
三、圖解看門狗
RLR 是重裝載寄存器,用來設置獨立看門狗的計數器的值。TR 是窗口看門狗的計數器的值,由 用戶獨立設置,WR 是窗口看門狗的上窗口值,由用戶獨立設置。
審核編輯:湯梓紅
?
評論
查看更多