当前位置: 首页 > news >正文

【ARM 嵌入式 C 入门及渐进 6.1 -- ARMv8 C 内嵌汇编写系统寄存器的函数实现】


请阅读【嵌入式开发学习必备专栏】


文章目录

    • ARMv8 C 内嵌汇编写系统寄存器

ARMv8 C 内嵌汇编写系统寄存器

在ARMv8架构下,使用C语言结合内嵌汇编实现将一个值写入特定系统寄存器的函数可以按照下面的方法进行。

下面这个示例展示了如何将一个uint64_t类型的值写入到系统寄存器 s3_0_c15_c5_5中。

首先,要让C代码能够直接与寄存器交互,我们需要使用内嵌汇编(inline assembly)。ARM的内嵌汇编语法可以在GCC编译器中使用,它允许直接从C代码中执行汇编指令。

下面是一个简单的system_write_reg函数实现,该函数接受一个uint64_t类型的参数val,然后将这个值写入到s3_0_c15_c5_5寄存器中:

#include <stdint.h>void system_write_reg(uint64_t val) 
{asm volatile("msr s3_0_c15_c5_5, %0" // 使用msr指令写入寄存器: // 没有输出操作数: "r" (val) // 输入操作数,%0与val变量对应: // 没有破坏的寄存器列表);
}

解释:

  1. asm 关键字用于标记内嵌汇编的开始,而volatile告诉编译器不要优化这段代码,因为它可能会改变程序状态或者被程序状态所改变。
  2. "msr s3_0_c15_c5_5, %0" 是汇编指令,其中msr(Move to System Register)用于将值写入系统寄存器,s3_0_c15_c5_5是目标寄存器的名称,%0表示这行汇编代码中的第一个输入(在这个例子中,是val)。
  3. 输出部分(紧接在第一个冒号之后)在这个例子中是空的,因为我们没有向C代码返回任何值。
  4. 输入部分(第二个冒号之后)指定了我们的输入操作数。这里我们指定了"r" (val),意味着使用一个通用寄存器来存储val的值,并在汇编指令中通过%0引用它。
  5. 第三个冒号后面通常会跟着一个列表,指定了这段汇编代码可能会修改的寄存器,作为一种告知编译器的手段,以避免潜在的寄存器值冲突。在这个例子中,我们没有列出任何寄存器,因为msr指令的影响已经很明确了。

请注意,在实际的系统编程或驱动开发中,直接操作系统寄存器通常需要具备相应权限和确保与操作系统的兼容性,特别是在嵌入式系统或特定硬件平台上。确保你了解这些操作的后果,并在需要时获取相应的权限。

http://www.lryc.cn/news/351037.html

相关文章:

  • ESP32基础应用之使用手机浏览器作为客户端与ESP32作为服务器进行通信
  • 【课后练习分享】Java用户注册界面设计和求三角形面积的图形界面程序
  • 三维空间坐标系变换(旋转平移)
  • OC笔记之foundation框架
  • Docker部署springboot包并联通MySQL
  • 多帧激光点云基于标定参数进行融合拼接
  • python数据类型之字符串
  • Vue3实战笔记(38)—粒子特效终章
  • 晶体振荡器
  • 单词可交互的弧形文本
  • Linux——进程信号(一)
  • centos9 stream在线安装NVIDIA驱动(rockylinux9.4也成功安装nvidia驱动)
  • springmvc不同格式的参数解析
  • Unity3D让BoxCollider根据子物体生成自适应大小
  • WSL 2 installation is incomplete.
  • Servlet的request对象
  • 蓝桥杯-合并数列
  • 《web应用技术》第9次课后作业
  • FRAUDARCatchSync算法简介
  • 刷题之将有序数组转换成二叉搜索树(leetcode)
  • K-means聚类模型教程(个人总结版)
  • android怎么告诉系统不要回收
  • 【FAQ】HarmonyOS SDK 闭源开放能力 —IAP Kit(2)
  • ubuntu设置root开机登录,允许root用户ssh远程登录
  • Web测试面试题(二)
  • VBA宏指令写的方法突然不能用了
  • 第13章 Python建模库介绍
  • IP学习——ospf1
  • 别说废话!说话说到点上,项目高效沟通的底层逻辑揭秘
  • 前后端编程语言和运行环境的理解