0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看威廉希尔官方网站 视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

AT32讲堂034 | AT32 MCU Cortex M4内核入门指南

雅特力 AT32 MCU 2022-11-01 10:04 次阅读

AT32内核架构概述

AT32F4系列产品是基于Cortex-M4F处理器架构,该处理器是一款低功耗处理器,具有低门数,低中断延迟和低成本调试的特点。支持包括DSP指令集与浮点运算功能,特别适合用于深度嵌入式应用程序需要快速中断响应功能。Cortex-M4F处理器是基于ARMv7-M架构,既支持Thumb指令集也支持DSP指令集。

下图为Cortex-M4F处理器的内部框图,请参阅《ARMCortex-M4 威廉希尔官方网站 参考手册》了解关于Cortex-M4F更详尽信息

图1. AT32 Cortex-M4F内部框图c0cddd18-5753-11ed-b116-dac502259ad0.png

本文主要就M4内核自带的位带、硬件浮点运算单元和滴答时钟中断功能进行基础讲解。

案例 位带操作

功能简介

利用位带操作,可以使用普通的加载/存储操作来对单一比特进行读写访问。在Cortex-M4F中提供了两个位带区:SRAM最低1M字节空间和外设区间的最低1M字节空间。这两个区中的地址除了可以像普通存储器一样访问外,还可以通过它们各自的位带别名区来快捷访问这两个区中任意地址的任意比特位,位带别名区将位带区每个比特膨胀成一个32位的字。当你访问位带别名区的一个地址时,等同于直接访问位带区的一个比特位。图2.位带区与位带别名区的膨胀关系图Ac0e639d0-5753-11ed-b116-dac502259ad0.png图3. 位带区与位带别名区的膨胀关系图Bc0f94e8a-5753-11ed-b116-dac502259ad0.png位带区:支持位带操作的地址区位带别名区:对别名区地址的访问最终作用到位带区的访问上在位带区中,每个比特都映射到别名地址区的一个字(这是只有LSB有效的字)。当一个位带别名区地址被访问时,会先把该地址变换成位带区地址。对于读操作,读取位带区地址中的一个字,再把需要的位右移到LSB,并把LSB返回。对于写操作,把需要写的位左移到对应的位序号处,然后执行一个比特级的“读-改-写”过程。

支持位带操作的两个内存区的地址范围为:

SRAM区中的最低1M字节:0x2000_0000~0x200F_FFFF外设区间的最低1M字节:0x4000_0000~0x400F_FFFF对于SRAM位带区的某个比特,如果所在字节地址为A,位序号为n(0<=n<=7),则该比特在别名区的地址为:AliasAddr=0x2200_0000+(A-0x2000_0000)*32+n*4对于外设区间位带区的某个比特,如果所在字节地址为A,位序号为n(0<=n<=7),则该比特在别名区的地址为:AliasAddr=0x4200_0000+(A-0x4000_0000)*32+n*4对于SRAM区中,位带区与位带别名区的映射如下表所示:表1. SRAM区中的位带地址映射c12abf88-5753-11ed-b116-dac502259ad0.png对于外设区中,位带区与位带别名区的映射如下表所示:表2. 外设区中的位带地址映射c1362120-5753-11ed-b116-dac502259ad0.png

位带操作的优越性最容易想到的是通过GPIO的管脚来单独控制每盏LED的点亮与熄灭。另一方面,也对操作串行接口提供很大的方便。总之,位带操作对于硬件I/O密集型的底层程序最有用处。位带操作还能简化跳转的判断。当跳转依据是某个位时,以前必须这样做:

读取整个寄存器屏蔽不需要的位比较并跳转现在只需要:从位带别名区读取该位的状态比较并跳转使代码更简洁,这只是位带操作优越性的初步体现,位带操作还有一个重要的好处是在多任务以及多任务环境中,将以前的读-改-写需要的三条指令,做成了一个硬件级别支持的原子操作,消除了以前读-改-写可能被中断,导致出现紊乱的情况。

注意事项

1) 因各系列的外设IP地址排布的不同,AT32F421xx与AT32F425xx系列的GPIO外设基地址不在位带映射地址范围内。

资源准备

1) 硬件环境对应产品型号的AT-START BOARD2) 软件环境project\at_start_f4xx\examples\cortex_m4\bit_band

软件设计

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,如果是则表示操作成功

外设位带操作

  • 对LED2对应GPIO ODT寄存器bit位的位带地址写0
  • 对LED2对应GPIO ODT寄存器bit位的位带地址写1
  • 循环执行上述操作,实现LED toggle功能

2) 代码介绍

main函数代码描述c1479fa4-5753-11ed-b116-dac502259ad0.png宏定义内容描述c1745972-5753-11ed-b116-dac502259ad0.png

实验结果

  • SRAM位带操作:如果不满足预期,LED4翻转。
  • 外设位带操作:如果满足预期,LED2翻转。

案例 硬件浮点运算单元

功能简介

FPU即浮点运算单元(Float Point Unit)。浮点运算,对于定点CPU(没有FPU的CPU)来说必须要按照IEEE-754标准的算法来完成运算,是相当耗费时间的。而对于有FPU的CPU来说,浮点运算则只是几条指令的事情,速度相当快。

AT32F4属于Cortex M4F架构,带有32位单精度硬件FPU,支持浮点指令集,相对于Cortex M0和Cortex M3等,高出数十倍甚至上百倍的运算性能

注意事项

1) 由各系列应用方向及成本的综合考虑,AT32F415xx、AT32F421xx和AT32F425xx系列不支持硬件浮点运算单元。

资源准备

1) 硬件环境对应产品型号的AT-START BOARD

2) 软件环境

project\at_start_f4xx\examples\cortex_m4\fpu

软件设计

1) 配置流程FPU功能的开启必须要编译器和代码都开启才可以。若只开启编译器FPU,程序会进入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)函数确保有如下粗斜体代码c26b4bba-5753-11ed-b116-dac502259ad0.png

执行Julia算法函数

比较开启和不开启 FPU 功能的 Julia 运算速度。2) 代码介绍main函数代码描述c2a6af16-5753-11ed-b116-dac502259ad0.png

实验结果

  • 编译器上开启FPU功能,观察LED4翻转速度
  • 编译器上关闭FPU功能,观察LED4翻转速度
  • 对比以上两种情形LED4翻转速度区别

案例 系统滴答时钟中断

功能简介

系统嘀嗒定时器是一个24位递减计数器,递减至零可自动重载计数初值。可产生周期性异常,用作嵌入式操作系统的多任务调度计数器,或对于无嵌入式操作系统,可用于调用需周期性执行的任务。系统嘀嗒定时器校准值固定值9000,当系统嘀嗒时钟设定为9MHz,产生1ms时间基准。

资源准备

1) 硬件环境对应产品型号的AT-START BOARD

2) 软件环境

project\at_start_f4xx\examples\cortex_m4\systick_interrupt

软件设计

1) 配置流程

  • 配置systick时钟源
  • 配置systick重载值并开启systick中断
  • 在void SysTick_Handler(void)函数中添加应用代码

2) 代码介绍

main函数代码描述c2f55c7e-5753-11ed-b116-dac502259ad0.png

实验结果

本应配置的是1 ms systick中断,每进200次systick中断LED2翻转一次,因此应该观察到的现象是LED2以200ms一次的频率进行翻转。关于雅特力雅特力科技于2016年成立,是一家致力于推动全球市场32位微控制器(MCU)创新趋势的芯片设计公司,专注于ARM Cortex-M4/M0+的32位微控制器研发与创新,全系列采用55nm先进工艺及ARM Cortex-M4高效能或M0+低功耗内核,缔造M4业界最高主频288MHz运算效能,并支持工业级别芯片工作温度范围(-40°~105°)。雅特力目前已累积相当多元的终端产品成功案例:如微型打印机、扫地机、光流无人机、热成像仪、激光雷达、工业缝纫机、伺服驱控、电竞周边市场、断路器、ADAS、T-BOX、数字电源、电动工具等终端设备应用,广泛地覆盖5G物联网、消费、商务及工控等领域。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • mcu
    mcu
    +关注

    关注

    146

    文章

    17172

    浏览量

    351550
收藏 人收藏

    评论

    相关推荐

    实际项目开发中为何选择ARM® Cortex®-M4 内核的HK32MCU

    ®Cortex®-M4内核的HK32F407芯片的深度知识,并围绕各类实际案例详细解读了如何选型,为何选择ARM®Cortex®-M4
    的头像 发表于 10-22 17:19 437次阅读
    实际项目开发中为何选择ARM® <b class='flag-5'>Cortex</b>®-<b class='flag-5'>M4</b> <b class='flag-5'>内核</b>的HK32<b class='flag-5'>MCU</b>?

    STM32转AT32代码转换

    1.引言在嵌入式开发中,我们经常会遇到更换单片机芯片的事情,若芯片是同一厂家的还好说,若是不同厂家的则需要重新写,重新调,重新去学习其底层驱动程序,比较费时费力。如:ST32转AT32、ST32转
    的头像 发表于 09-28 08:09 341次阅读
    STM32转<b class='flag-5'>AT32</b>代码转换

    AT32讲堂087 | 雅特力AT32 IDE快速入门指南

    新建项目新项目向导AT32ID提供支持雅特力MCU的C语言项目模板,方便用户快速创建项目。菜单栏【File】>【New】>【CProject】。新建项目向导的对话框将出现。在对
    的头像 发表于 09-15 08:08 481次阅读
    <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的随机数生成

    概述产品和生态系统安全性的需求比以往任何时候都更加重要。真随机数是所有安全系统的核心,其质量会影响设计的安全性。因此在没有内置硬件TRNG的AT32的微控制器系列中,如何提高随机数的有效,来符合
    的头像 发表于 08-30 12:26 610次阅读
    雅特力<b class='flag-5'>AT32</b> <b class='flag-5'>MCU</b>的随机数生成

    AT32讲堂085 | 雅特力AT32 MCU HICK时钟校准

    简介AT32系列MCU内部都有提供适合运行的内部高速时钟(HICK),其本质就是内置于芯片的RC振荡器。在25℃下,其典型值频率8MHz的精度由工厂校准到±1%,在-40到105℃,该内部高速时钟
    的头像 发表于 08-30 12:26 650次阅读
    <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时钟校准

    揭幕M4内核MCU,航顺新品发布会有哪些看点?

    在物联网、智能家居和工业自动化等领域的快速发展下,航顺芯片将在7月26日的新品发布会上推出一款搭载M4内核的高性能MCU以及指纹传感器专用芯片。 对于MCU厂商来说,物联网、智能家居、
    的头像 发表于 07-25 09:50 341次阅读

    请问stm32L4是不是M4内核

    为什么L4在ucos 库里是属于 M3内核,F4系列 在ucos库里是属于 M4内核
    发表于 04-17 07:07

    东芝推出一种适用于电机控制的Arm® Cortex®-M4微控制器

    东芝电子元件及存储装置株式会社(“东芝”)今日宣布,采用Cortex®-M4内核并搭载FPU的TXZ+™族高级系列32位微控制器的M4K组新增8款新产品,闪存容量达512 KB/1 M
    的头像 发表于 03-27 10:07 769次阅读
    东芝推出一种适用于电机控制的Arm® <b class='flag-5'>Cortex</b>®-<b class='flag-5'>M4</b>微控制器

    Cortex-M85内核单片机如何快速上手

    2022年4月,Arm推出了全新的MCU内核Cortex-M85。截止目前(2024年2月),Cortex-M85是最新、最强的
    发表于 02-29 09:35 762次阅读
    <b class='flag-5'>Cortex-M</b>85<b class='flag-5'>内核</b>单片机如何快速上手

    雅特力AT32 MCU与SEGGER携手合作,开发量产事半功倍

    销售以来,基于32位ARM®-Cortex®-M4内核,推出超值型、主流型、高效能、无线型及车载型系列MCU,并即将发表M0+低功耗系列及马
    的头像 发表于 02-23 10:27 431次阅读

    高效能Cortex®-M4 &M0+MCU选型表

    设有研发、销售及威廉希尔官方网站 支持分部。雅特力坚持自主研发,以科技创新引领智慧未来,专注于ARM® Cortex®-M4/M0+的32位微控制器研发与创新,提供高效能、高可靠性且具有竞争力的产品。全系列产品采用55nm先进工艺,通过ISO
    发表于 01-29 14:10 1次下载

    强大的Arm® Cortex®-M3内核(下)

    经过前一期的芝识课堂,我们了解了东芝MCU产品所基于Arm Cortex-M3内核的基本结构和寄存器分配的细节。
    的头像 发表于 01-25 09:25 1269次阅读
    强大的Arm® <b class='flag-5'>Cortex</b>®-<b class='flag-5'>M</b>3<b class='flag-5'>内核</b>(下)

    Arm®Cortex®-M4 32位MCU GD32F303xB数据手册

    电子发烧友网站提供《Arm®Cortex®-M4 32位MCU GD32F303xB数据手册.pdf》资料免费下载
    发表于 01-14 09:54 0次下载
    Arm®<b class='flag-5'>Cortex</b>®-<b class='flag-5'>M4</b> 32位<b class='flag-5'>MCU</b> GD32F303xB数据手册

    Arm®Cortex®-M4 32位MCU GD32F303xx数据手册

    电子发烧友网站提供《Arm®Cortex®-M4 32位MCU GD32F303xx数据手册.pdf》资料免费下载
    发表于 01-14 09:49 9次下载
    Arm®<b class='flag-5'>Cortex</b>®-<b class='flag-5'>M4</b> 32位<b class='flag-5'>MCU</b> GD32F303xx数据手册

    AT32 定时器配置中pr和div的作用

    AT32定时器是51系列单片机中的一种定时器,可以实现多种定时功能。在AT32定时器中,pr和div是两个相关的参数,用于配置定时器的工作参数。 首先,需要了解pr和div分别代表什么含义。pr
    的头像 发表于 01-08 10:12 1340次阅读