日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

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

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(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)試的特點(diǎn)。支持包括DSP指令集與浮點(diǎn)運(yùn)算功能,特別適合用于深度嵌入式應(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)核自帶的位帶、硬件浮點(diǎn)運(yùn)算單元和滴答時(shí)鐘中斷功能進(jìn)行基礎(chǔ)講解。

案例 位帶操作

功能簡介

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

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

SRAM區(qū)中的最低1M字節(jié):0x2000_0000~0x200F_FFFF外設(shè)區(qū)間的最低1M字節(jié):0x4000_0000~0x400F_FFFF對于SRAM位帶區(qū)的某個(gè)比特,如果所在字節(jié)地址為A,位序號(hào)為n(0<=n<=7),則該比特在別名區(qū)的地址為:AliasAddr=0x2200_0000+(A-0x2000_0000)*32+n*4對于外設(shè)區(qū)間位帶區(qū)的某個(gè)比特,如果所在字節(jié)地址為A,位序號(hào)為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的管腳來單獨(dú)控制每盞LED的點(diǎn)亮與熄滅。另一方面,也對操作串行接口提供很大的方便。總之,位帶操作對于硬件I/O密集型的底層程序最有用處。位帶操作還能簡化跳轉(zhuǎn)的判斷。當(dāng)跳轉(zhuǎn)依據(jù)是某個(gè)位時(shí),以前必須這樣做:

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

注意事項(xiàng)

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

資源準(zhǔn)備

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

軟件設(shè)計(jì)

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í)行上述操作,實(shí)現(xiàn)LED toggle功能

2) 代碼介紹

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

實(shí)驗(yàn)結(jié)果

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

案例 硬件浮點(diǎn)運(yùn)算單元

功能簡介

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

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

注意事項(xiàng)

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

資源準(zhǔn)備

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

2) 軟件環(huán)境

project\at_start_f4xx\examples\cortex_m4\fpu

軟件設(shè)計(jì)

1) 配置流程FPU功能的開啟必須要編譯器和代碼都開啟才可以。若只開啟編譯器FPU,程序會(huì)進(jìn)入hardfault;若只開啟代碼中FPU,編譯器不會(huì)編譯出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 運(yùn)算速度。2) 代碼介紹main函數(shù)代碼描述c2a6af16-5753-11ed-b116-dac502259ad0.png

實(shí)驗(yàn)結(jié)果

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

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

功能簡介

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

資源準(zhǔn)備

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

2) 軟件環(huán)境

project\at_start_f4xx\examples\cortex_m4\systick_interrupt

軟件設(shè)計(jì)

1) 配置流程

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

2) 代碼介紹

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

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

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

    關(guān)注

    147

    文章

    19160

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

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

    探索LPC5410x:32位ARM Cortex - M4/M0+微控制器的卓越性能

    探索LPC5410x:32位ARM Cortex - M4/M0+微控制器的卓越性能 在嵌入式系統(tǒng)的設(shè)計(jì)領(lǐng)域,選擇一款合適的微控制器是至關(guān)重要的。NXP的LPC5410x系列32位ARM
    的頭像 發(fā)表于 04-27 17:25 ?412次閱讀

    AT32 Work Bench介紹和使用指南

    本帖最后由 jf_77210199 于 2026-4-21 20:01 編輯 本帖介紹 AT32 Work Bench 使用。AT32 Work Bench 通過對 MCU 的圖
    發(fā)表于 04-14 18:07

    深入解析NXP LPC408x/7x:32位ARM Cortex - M4 MCU的卓越之選

    深入解析NXP LPC408x/7x:32位ARM Cortex - M4 MCU的卓越之選 在嵌入式系統(tǒng)設(shè)計(jì)領(lǐng)域,選擇一款性能卓越、功能豐富的微控制器(MCU)至關(guān)重要。NXP的LP
    的頭像 發(fā)表于 04-09 09:45 ?140次閱讀

    深入解析LPC408x/7x 32位ARM Cortex - M4微控制器

    的數(shù)字信號(hào)控制器,專為需要高度集成和低功耗的嵌入式應(yīng)用而設(shè)計(jì)。ARM Cortex - M4內(nèi)核具有低功耗、增強(qiáng)的調(diào)試功能和高度集成的支持模塊等特點(diǎn)。它采用3級流水線,
    的頭像 發(fā)表于 04-09 09:35 ?255次閱讀

    MAX32570:用于安全應(yīng)用的低功耗ARM Cortex - M4微控制器

    MAX32570:用于安全應(yīng)用的低功耗ARM Cortex - M4微控制器 在電子設(shè)計(jì)領(lǐng)域,安全和低功耗一直是工程師們關(guān)注的重點(diǎn)。今天要為大家介紹的是Analog Devices的MAX32570
    的頭像 發(fā)表于 03-26 16:50 ?327次閱讀

    LPC43S50/S30/S20:32 位 ARM Cortex - M4/M0 微控制器的深度剖析

    LPC43S50/S30/S20:32 位 ARM Cortex - M4/M0 微控制器的深度剖析 在嵌入式系統(tǒng)設(shè)計(jì)領(lǐng)域,選擇一款合適的微控制器至關(guān)重要。NXP 推出的 LPC43S50/S30
    的頭像 發(fā)表于 03-15 17:10 ?1097次閱讀

    AT32硬件除法器應(yīng)用指南

    AT32硬件除法器應(yīng)用指南 AT32F011 提供了 32 位硬件除法器,并且可以執(zhí)行無符號(hào)及有符號(hào)運(yùn)算,本應(yīng)用指南將介紹基礎(chǔ)概念及實(shí)際案例。 支持型號(hào): AT32F011 系列 1. AT
    發(fā)表于 01-30 13:49

    森國科SGK32G034 MCU產(chǎn)品在掃地機(jī)無刷電機(jī)的應(yīng)用方案

    森國科發(fā)布SGK32電機(jī)專用MCU以來,一直深受電驅(qū)工程師、應(yīng)用工程師、算法工程師的喜愛,近期我們推出了可用于掃地機(jī)掃地機(jī)器人無刷電機(jī)的應(yīng)用方案,方案使用了基于 ARM Cortex M0 內(nèi)
    的頭像 發(fā)表于 01-29 11:34 ?2810次閱讀
    森國科SGK32G<b class='flag-5'>034</b> <b class='flag-5'>MCU</b>產(chǎn)品在掃地機(jī)無刷電機(jī)的應(yīng)用方案

    國產(chǎn)MCU替代優(yōu)選!雅特力AT32系列憑高性能+高兼容,橫掃工控/消費(fèi)/AIoT多場景

    在國產(chǎn)化替代加速背景下,雅特力AT32系列MCU成工程師優(yōu)選。該系列基于ARM Cortex-M4/M0+內(nèi)核,具備高主頻、豐富外設(shè)及工業(yè)級
    的頭像 發(fā)表于 01-07 17:15 ?2040次閱讀

    雅特力AT32 MCU推動(dòng)低空經(jīng)濟(jì)發(fā)展

    雅特力AT32系列MCU憑借288MHz主頻與高精度外設(shè),為無人機(jī)飛控、電調(diào)及云臺(tái)提供核心算力支持,實(shí)現(xiàn)厘米級定位與高效動(dòng)力控制,顯著提升在電力巡檢、農(nóng)林植保等低空經(jīng)濟(jì)場景下的作業(yè)精度與可靠性,助力產(chǎn)業(yè)智能化升級。
    的頭像 發(fā)表于 12-04 09:53 ?1925次閱讀
    雅特力<b class='flag-5'>AT32</b> <b class='flag-5'>MCU</b>推動(dòng)低空經(jīng)濟(jì)發(fā)展

    請問NuMicro? Cortex-M0/M4系列可以提供哪些USB器件示例代碼?

    NuMicro? Cortex-M0/M4系列可以提供哪些USB器件示例代碼?
    發(fā)表于 08-19 07:05

    AT32 MCU如何使用IAP

    AT32 MCU使用IAP的方法涉及在微控制器上創(chuàng)建特定固件,以實(shí)現(xiàn)在應(yīng)用編程(In-Application Programming,簡稱IAP)功能,主要通過USART通信接口進(jìn)行固件更新操作
    發(fā)表于 08-08 17:13

    AT32 IAP using the USART

    對于AT32 MCU,除了出廠固化的bootloader,用戶也可以在應(yīng)用程序中編寫自己的bootloader程序,用于最終產(chǎn)品的固件更新。此功能稱為應(yīng)用程序內(nèi)編程(IAP)。 本應(yīng)用筆記的目的
    發(fā)表于 07-11 10:51

    使用STM32CubeIDE調(diào)試STM32MP157D的M4內(nèi)核時(shí)報(bào)了下圖這個(gè)錯(cuò)誤,怎么解決?

    我使用STM32CubeIDE調(diào)試STM32MP157D的M4內(nèi)核時(shí)報(bào)了下圖這個(gè)錯(cuò)誤: 經(jīng)過我的排除后發(fā)現(xiàn),應(yīng)該是STM32CubeIDE上傳&quot
    發(fā)表于 06-18 06:57

    Analog Devices Inc. MAX32675C超低功耗Arm? Cortex?-M4F MCU數(shù)據(jù)手冊

    MCU基于帶浮點(diǎn)單元(FPU)的超低功耗Arm Cortex- M4,包括384KB(376KB用戶)閃存和160KB SRAM。在整個(gè)閃存、SRAM和緩存上實(shí)現(xiàn)糾錯(cuò)編碼(ECC),能夠?qū)崿F(xiàn)單錯(cuò)校正和雙錯(cuò)檢測(SEC-DED),
    的頭像 發(fā)表于 06-03 10:04 ?1282次閱讀
    Analog Devices Inc. MAX32675C超低功耗Arm? <b class='flag-5'>Cortex</b>?-<b class='flag-5'>M4</b>F <b class='flag-5'>MCU</b>數(shù)據(jù)手冊
    金昌市| 阿拉善盟| 宁武县| 三明市| 右玉县| 汕头市| 阿图什市| 定南县| 卓资县| 武胜县| 九寨沟县| 眉山市| 安陆市| 论坛| 石渠县| 定州市| 烟台市| 丘北县| 富顺县| 霸州市| 宜兴市| 左权县| 永平县| 凉城县| 隆化县| 乐平市| 沂源县| 福建省| 共和县| 彰化县| 当阳市| 新化县| 资中县| 武城县| 萨嘎县| 石楼县| 普安县| 阿尔山市| 元阳县| 双城市| 巧家县|