arm芯片中的浮点运算(一)

本文介绍了如何在ARM Cortex-A9芯片上启用和使用浮点运算,包括在安全和非安全模式下访问并配置FPU寄存器,如设置CPACR和FPEXC寄存器,以及在编译时添加浮点支持的选项。
摘要由CSDN通过智能技术生成

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协处理器)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值