所以在stm32f4中屏蔽 __ASM volatile ("VMSR fpscr, %0" : : "r" (fpscr) : "armcc");有什么影响
时间: 2023-10-22 16:25:05 浏览: 145
在STM32F4中,屏蔽掉__ASM volatile ("VMSR fpscr, %0" : : "r" (fpscr) : "armcc");会影响使用VFP(浮点运算器)进行浮点运算的性能。这段代码的作用是将当前的浮点状态寄存器(FPSCR)的值保存到内存中,以便在函数返回时还原浮点状态。如果屏蔽掉这段代码,浮点状态寄存器不会被保存和还原,这可能会导致浮点运算的结果不正确。此外,如果在函数调用过程中发生了浮点异常,调试器可能无法正确地定位异常的源代码行,从而增加调试的难度。因此,建议不要屏蔽这段代码,以确保浮点运算的正确性和调试的方便性。
相关问题
__ASM volatile ("VMSR fpscr, %0" : : "r" (fpscr) : "vfpcc");在v6编译器
在v6编译器中,该语句与v5编译器中的语句有所不同,因为v6编译器使用了新的指令集架构,即ARMv8-M架构。在ARMv8-M架构中,VFP指令已被废弃,取而代之的是Advanced SIMD指令集和浮点指令扩展(Floating-Point Extension,FPE)。因此,VMSR指令已经不再使用,而是使用了新的指令VMRS。
因此,在v6编译器中,将原来的VMSR指令更改为VMRS指令,修改后的语句如下所示:
```c
__ASM volatile ("VMRS fpscr, %0" : : "r" (fpscr) : "vfpcc");
```
该语句的作用是将传入的fpscr值写入FPSCR寄存器中,以配置和控制FPU的运算精度和舍入方式等。具体的操作是通过汇编指令 `VMRS fpscr, %0` 实现的,其中 `%0` 表示使用第一个输入参数(即fpscr值)替换指令中的占位符,将fpscr值写入FPSCR寄存器中。
需要注意的是,该语句中仍然使用了 `"vfpcc"` 修饰符,表示该指令依赖于VFPcc控制位的设置。这是因为在ARMv8-M架构中,VFPcc控制位已经被替换为了FPEcc控制位,但仍然可以使用VFPcc修饰符来指定FPEcc控制位的设置。
把__ASM volatile ("VMSR fpscr, %0" : : "r" (fpscr) : "vfpcc");改成gnu风格
将__ASM volatile ("VMSR fpscr, %0" : : "r" (fpscr) : "vfpcc");改成GNU风格的汇编语言可以使用如下代码:
```
__asm__ volatile ("VMSR fpscr, %0" : : "r" (fpscr) : "vfpcc");
```
其中,__asm__ 是GNU C语言中表示汇编代码的关键字,volatile表示汇编代码是具有副作用的,"VMSR fpscr, %0"是汇编代码,:表示分隔符,"r" (fpscr)表示将C语言变量fpscr传递给汇编代码,"vfpcc"表示使用vfpcc寄存器。
阅读全文