51與STM32單片機架構(內核和片上外設)的區別彙總+拓展

**

單片機簡介**

單片微型計算機簡稱單片機,簡單來說就是集CPU(運算、控制)、RAM(數據存儲-內存)、ROM(程序存儲)、輸入輸出設備(串口、並口等)和中斷系統處於同一芯片的器件,在我們自己的個人電腦中,CPU、RAM、ROM、I/O這些都是單獨的芯片,然後這些芯片被安裝在一個主板上,這樣就構成了我們的PC主板,進而組裝成電腦,而單片機只是將這所有的集中在了一個芯片上而已(一個集成封裝樣式的芯片就是一臺pc,不要把那個開發板電路板也算進去)。
  
   在這裏插入圖片描述【就這個就叫單片機】
  在這裏插入圖片描述
  我們先普及一個概念,單片機(即Microcontroller Unit;MCU) 裏面有什麼。一個人最重要的是大腦,身體的各個部分都在大腦的指揮下工作。MCU跟人體很像,簡單來說是由一個最重要的內核加其他外設組成,內核就相當於人的大腦,外設就如人體的各個功能器官。下面我們來簡單介紹下51單片機和STM32單片機的結構。
**

一、51與STM32單片機架構

1、51架構

**
在這裏插入圖片描述
在這裏插入圖片描述
51系統結構框圖

我們說的51一般是指51系列的單片機,型號有很多,常見的有STC89C51、AT89S51,其中國內用的最多的是STC89C51/2,下面我們就以STC89C51來講解,並以51簡稱。

  1. 內核
      51單片機由一個IP核和片上外設組成,IP核(內核)就是上圖中的CPU,片上外設就是上圖中的:時鐘電路、SFR和RAM、ROM、定時/計數器、並行I/O口、串行I/O口、中斷系統。IP核跟外設之間由系統總線連接,且是8bit的,速度有限。

51內核是上個世紀70年代Intel公司設計的,速度只有12M,外設是IC廠商(STC)在內核的基礎上添加的,不同的IC廠商會在內核上添加不同的外設,從而設計出各具特色的單片機。這裏Intel屬於IP核廠商,STC屬於IC廠商。我們後面要講的STM32也一樣,ARM屬於IP核廠商,ARM給ST授權,ST公司在Cortex-M3內核的基礎上設計出STM32單片機。

  1. 外設
      我們在學習51的時候,關於內核部分接觸的比較少,使用的最多的是片上外設,我們在編程的時候操作的也就是這些外設。

編程的時候操作的寄存器位於SFR和RAM這個部分,其中SFR(特殊功能寄存器)佔有 128字節(實際上只用了 26 個字節,只有 26 個寄存器,其他都屬於保留區),RAM佔有 128 字節,我們在程序中定義的變量就是放在RAM中。其中SFR和RAM在地址上是重合的,都是在80~FF地址區間,但在物理區間上是分開的,所以51的RAM是有256個字節。

編寫好的程序是燒寫到ROM區。剩下的外設都是我們非常熟悉的IO口,串口、定時器、中斷這幾個外設。
【51單片機的CPU結構】

51單片機內部有一個8位的CPU,包含運算器,控制器及若干寄存器等。
在這裏插入圖片描述【注意】上圖中這個外存儲器是在cpu虛線外面

2. STM32架構

在這裏插入圖片描述
STM32系統結構框圖

  1. 內核

在系統結構上,STM32和51都屬於單片機,都是由內核和片上外設組成。只是STM32使用的Cortex-M3內核比51複雜得多,優秀得多,支持的外設也比51多得多,同時總線寬度也上升到32bit,無論速度、功耗、外設都強於51。

從結構框圖上看,對比51內核只有一種總線,取指和取數共用。Cortex-M3內部有若干個總線接口,以使CM3能同時取址和訪內(訪問內存),它們是:

指令存儲區總線(兩條)、系統總線、私有外設總線。有兩條代碼存儲區總線負責對代碼存儲區(即FLASH外設)的訪問,分別是I-Code總線和D-Code總線。

I-Code用於取指,D-Code用於查表等操作,它們按最佳執行速度進行優化。

系統總線(System)用於訪問內存和外設,覆蓋的區域包括SRAM,片上外設,片外RAM,片外擴展設備,以及系統級存儲區的部分空間。

私有外設總線負責一部分私有外設的訪問,主要就是訪問調試組件。它們也在系統級存儲區。

還有一個DMA總線,從字面上看,DMA是data memory access的意思,是一種連接內核和外設的橋樑,它可以訪問外設、內存,傳輸不受CPU的控制,並且是雙向通信。簡而言之,這個傢伙就是一個速度很快的且不受老大控制的數據搬運工,這個在51裏面是沒有的。

  1. 外設

從結構框圖上看, STM32比51的外設多得多,51有的串口、定時器、IO口等外設 STM32 都有。STM32還多了很多特色外設:如FSMC、SDIO、SPI、I2C等,這些外設按照速度的不同,分別掛載到AHB、APB2、APB1這三條總線上。
(中間這段內容我也看了一個大佬的內容然後覺得非常精煉,與其再組織語言去描述,不如直接copy過來供大家閱讀分析)

51單片機特性

1、從內部的硬件到軟件有一套完整的按位操作系統,稱作位處理器(CPU),處理對象不是字或字節而是位。不但能對片內某些特殊功能寄存器的某位進行處理,如傳送、置位、清零、測試等,還能進行位的邏輯運算,其功能十分完備,使用起來得心應手。

2、同時在片內RAM區間還特別開闢了一個雙重功能的地址區間,使用極爲靈活,這一功能無疑給使用者提供了極大的方便,

3、乘法和除法指令,這給編程也帶來了便利。很多的八位單片機都不具備乘法功能,作乘法時還得編上一段子程序調用,十分不便。
STM32單片機特性

1、內核:ARM32位Cortex-M3CPU,最高工作頻率72MHz,1.25DMIPS/MHz,單週期乘法和硬件除法

2、存儲器:片上集成32-512KB的Flash存儲器。6-64KB的SRAM存儲器

3、時鐘、復位和電源管理:2.0-3.6V的電源供電和I/O接口的驅動電壓。POR、PDR和可編程的電壓探測器(PVD)。4-16MHz的晶振。內嵌出廠前調校的8MHz RC振盪電路。內部40 kHz的RC振盪電路。用於CPU時鐘的PLL。帶校準用於RTC的32kHz的晶振

4、調試模式:串行調試(SWD)和JTAG接口。最多高達112個的快速I/O端口、最多多達11個定時器、最多多達13個通信接口。

二、由PC的操作系統、內核聯想到MCU

操作系統是配置在計算機硬件上的第一層軟件,是對硬件系統的首次擴充。
  操作系統定義:一組控制和管理計算機硬件和管理軟件資源,合理對各類作業進行調度,以及方便用戶使用的一組程序的集合屬於軟件);
一、cpu:
cpu是central process unit的簡稱,是計算機的核心處理器。cpu的作用是運行機器語言指令。高級語言和彙編語言程序被編譯成cpu能理解的機器語言(二級制代碼)後,存入到內存中,cpu就會從內存中讀取並執行這些指令序列,完成程序功能
包括控制器、寄存器、運算器、時鐘四個部分組成。
運算器是用來進行邏輯計算的,
寄存器是臨時存放中間數據以及指令的;包括程序計數器、指令寄存器、數據寄存器、地址寄存器等。 寄存器是彙編語言所研究的對象,彙編語言通過對寄存器的控制(寫入,讀出,加),實現功能。程序計數器和內存的關係:程序計數器記錄了當前執行的指令在內存中年存儲的位置。
控制器是用來控制何時將內存的數據及指令讀入寄存器,何時將寄存器中的值輸出到內存。
時鐘是同步各個部件之間的步調;
二、內存RAM
內存又叫主存,與cpu的寄存器鏈接,用於將數據以及指令輸入到寄存器中;同時也可以接受寄存器的輸出。本質是作爲磁盤與寄存器的中間件,起到緩衝作用。斷電後會丟失所有數據。
內存和磁盤的關係:由於磁盤的讀寫速度與cpu相差太大,如果cpu直接從磁盤中讀取數據,會造成cpu計算能力極大的浪費。爲了解決這個問題,在磁盤與cpu之間加一個內存,將磁盤存儲的程序以及數據線讀入內存中,cpu直接與內存打交道。此外,由於內存的空間比磁盤小很多,會出現內存不夠用的情況,此時,會將一部分磁盤當做內存來使用,也就是虛擬內存。
三、磁盤ROM
存放數據的,容量比內存大,速度慢。
斷電不會丟失數據。
四、指令:
指令是控制cpu按照一定功能運算的機器碼。每一種cpu有自己的一套指令集。高級語言編寫的程序最終也要編譯成可以讓cpu理解的一條條機器指令,才能被cpu執行。cpu除了可以計算數據以外,還可以控制硬件,方法是通過cpu寄存器與I/O端口進行數據交換。計算機中主機與外圍硬件的鏈接方式是通過I/O端口進行的(端口是用於主機寄存器與外圍設備交換數據時臨時存儲數據的寄存器)。所以,指令通過控制cpu的輸出和輸入位置,可以讓cpu寄存器向I/O端口寄存器發送數據,外圍設備通過與I/O寄存器交換數據,從而達到控制外圍設備的效果。而操作系統的作用是封裝一套指令序列,cpu通過執行這套指令序列,可以讓硬件完成一系列動作。而應用程序如果需要對硬件進行操作,只需要將操作系統的這套指令序列複製到自己的程序中即可。複製這套指令的方式就是API(API就是操作系統留給應用程序的一個調用接口,應用程序通過調用操作系統的 API 而使操作系統去執行應用程序的命令。)。從這個角度來看,操作系統就是封裝了控制硬件完成一系列動作的指令序列的集合,這套集合提供給應用程序以及計算機的使用者。從而達到了將人、應用程序與硬件隔離的效果。
五、操作系統的內核
操作系統內核(就是操作系統最核心最底層的一部分代碼(基礎代碼))
內核,是一個操作系統的核心。它負責管理系統的進程、內存、設備驅動程序、文件和網絡系統,決定着系統的性能和穩定性。
“內核”指的是一個提供硬件抽象層、磁盤及文件系統控制、多任務等功能的系統軟件。一個內核不是一套完整的操作系統。一套基於Linux內核的完整操作系統叫作Linux操作系統,或是GNU/Linux。
現在主流的操作系統內核有四個:Unix、Linux、Windows、OS/2
其他很多各種各樣以及各個版本的系統都是建立在這四種內核的基礎上的。

所以不妨大膽去想MCU是集成版PC,所以操作系統等控制CPU的軟件程序指令就好比你燒錄到單片機裏面的程序一樣(暫時這樣理解),那麼指令又是如何控制CPU呢?
在這裏插入圖片描述
在這裏插入圖片描述
在這裏插入圖片描述
在這裏插入圖片描述
在這裏插入圖片描述
cpu只能執行所支持的指令集裏的指令,不同公司的產品對應有自己的指令集,cpu是出廠前預先設計製造好的電路,操作系統/軟件程序編寫肯定是要對照着相應產品cpu的指令集,這樣的程序編譯後才能讓cpu執行,也就是控制cpu;

發佈了14 篇原創文章 · 獲贊 3 · 訪問量 5490
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章