91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

STM32芯片的內(nèi)部架構(gòu)如何

電子工程師 ? 來(lái)源:玩點(diǎn)嵌入式 ? 作者:玩點(diǎn)嵌入式 ? 2022-08-08 15:47 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

STM32芯片主要由內(nèi)核和片上外設(shè)組成,STM32F103采用的是Cortex-M3內(nèi)核,內(nèi)核由ARM公司設(shè)計(jì)。STM32的芯片生產(chǎn)廠商ST,負(fù)責(zé)在內(nèi)核之外設(shè)計(jì)部件并生產(chǎn)整個(gè)芯片。這些內(nèi)核之外的部件被稱為核外外設(shè)或片上外設(shè),如 GPIO、USART(串口)、I2C、SPI 等。

芯片內(nèi)部架構(gòu)示意圖

芯片內(nèi)核與外設(shè)之間通過(guò)各種總線連接,其中驅(qū)動(dòng)單元有 4 個(gè),被動(dòng)單元也有 4 個(gè),具體如上圖所示??梢园羊?qū)動(dòng)單元理解成是內(nèi)核部分,被動(dòng)單元都理解成外設(shè)。

ICode 總線

ICode總線是專門用來(lái)取指令的,其中的I表示Instruction(指令),指令的意思。寫好的程序編譯之后都是一條條指令,存放在 FLASH中,內(nèi)核通過(guò)ICode總線讀取這些指令來(lái)執(zhí)行程序。

DCode總線

DCode這條總線是用來(lái)取數(shù)的,其中的D表示Data(數(shù)據(jù))。在寫程序的時(shí)候,數(shù)據(jù)有常量和變量?jī)煞N。常量就是固定不變的,用C語(yǔ)言中的const關(guān)鍵字修飾,放到內(nèi)部FLASH當(dāng)中。變量是可變的,不管是全局變量還是局部變量都放在內(nèi)部的SRAM。

系統(tǒng)System總線

我們通常說(shuō)的寄存器編程,即讀寫寄存器都是通過(guò)系統(tǒng)總線來(lái)完成的,系統(tǒng)總線主要是用來(lái)訪問(wèn)外設(shè)的寄存器。

DMA總線

DMA總線也主要是用來(lái)傳輸數(shù)據(jù),這個(gè)數(shù)據(jù)可以是在某個(gè)外設(shè)的數(shù)據(jù)寄存器,可以在SRAM,可以在內(nèi)部FLASH。

因?yàn)閿?shù)據(jù)可以被Dcode總線,也可以被DMA總線訪問(wèn),為了避免訪問(wèn)沖突,在取數(shù)的時(shí)候需要經(jīng)過(guò)一個(gè)總線矩陣來(lái)仲裁,決定哪個(gè)總線在取數(shù)。

內(nèi)部的閃存存儲(chǔ)器Flash

內(nèi)部的閃存存儲(chǔ)器即FLASH,編寫好的程序就放在這個(gè)地方。內(nèi)核通過(guò)ICode總線來(lái)取里面的指令。

內(nèi)部的SRAM

內(nèi)部的SRAM,是通常所說(shuō)的內(nèi)存,程序中的變量、堆棧等的開銷都是基于內(nèi)部SRAM,內(nèi)核通過(guò)DCode總線來(lái)訪問(wèn)它。

FSMC

FSMC的英文全稱是Flexible static memory controller(靈活的靜態(tài)的存儲(chǔ)器控制器)。通過(guò)FSMC可以擴(kuò)展內(nèi)存,如外部的SRAM、NAND-FLASH和NORFLASH。但FSMC只能擴(kuò)展靜態(tài)的內(nèi)存,不能是動(dòng)態(tài)的內(nèi)存,比如就不能用來(lái)擴(kuò)展SDRAM。

AHB

從AHB總線延伸出來(lái)的兩條APB2和APB1總線是最常見(jiàn)的總線,GPIO、串口、I2C、SPI 這些外設(shè)就掛載在這兩條總線上。這個(gè)是學(xué)習(xí)STM32的重點(diǎn),要學(xué)會(huì)對(duì)這些外設(shè)編程,去驅(qū)動(dòng)外部的各種設(shè)備。

審核編輯:郭婷


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 芯片
    +關(guān)注

    關(guān)注

    463

    文章

    54010

    瀏覽量

    466146
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5608

    瀏覽量

    130001
  • 總線
    +關(guān)注

    關(guān)注

    10

    文章

    3040

    瀏覽量

    91666

原文標(biāo)題:梳理STM32芯片的內(nèi)部架構(gòu)

文章出處:【微信號(hào):玩點(diǎn)嵌入式,微信公眾號(hào):玩點(diǎn)嵌入式】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    如何從芯片內(nèi)部時(shí)鐘轉(zhuǎn)換到外部時(shí)鐘?

    怎么樣從芯片內(nèi)部時(shí)鐘轉(zhuǎn)換到外部時(shí)鐘?
    發(fā)表于 01-12 07:39

    電能質(zhì)量在線監(jiān)測(cè)裝置的核心芯片架構(gòu)對(duì)裝置性能有哪些影響?

    核心芯片架構(gòu)是電能質(zhì)量在線監(jiān)測(cè)裝置的 “算力中樞”,直接決定裝置的 測(cè)量精度、實(shí)時(shí)性、多參數(shù)處理能力、擴(kuò)展性和可靠性 。目前主流架構(gòu)分為三類: DSP+ARM 雙核異構(gòu)、專用計(jì)量芯片
    的頭像 發(fā)表于 12-17 15:21 ?448次閱讀
    電能質(zhì)量在線監(jiān)測(cè)裝置的核心<b class='flag-5'>芯片</b><b class='flag-5'>架構(gòu)</b>對(duì)裝置性能有哪些影響?

    看點(diǎn):全球首顆!中國(guó)研發(fā)全新架構(gòu)閃存芯片 OpenAI拉上巨頭豪賭AI基建

    給大家?guī)?lái)一些業(yè)界消息: 全球首顆!中國(guó)研發(fā)全新架構(gòu)閃存芯片 日前,復(fù)旦大學(xué)團(tuán)隊(duì)在《自然》發(fā)表成果,成功研制全球首顆二維—硅基混合架構(gòu)閃存芯片“長(zhǎng)纓(CY-01)”。相關(guān)成果率先實(shí)現(xiàn)全
    的頭像 發(fā)表于 10-10 18:20 ?1848次閱讀

    請(qǐng)問(wèn)STM32內(nèi)部Flash操作是不是優(yōu)先級(jí)最高?

    STM32內(nèi)部Flash操作是不是優(yōu)先級(jí)最高?目前在內(nèi)部Flash的單獨(dú)一頁(yè)存儲(chǔ)了數(shù)據(jù),發(fā)現(xiàn)在進(jìn)行頁(yè)擦除的時(shí)候正常工作的定時(shí)器中斷無(wú)法進(jìn)入了
    發(fā)表于 08-13 07:03

    請(qǐng)問(wèn)STM32N6 cubeAI部署時(shí)用的內(nèi)存是在內(nèi)部還是外部?

    STM32N6用cube AI部署模型的時(shí)候,用n6-allmems-O3之后analyse得到了RAM和FLASH的內(nèi)存占用,這里展示的內(nèi)存占用都是指的是芯片內(nèi)部的存儲(chǔ)器嗎
    發(fā)表于 06-09 06:19

    通過(guò)stm32控制AD9914遇到芯片問(wèn)題

    各位大佬,請(qǐng)教一個(gè)問(wèn)題,就是我使用了AD9914這個(gè)芯片,使用100M晶振提供時(shí)鐘信號(hào)。想經(jīng)過(guò)內(nèi)部的倍頻產(chǎn)生2.4的系統(tǒng)時(shí)鐘。芯片的供電沒(méi)有問(wèn)題3.3V和1.8V。但是引腳沒(méi)有短路的情況下。沒(méi)有
    發(fā)表于 06-04 11:08

    請(qǐng)問(wèn)STM32N6 cubeAI部署時(shí)用的內(nèi)存是在內(nèi)部還是外部?

    STM32N6用cube AI部署模型的時(shí)候,用n6-allmems-O3之后analyse得到了RAM和FLASH的內(nèi)存占用,這里展示的內(nèi)存占用都是指的是芯片內(nèi)部的存儲(chǔ)器嗎
    發(fā)表于 06-03 12:13

    stm32f103c8t6主控芯片無(wú)人機(jī)原理圖

    stm32f103c8t6主控芯片無(wú)人機(jī)原理圖
    發(fā)表于 04-29 17:02 ?3次下載

    邊緣AI應(yīng)用爆火!STM32N6芯片憑何領(lǐng)跑AI眼鏡和機(jī)器人賽道?

    STM32N6芯片就發(fā)揮了重要的作用。為此,記者特別專訪了意法半導(dǎo)體中國(guó)區(qū)微控制器、數(shù)字IC與射頻產(chǎn)品部市場(chǎng)經(jīng)理丁曉磊,請(qǐng)她分享了關(guān)于STM32N6芯片的性能和
    的頭像 發(fā)表于 04-29 13:52 ?5023次閱讀
    邊緣AI應(yīng)用爆火!<b class='flag-5'>STM32</b>N6<b class='flag-5'>芯片</b>憑何領(lǐng)跑AI眼鏡和機(jī)器人賽道?

    請(qǐng)問(wèn)STM32N6 cubeAI部署時(shí)用的內(nèi)存是在內(nèi)部還是外部?

    STM32N6用cube AI部署模型的時(shí)候,用n6-allmems-O3之后analyse得到了RAM和FLASH的內(nèi)存占用,這里展示的內(nèi)存占用都是指的是芯片內(nèi)部的存儲(chǔ)器嗎
    發(fā)表于 04-28 08:25

    STM32F030內(nèi)部晶振怎么設(shè)置,內(nèi)部晶振是延時(shí)函數(shù)怎么設(shè)置?

    STM32F030內(nèi)部晶振怎么設(shè)置,內(nèi)部晶振是延時(shí)函數(shù)怎么設(shè)置 使用STM32F030時(shí)沒(méi)使用內(nèi)部晶振怎么設(shè)置,使用
    發(fā)表于 04-23 07:45

    AD5764芯片內(nèi)部短路是正常的現(xiàn)象嗎?

    我在tb上買了一顆芯片,用萬(wàn)用表短路檢測(cè)發(fā)現(xiàn)5號(hào)引腳和3號(hào)引腳、5號(hào)引腳和21號(hào)引腳都是短路的。我焊接到板子后上電,電源啟動(dòng)了短路保護(hù),電壓上不去,我斷電后重新檢測(cè),發(fā)現(xiàn)GND和AVSS之間也短路了。我想問(wèn)一下老哥們,這款芯片內(nèi)部
    發(fā)表于 04-15 06:37

    電壓調(diào)節(jié)芯片SG3525內(nèi)部結(jié)構(gòu)及功能

    電子發(fā)燒友網(wǎng)站提供《電壓調(diào)節(jié)芯片SG3525內(nèi)部結(jié)構(gòu)及功能.pdf》資料免費(fèi)下載
    發(fā)表于 03-21 16:27 ?1次下載

    請(qǐng)問(wèn)STM32訪問(wèn)FPGA內(nèi)部SRAM部分區(qū)域?yàn)楹沃荒茏x不能寫?

    采用STM32F427+FPGA+Flash。 STM32通過(guò)FMC總線訪問(wèn)FPGA內(nèi)部SRAM,起始地址為0x60000000; Flash中存儲(chǔ)FPGA的配置數(shù)據(jù),STM32和FP
    發(fā)表于 03-12 07:59

    classB認(rèn)證獲取指南中的方案架構(gòu)看起來(lái)都是針對(duì)MCU的架構(gòu),MPU的沒(méi)辦法完全適配,怎么解決?

    classB認(rèn)證獲取指南中的方案架構(gòu)看起來(lái)都是針對(duì)MCU的架構(gòu),MPU的沒(méi)辦法完全適配。ST有針對(duì)MPU的自檢解決方案嗎?我用的是STM32MP157D
    發(fā)表于 03-12 07:34