搜索
bottom↓
回复: 5

【转载分享】如何使能Kinetis K64 Cortex-M4F内核的FPU功能

[复制链接]

出0入0汤圆

发表于 2015-3-27 16:00:56 | 显示全部楼层 |阅读模式
原文地址:http://blog.chinaaet.com/detail/39733
原作者: FSL_FAE_JiCheng

FPU即浮点运算单元是M4的一大特色亮点,虽然这个模块在ARM Cortex-M4内核中是一个选配,不过飞思卡尔最新的M4产品几乎都把FPU功能加进去了,毕竟没增加多少钱,而且还多了一个亮点,何乐而不为呢,呵呵。虽然加入了这个FPU会提高一定的浮点运算性能,但是具体使用中还是有些需要注意的地方,下面我简单聊聊,各位看官且瞧且珍惜,呵呵…

    我以IAR下K64的代码为例介绍使用FPU的功能的方法,准备如下:

测试平台:FRDM-K64

开发环境:IAR

例程代码:K64F120M_IAR_Sample_Code\build\iar\hello_world

1. 首先需要配置IAR的编译器,在Options->General Options->Target选项卡中,打开FPU功能即选中VFPv4,即告诉编译器,该芯片平台自带FPU功能,对浮点变量的运算尽量使用FPU的运算指令;



2. 上一步是对IAR进行了配置,但是ARM Cortex-M4内核上电默认是把该FPU的权限是关闭的(如下图,M4内核默认是禁止访问FPU的),所以造成了一种冲突,即IAR编译器把FPU相关的指令分配给浮点运算,但是内核部分却没有把这个权限打开,所以如果只配置了第一步,然后在程序里使用了浮点运算则会引起芯片的硬件错误(Hard fault),所以在程序最开始的地方需要配置M4内核寄存器CPACR,打开对FPU的访问权限,如下图:





3. 在主函数中定义并赋值浮点型变量,编译并下载到K64,进入调试环境查看反汇编窗口,可以看到带有浮点操作的指令都是前面带'v’的FPU专用指令,这样FPU就并利用起来的,至于具体FPU的performance我没有测,以后有时间找个好用的方法测试一下。



    好了,不早了,这部分就写到这了,图多文字少了点,主要是我觉着这个东西还是看图比较直接些,一下就明白了,呵呵。洗洗睡了,未完待续~

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

出0入0汤圆

 楼主| 发表于 2015-3-27 16:02:14 | 显示全部楼层
pdf文档:

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

出0入0汤圆

发表于 2015-3-28 16:18:23 | 显示全部楼层
收藏学习,K64我有。留着以后备用,谢谢搬运!

出0入0汤圆

发表于 2015-3-29 09:00:25 | 显示全部楼层
这个博主总后总习惯来上一句未完待续,后来发现是确实没有后续了。。。

出0入0汤圆

发表于 2015-3-29 10:31:15 | 显示全部楼层
不说还不知道

出0入0汤圆

发表于 2015-4-8 14:37:22 | 显示全部楼层
非常感谢你关于Kinetis的经验分享!
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-4-20 07:38

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表