《嵌入式Linux与物联网软件开发——C语言内核深度解析》一2.3 位操作与寄存器

简介:

本节书摘来自异步社区《嵌入式Linux与物联网软件开发——C语言内核深度解析》一书中的第2章,第2.3节,作者朱有鹏 , 张先凤,更多章节内容可以访问云栖社区“异步社区”公众号查看。

2.3 位操作与寄存器

2.3.1 寄存器的操作

一般来说,一个SOC片内外设由若干个寄存器控制,IO操作的寄存器与内存统一编址,如果我们要操作片内外设,那么就是操作片内外设的控制寄存器。因此,控制硬件就是读写寄存器(寄存器亦可理解为特定地址的内存)。

SOC中一个寄存器的数据宽度一般是32bit,每个bit可以配置为0或者1,单个bit或相邻几个bit一起控制片上外设某个属性的状态。单个bit最多控制两种状态,三个bit最多控制8种状态。因此寄存器的特定bit配置为0或1,就可以实现对硬件的控制。

然而,CPU对寄存器读写一般都是按照寄存器的数据宽度一起读写(部分寄存器可以按照位读取,这里不讨论),即32bit读出,32bit写入。假设我们只想修改寄存器其中某个属性的状态,即修改寄存器特定位。那么就只能先整体读出来,然后将需要修改的部分修改后,再将修改后的值整体写入寄存器中,即读-改-写三部曲。并且我们只能修改需要修改的位,不能影响其他位。对寄存器特定位的操作分三种情况:清零、置1和取反。

2.3.2 寄存器特定位清零用&

如果希望将一个寄存器的某些特定位变成0而不影响其他位,可以构造一个合适的1和0组成的数,和这个寄存器原来的值进行位与操作,就可以将特定位清零。假设原来32位寄存器REG1中的值为0xAAAAAAAA,我们希望将bit8~bit15清零而其他位不变,将这个数与0xFFFF00FF进行位与即可。

REG1 &= 0xFFFF00FF;
AI 代码解读

经过上式的读-改-写后,REG1中的值为0xAAAA00AA,达到了特定位清零的目的。

2.3.3 寄存器特定位置1用|

如果希望将一个寄存器的某些特定位变成1而不影响其他位,可以构造一个合适的1和0组成的数,和这个寄存器原来的值进行位或操作,就可以将特定位置1。假设原来32位寄存器REG1中的值为0xAAAA00AA,我们希望将bit8~bit15置1而其他位不变,将这个数与0X0000FF00进行位或即可。

REG1 |= 0x0000FF00;
AI 代码解读

经过上式的读-改-写后,REG1中的值为0xAAAAFFAA,达到了特定位置1的目的。

2.3.4 寄存器特定位取反用~

如果希望将一个寄存器的某些特定位0变成1,而1变成0,即取反而不影响其他位,可以构造一个合适的1和0组成的数,和这个寄存器原来的值进行位异或操作,就可以将特定位取反。假设原来32位寄存器REG1中的值为0xAAAAAAAA,我们希望将bit8~bit15取反而其他位不变,将这个数与0X0000FF00进行位异或即可。

REG1 ^= 0x0000FF00;
AI 代码解读

经过上式的读-改-写后,REG1中的值为0xAAAA55AA,达到了特定位取反的目的。

学完本节,你会发现配置寄存器操作并没有想象的那么难,只要我们学会设置位操作的特定的构造数就行了。上面举的例子是bit8~bit15,很好算。但如果要构造一个bit1、bit3~bit5、bit15~bit17位为1的数。傻眼了?一步步来,先用二进制挨个排列好0011 1000 0000 0011 1010,再换算成十六进制0X0003803A,总算算出来了。是不是非要这么麻烦呢?我们既然已经学习了位运算,能不能用位运算构建一个构造数呢?

相关实践学习
钉钉群中如何接收IoT温控器数据告警通知
本实验主要介绍如何将温控器设备以MQTT协议接入IoT物联网平台,通过云产品流转到函数计算FC,调用钉钉群机器人API,实时推送温湿度消息到钉钉群。
阿里云AIoT物联网开发实战
本课程将由物联网专家带你熟悉阿里云AIoT物联网领域全套云产品,7天轻松搭建基于Arduino的端到端物联网场景应用。 开始学习前,请先开通下方两个云产品,让学习更流畅: IoT物联网平台:https://iot.console.aliyun.com/ LinkWAN物联网络管理平台:https://linkwan.console.aliyun.com/service-open
目录
打赏
0
0
0
0
1819
分享
相关文章
Linux内核中的线程和进程实现详解
了解进程和线程如何工作,可以帮助我们更好地编写程序,充分利用多核CPU,实现并行计算,提高系统的响应速度和计算效能。记住,适当平衡进程和线程的使用,既要拥有独立空间的'兄弟',也需要在'家庭'中分享和并行的成员。对于这个世界,现在,你应该有一个全新的认识。
118 67
|
2天前
|
Linux内核中的current机制解析
总的来说,current机制是Linux内核中进程管理的基础,它通过获取当前进程的task_struct结构的地址,可以方便地获取和修改进程的信息。这个机制在内核中的使用非常广泛,对于理解Linux内核的工作原理有着重要的意义。
23 11
Linux 内核源码分析---proc 文件系统
`proc`文件系统是Linux内核中一个灵活而强大的工具,提供了一个与内核数据结构交互的接口。通过本文的分析,我们深入探讨了 `proc`文件系统的实现原理,包括其初始化、文件的创建与操作、动态内容生成等方面。通过对这些内容的理解,开发者可以更好地利用 `proc`文件系统来监控和调试内核,同时也为系统管理提供了便利的工具。
67 16
Android调试终极指南:ADB安装+多设备连接+ANR日志抓取全流程解析,覆盖环境变量配置/多设备调试/ANR日志分析全流程,附Win/Mac/Linux三平台解决方案
ADB(Android Debug Bridge)是安卓开发中的重要工具,用于连接电脑与安卓设备,实现文件传输、应用管理、日志抓取等功能。本文介绍了 ADB 的基本概念、安装配置及常用命令。包括:1) 基本命令如 `adb version` 和 `adb devices`;2) 权限操作如 `adb root` 和 `adb shell`;3) APK 操作如安装、卸载应用;4) 文件传输如 `adb push` 和 `adb pull`;5) 日志记录如 `adb logcat`;6) 系统信息获取如屏幕截图和录屏。通过这些功能,用户可高效调试和管理安卓设备。
自学esb32烧录进军物联网和嵌入式
自学esb32烧录进军物联网和嵌入式
深入解析:Linux网络配置工具ifconfig与ip命令的全面对比
虽然 `ifconfig`作为一个经典的网络配置工具,简单易用,但其功能已经不能满足现代网络配置的需求。相比之下,`ip`命令不仅功能全面,而且提供了一致且简洁的语法,适用于各种网络配置场景。因此,在实际使用中,推荐逐步过渡到 `ip`命令,以更好地适应现代网络管理需求。
98 11
深入解析操作系统控制台:阿里云Alibaba Cloud Linux(Alinux)的运维利器
本文将详细介绍阿里云的Alibaba Cloud Linux操作系统控制台的功能和优势。
148 6
Intel Linux 内核测试套件-LKVS介绍 | 龙蜥大讲堂104期
《Intel Linux内核测试套件-LKVS介绍》(龙蜥大讲堂104期)主要介绍了LKVS的定义、使用方法、测试范围、典型案例及其优势。LKVS是轻量级、低耦合且高代码覆盖率的测试工具,涵盖20多个硬件和内核属性,已开源并集成到多个社区CICD系统中。课程详细讲解了如何使用LKVS进行CPU、电源管理和安全特性(如TDX、CET)的测试,并展示了其在实际应用中的价值。
Ubuntu20.04搭建嵌入式linux网络加载内核、设备树和根文件系统
使用上述U-Boot命令配置并启动嵌入式设备。如果配置正确,设备将通过TFTP加载内核和设备树,并通过NFS挂载根文件系统。
199 15
深入探索Linux内核调度器:公平与效率的平衡####
本文通过剖析Linux内核调度器的工作机制,揭示了其在多任务处理环境中如何实现时间片轮转、优先级调整及完全公平调度算法(CFS),以达到既公平又高效地分配CPU资源的目标。通过对比FIFO和RR等传统调度策略,本文展示了Linux调度器如何在复杂的计算场景下优化性能,为系统设计师和开发者提供了宝贵的设计思路。 ####
99 26

物联网

+关注

相关产品

  • 物联网平台
  • AI助理

    你好,我是AI助理

    可以解答问题、推荐解决方案等