在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

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

AT32講堂034 | AT32 MCU Cortex M4內(nèi)核入門指南

雅特力 AT32 MCU ? 2022-11-01 10:04 ? 次閱讀

AT32內(nèi)核架構(gòu)概述

AT32F4系列產(chǎn)品是基于Cortex-M4F處理器架構(gòu),該處理器是一款低功耗處理器,具有低門數(shù),低中斷延遲和低成本調(diào)試的特點。支持包括DSP指令集與浮點運算功能,特別適合用于深度嵌入式應(yīng)用程序需要快速中斷響應(yīng)功能。Cortex-M4F處理器是基于ARMv7-M架構(gòu),既支持Thumb指令集也支持DSP指令集。

下圖為Cortex-M4F處理器的內(nèi)部框圖,請參閱《ARMCortex-M4 技術(shù)參考手冊》了解關(guān)于Cortex-M4F更詳盡信息

圖1. AT32 Cortex-M4F內(nèi)部框圖c0cddd18-5753-11ed-b116-dac502259ad0.png

本文主要就M4內(nèi)核自帶的位帶、硬件浮點運算單元和滴答時鐘中斷功能進(jìn)行基礎(chǔ)講解。

案例 位帶操作

功能簡介

利用位帶操作,可以使用普通的加載/存儲操作來對單一比特進(jìn)行讀寫訪問。在Cortex-M4F中提供了兩個位帶區(qū):SRAM最低1M字節(jié)空間和外設(shè)區(qū)間的最低1M字節(jié)空間。這兩個區(qū)中的地址除了可以像普通存儲器一樣訪問外,還可以通過它們各自的位帶別名區(qū)來快捷訪問這兩個區(qū)中任意地址的任意比特位,位帶別名區(qū)將位帶區(qū)每個比特膨脹成一個32位的字。當(dāng)你訪問位帶別名區(qū)的一個地址時,等同于直接訪問位帶區(qū)的一個比特位。圖2.位帶區(qū)與位帶別名區(qū)的膨脹關(guān)系圖Ac0e639d0-5753-11ed-b116-dac502259ad0.png圖3. 位帶區(qū)與位帶別名區(qū)的膨脹關(guān)系圖Bc0f94e8a-5753-11ed-b116-dac502259ad0.png位帶區(qū):支持位帶操作的地址區(qū)位帶別名區(qū):對別名區(qū)地址的訪問最終作用到位帶區(qū)的訪問上在位帶區(qū)中,每個比特都映射到別名地址區(qū)的一個字(這是只有LSB有效的字)。當(dāng)一個位帶別名區(qū)地址被訪問時,會先把該地址變換成位帶區(qū)地址。對于讀操作,讀取位帶區(qū)地址中的一個字,再把需要的位右移到LSB,并把LSB返回。對于寫操作,把需要寫的位左移到對應(yīng)的位序號處,然后執(zhí)行一個比特級的“讀-改-寫”過程。

支持位帶操作的兩個內(nèi)存區(qū)的地址范圍為:

SRAM區(qū)中的最低1M字節(jié):0x2000_0000~0x200F_FFFF外設(shè)區(qū)間的最低1M字節(jié):0x4000_0000~0x400F_FFFF對于SRAM位帶區(qū)的某個比特,如果所在字節(jié)地址為A,位序號為n(0<=n<=7),則該比特在別名區(qū)的地址為:AliasAddr=0x2200_0000+(A-0x2000_0000)*32+n*4對于外設(shè)區(qū)間位帶區(qū)的某個比特,如果所在字節(jié)地址為A,位序號為n(0<=n<=7),則該比特在別名區(qū)的地址為:AliasAddr=0x4200_0000+(A-0x4000_0000)*32+n*4對于SRAM區(qū)中,位帶區(qū)與位帶別名區(qū)的映射如下表所示:表1. SRAM區(qū)中的位帶地址映射c12abf88-5753-11ed-b116-dac502259ad0.png對于外設(shè)區(qū)中,位帶區(qū)與位帶別名區(qū)的映射如下表所示:表2. 外設(shè)區(qū)中的位帶地址映射c1362120-5753-11ed-b116-dac502259ad0.png

位帶操作的優(yōu)越性最容易想到的是通過GPIO的管腳來單獨控制每盞LED的點亮與熄滅。另一方面,也對操作串行接口提供很大的方便。總之,位帶操作對于硬件I/O密集型的底層程序最有用處。位帶操作還能簡化跳轉(zhuǎn)的判斷。當(dāng)跳轉(zhuǎn)依據(jù)是某個位時,以前必須這樣做:

讀取整個寄存器屏蔽不需要的位比較并跳轉(zhuǎn)現(xiàn)在只需要:從位帶別名區(qū)讀取該位的狀態(tài)比較并跳轉(zhuǎn)使代碼更簡潔,這只是位帶操作優(yōu)越性的初步體現(xiàn),位帶操作還有一個重要的好處是在多任務(wù)以及多任務(wù)環(huán)境中,將以前的讀-改-寫需要的三條指令,做成了一個硬件級別支持的原子操作,消除了以前讀-改-寫可能被中斷,導(dǎo)致出現(xiàn)紊亂的情況。

注意事項

1) 因各系列的外設(shè)IP地址排布的不同,AT32F421xx與AT32F425xx系列的GPIO外設(shè)基地址不在位帶映射地址范圍內(nèi)。

資源準(zhǔn)備

1) 硬件環(huán)境對應(yīng)產(chǎn)品型號的AT-START BOARD2) 軟件環(huán)境project\at_start_f4xx\examples\cortex_m4\bit_band

軟件設(shè)計

1) 配置流程SRAM位帶操作

  • 定義全局變量variables=0xA5A5A5A5,
  • 對variables bit0的位帶地址寫0
  • 檢查variables是否修改為0xA5A5A5A4,如果是則表示操作成功
  • 對variables bit0的位帶地址寫1
  • 檢查variables是否修改為0xA5A5A5A5,如果是則表示操作成功
  • 對variables bit16的位帶地址寫0
  • 檢查variables是否修改為0xA5A4A5A5,如果是則表示操作成功
  • 對variables bit16的位帶地址寫1
  • 檢查variables是否修改為0xA5A5A5A5,如果是則表示操作成功
  • 對variables bit31的位帶地址寫0
  • 檢查variables是否修改為0x25A5A5A5,如果是則表示操作成功
  • 對variables bit31的位帶地址寫1
  • 檢查variables是否修改為0xA5A5A5A5,如果是則表示操作成功

外設(shè)位帶操作

  • 對LED2對應(yīng)GPIO ODT寄存器bit位的位帶地址寫0
  • 對LED2對應(yīng)GPIO ODT寄存器bit位的位帶地址寫1
  • 循環(huán)執(zhí)行上述操作,實現(xiàn)LED toggle功能

2) 代碼介紹

main函數(shù)代碼描述c1479fa4-5753-11ed-b116-dac502259ad0.png宏定義內(nèi)容描述c1745972-5753-11ed-b116-dac502259ad0.png

實驗結(jié)果

  • SRAM位帶操作:如果不滿足預(yù)期,LED4翻轉(zhuǎn)。
  • 外設(shè)位帶操作:如果滿足預(yù)期,LED2翻轉(zhuǎn)。

案例 硬件浮點運算單元

功能簡介

FPU即浮點運算單元(Float Point Unit)。浮點運算,對于定點CPU(沒有FPU的CPU)來說必須要按照IEEE-754標(biāo)準(zhǔn)的算法來完成運算,是相當(dāng)耗費時間的。而對于有FPU的CPU來說,浮點運算則只是幾條指令的事情,速度相當(dāng)快。

AT32F4屬于Cortex M4F架構(gòu),帶有32位單精度硬件FPU,支持浮點指令集,相對于Cortex M0和Cortex M3等,高出數(shù)十倍甚至上百倍的運算性能

注意事項

1) 由各系列應(yīng)用方向及成本的綜合考慮,AT32F415xx、AT32F421xx和AT32F425xx系列不支持硬件浮點運算單元。

資源準(zhǔn)備

1) 硬件環(huán)境對應(yīng)產(chǎn)品型號的AT-START BOARD

2) 軟件環(huán)境

project\at_start_f4xx\examples\cortex_m4\fpu

軟件設(shè)計

1) 配置流程FPU功能的開啟必須要編譯器和代碼都開啟才可以。若只開啟編譯器FPU,程序會進(jìn)入hardfault;若只開啟代碼中FPU,編譯器不會編譯出FPU的代碼指令。

編譯器上開啟FPU功能

IAR開啟FPU方式如下圖圖4. IAR開啟FPU方式c1da76ee-5753-11ed-b116-dac502259ad0.pngMDK開啟FPU方式如下圖圖5. MDK開啟FPU方式c20a5fee-5753-11ed-b116-dac502259ad0.png

  • 代碼中開啟FPU功能

在system_at32f4xx.c文件中void SystemInit (void)函數(shù)確保有如下粗斜體代碼c26b4bba-5753-11ed-b116-dac502259ad0.png

執(zhí)行Julia算法函數(shù)

比較開啟和不開啟 FPU 功能的 Julia 運算速度。2) 代碼介紹main函數(shù)代碼描述c2a6af16-5753-11ed-b116-dac502259ad0.png

實驗結(jié)果

  • 編譯器上開啟FPU功能,觀察LED4翻轉(zhuǎn)速度
  • 編譯器上關(guān)閉FPU功能,觀察LED4翻轉(zhuǎn)速度
  • 對比以上兩種情形LED4翻轉(zhuǎn)速度區(qū)別

案例 系統(tǒng)滴答時鐘中斷

功能簡介

系統(tǒng)嘀嗒定時器是一個24位遞減計數(shù)器,遞減至零可自動重載計數(shù)初值。可產(chǎn)生周期性異常,用作嵌入式操作系統(tǒng)的多任務(wù)調(diào)度計數(shù)器,或?qū)τ跓o嵌入式操作系統(tǒng),可用于調(diào)用需周期性執(zhí)行的任務(wù)。系統(tǒng)嘀嗒定時器校準(zhǔn)值固定值9000,當(dāng)系統(tǒng)嘀嗒時鐘設(shè)定為9MHz,產(chǎn)生1ms時間基準(zhǔn)。

資源準(zhǔn)備

1) 硬件環(huán)境對應(yīng)產(chǎn)品型號的AT-START BOARD

2) 軟件環(huán)境

project\at_start_f4xx\examples\cortex_m4\systick_interrupt

軟件設(shè)計

1) 配置流程

  • 配置systick時鐘源
  • 配置systick重載值并開啟systick中斷
  • 在void SysTick_Handler(void)函數(shù)中添加應(yīng)用代碼

2) 代碼介紹

main函數(shù)代碼描述c2f55c7e-5753-11ed-b116-dac502259ad0.png

實驗結(jié)果

本應(yīng)配置的是1 ms systick中斷,每進(jìn)200次systick中斷LED2翻轉(zhuǎn)一次,因此應(yīng)該觀察到的現(xiàn)象是LED2以200ms一次的頻率進(jìn)行翻轉(zhuǎn)。關(guān)于雅特力雅特力科技于2016年成立,是一家致力于推動全球市場32位微控制器(MCU)創(chuàng)新趨勢的芯片設(shè)計公司,專注于ARM Cortex-M4/M0+的32位微控制器研發(fā)與創(chuàng)新,全系列采用55nm先進(jìn)工藝及ARM Cortex-M4高效能或M0+低功耗內(nèi)核,締造M4業(yè)界最高主頻288MHz運算效能,并支持工業(yè)級別芯片工作溫度范圍(-40°~105°)。雅特力目前已累積相當(dāng)多元的終端產(chǎn)品成功案例:如微型打印機、掃地機、光流無人機、熱成像儀、激光雷達(dá)、工業(yè)縫紉機、伺服驅(qū)控、電競周邊市場、斷路器、ADAS、T-BOX、數(shù)字電源、電動工具等終端設(shè)備應(yīng)用,廣泛地覆蓋5G物聯(lián)網(wǎng)、消費、商務(wù)及工控等領(lǐng)域。

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

    關(guān)注

    146

    文章

    17338

    瀏覽量

    352701
收藏 人收藏

    評論

    相關(guān)推薦

    PGAxxxEVM-034用戶指南

    電子發(fā)燒友網(wǎng)站提供《PGAxxxEVM-034用戶指南.pdf》資料免費下載
    發(fā)表于 12-07 15:10 ?1次下載
    PGAxxxEVM-<b class='flag-5'>034</b>用戶<b class='flag-5'>指南</b>

    MAX32675C超低功耗Arm? Cortex?-M4F MCU

    MCU基于帶浮點單元(FPU)的超低功耗Arm Cortex- M4,包括384KB(376KB用戶)閃存和160KBSRAM。在整個閃存、SRAM和緩存上實現(xiàn)糾錯編碼(ECC),能夠?qū)崿F(xiàn)單錯校正和雙錯
    的頭像 發(fā)表于 11-28 11:50 ?499次閱讀
    MAX32675C超低功耗Arm? <b class='flag-5'>Cortex</b>?-<b class='flag-5'>M4</b>F <b class='flag-5'>MCU</b>

    實際項目開發(fā)中為何選擇ARM? Cortex?-M4 內(nèi)核的HK32MCU

    ?Cortex?-M4內(nèi)核的HK32F407芯片的深度知識,并圍繞各類實際案例詳細(xì)解讀了如何選型,為何選擇ARM?Cortex?-M4
    的頭像 發(fā)表于 10-22 17:19 ?489次閱讀
    實際項目開發(fā)中為何選擇ARM? <b class='flag-5'>Cortex</b>?-<b class='flag-5'>M4</b> <b class='flag-5'>內(nèi)核</b>的HK32<b class='flag-5'>MCU</b>?

    STM32轉(zhuǎn)AT32代碼轉(zhuǎn)換

    1.引言在嵌入式開發(fā)中,我們經(jīng)常會遇到更換單片機芯片的事情,若芯片是同一廠家的還好說,若是不同廠家的則需要重新寫,重新調(diào),重新去學(xué)習(xí)其底層驅(qū)動程序,比較費時費力。如:ST32轉(zhuǎn)AT32、ST32轉(zhuǎn)
    的頭像 發(fā)表于 09-28 08:09 ?387次閱讀
    STM32轉(zhuǎn)<b class='flag-5'>AT32</b>代碼轉(zhuǎn)換

    AT32講堂087 | 雅特力AT32 IDE快速入門指南

    新建項目新項目向?qū)T32ID提供支持雅特力MCU的C語言項目模板,方便用戶快速創(chuàng)建項目。菜單欄【File】>【New】>【CProject】。新建項目向?qū)У膶υ捒驅(qū)⒊霈F(xiàn)。在對
    的頭像 發(fā)表于 09-15 08:08 ?563次閱讀
    <b class='flag-5'>AT32</b><b class='flag-5'>講堂</b>087 | 雅特力<b class='flag-5'>AT32</b> IDE快速<b class='flag-5'>入門</b><b class='flag-5'>指南</b>

    雅特力AT32 MCU的隨機數(shù)生成

    概述產(chǎn)品和生態(tài)系統(tǒng)安全性的需求比以往任何時候都更加重要。真隨機數(shù)是所有安全系統(tǒng)的核心,其質(zhì)量會影響設(shè)計的安全性。因此在沒有內(nèi)置硬件TRNG的AT32的微控制器系列中,如何提高隨機數(shù)的有效,來符合
    的頭像 發(fā)表于 08-30 12:26 ?714次閱讀
    雅特力<b class='flag-5'>AT32</b> <b class='flag-5'>MCU</b>的隨機數(shù)生成

    AT32講堂085 | 雅特力AT32 MCU HICK時鐘校準(zhǔn)

    簡介AT32系列MCU內(nèi)部都有提供適合運行的內(nèi)部高速時鐘(HICK),其本質(zhì)就是內(nèi)置于芯片的RC振蕩器。在25℃下,其典型值頻率8MHz的精度由工廠校準(zhǔn)到±1%,在-40到105℃,該內(nèi)部高速時鐘
    的頭像 發(fā)表于 08-30 12:26 ?838次閱讀
    <b class='flag-5'>AT32</b><b class='flag-5'>講堂</b>085 | 雅特力<b class='flag-5'>AT32</b> <b class='flag-5'>MCU</b> HICK時鐘校準(zhǔn)

    揭幕M4內(nèi)核MCU,航順新品發(fā)布會有哪些看點?

    在物聯(lián)網(wǎng)、智能家居和工業(yè)自動化等領(lǐng)域的快速發(fā)展下,航順芯片將在7月26日的新品發(fā)布會上推出一款搭載M4內(nèi)核的高性能MCU以及指紋傳感器專用芯片。 對于MCU廠商來說,物聯(lián)網(wǎng)、智能家居、
    的頭像 發(fā)表于 07-25 09:50 ?388次閱讀

    請問stm32L4是不是M4內(nèi)核

    為什么L4在ucos 庫里是屬于 M3內(nèi)核,F(xiàn)4系列 在ucos庫里是屬于 M4內(nèi)核
    發(fā)表于 04-17 07:07

    東芝推出一種適用于電機控制的Arm? Cortex?-M4微控制器

    東芝電子元件及存儲裝置株式會社(“東芝”)今日宣布,采用Cortex?-M4內(nèi)核并搭載FPU的TXZ+?族高級系列32位微控制器的M4K組新增8款新產(chǎn)品,閃存容量達(dá)512 KB/1 M
    的頭像 發(fā)表于 03-27 10:07 ?822次閱讀
    東芝推出一種適用于電機控制的Arm? <b class='flag-5'>Cortex</b>?-<b class='flag-5'>M4</b>微控制器

    兆易創(chuàng)新推出GD32F5系列Cortex-M33內(nèi)核MCU

    兆易創(chuàng)新GigaDevice宣布,正式推出GD32F5系列高性能微控制器,該系列MCU基于Arm? Cortex?-M33內(nèi)核,旨在滿足各類高要求應(yīng)用場景的需求。
    的頭像 發(fā)表于 03-16 09:58 ?1329次閱讀

    Cortex-M85內(nèi)核單片機如何快速上手

    2022年4月,Arm推出了全新的MCU內(nèi)核Cortex-M85。截止目前(2024年2月),Cortex-M85是最新、最強的
    發(fā)表于 02-29 09:35 ?810次閱讀
    <b class='flag-5'>Cortex-M</b>85<b class='flag-5'>內(nèi)核</b>單片機如何快速上手

    雅特力AT32 MCU與SEGGER攜手合作,開發(fā)量產(chǎn)事半功倍

    銷售以來,基于32位ARM?-Cortex?-M4內(nèi)核,推出超值型、主流型、高效能、無線型及車載型系列MCU,并即將發(fā)表M0+低功耗系列及馬
    的頭像 發(fā)表于 02-23 10:27 ?464次閱讀

    雅特力AT32 MCU與SEGGER攜手合作,開發(fā)量產(chǎn)事半功倍

    ,基于32位ARM-Cortex-M4內(nèi)核,推出超值型、主流型、高效能、無線型及車載型系列MCU,并即將發(fā)表M0+低功耗系列及馬達(dá)專用MCU
    的頭像 發(fā)表于 02-22 08:13 ?539次閱讀
    雅特力<b class='flag-5'>AT32</b> <b class='flag-5'>MCU</b>與SEGGER攜手合作,開發(fā)量產(chǎn)事半功倍

    使用pSoC6247雙核MCU使用IPC方式M0和M4進(jìn)行數(shù)據(jù)傳遞,ipc雙向數(shù)據(jù)死機的原因?怎么解決?

    我在使用pSoC6247雙核MCU使用IPC方式M0和M4進(jìn)行數(shù)據(jù)傳遞。 我發(fā)現(xiàn)如果兩個核同時傳遞數(shù)據(jù),如果雙向都很頻繁的時候,有概率丟數(shù)據(jù),還有概率引起看門狗復(fù)位。 如果改成單項傳輸就不會
    發(fā)表于 02-21 07:27
    主站蜘蛛池模板: h版欧美一区二区三区四区 h网站亚洲 | 午夜操 | 狠狠色成色综合网 | 色综合综合网 | 黄 色 片 在 线 看 | 天天摸天天爽天天澡视频 | 狠狠色丁香婷婷综合欧美 | 免费的男女拍拍拍的视频 | 国产精品天天干 | 日韩亚洲人成在线综合日本 | 亚洲视频一区在线观看 | 黄色视屏免费在线观看 | 99午夜高清在线视频在观看 | 天天爱天天干天天 | 日韩午夜r电影在线观看 | 欧美成人天天综合在线视色 | 黄网站视频在线观看 | 天天碰视频 | 久久国内| 亚洲国产精品乱码在线观看97 | 深夜在线视频免费网址 | 亚洲欧美视频一区二区 | 久久精品亚瑟全部免费观看 | 夜夜狠狠 | 伊人成人在线 | 亚洲视频在线播放 | 成人5252色 | 欧美成人全部免费观看1314色 | 三级视频网 | 手机福利在线观看 | 日本不卡一 | 播放个毛片看看 | 色黄视频| 久久精品国产精品亚洲毛片 | 黄色软件入口 | 日韩有色| 特黄特黄一级高清免费大片 | 九九涩 | 综合色爱 | 成人国产在线视频 | 777色狠狠一区二区三区香蕉 |