arm芯片中的浮点运算(一)
arm芯片中的浮點運算(一)
https://blog.csdn.net/yuanlu837/article/details/7742324
2012年07月12日 23:40:00?yuanlu837?閱讀數 3882
1、訪問FPU寄存器
訪問FPU寄存器是通過控制CORTEX-A9的兩個系統控制協處理器寄存器來實現的
非安全模式下訪問控制寄存器(NSACR)
協處理器訪問控制寄存器(CPACR)
?
只在安全模式下使用FPU:
要在安全狀態下使用FPU,必須定義CPACR和FPEXC寄存器來使能FPU模塊
FPEXC:浮點意外寄存器
1)設置CPACR訪問CP10和CP11(FPU協處理器)
LDR r0, =(0xF << 20)
MCR p15,0,r0,c1,c0,2
2)設置FPEXC的EN位來使能FPU
MOV r3,#0x40000000
VMSR FPEXC,r3
?
在非安全模式和安全模式下使用FPU:
在安全和非安全模式下使用FPU,必須定義NSACR、CPACR、FPEXC寄存器
1)設置NSACR寄存器的bits[11:10]位,用來訪問CP10和CP11,從安全和非安全模式下:
MCR?? p15,0,r0,c1,c1,2
ORR r0,r0,#2_11<<10;? enable fpu/neon
MCR p15,0,r0,c1,c1,2
2)設置?CPACR訪問CP10和CP11(FPU協處理器)
LDR r0,=(0xF<<20)
MCR p15, 0, r0, c1, c0, 2
3)設置FPEXC的EN位來使能FPU
MOV r3,? #0x40000000
VMSR? FPEXC,? r3
?
以下是針對ARM芯片運行裸機程序的說明
?
如何運行浮點類的運算呢:
1、首先需要打開ARM芯片上的FPU模塊
2、編譯選項要把FPU的特性加上,例如CFLAGS=???? -mfloat-abi=hard?????? -mfpu=vfpv3
總結
以上是生活随笔為你收集整理的arm芯片中的浮点运算(一)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 论文阅读|训练过程中动态改变训练方案的D
- 下一篇: Mongodb 2