ARM编程寄存器定义
来源:互联网 发布:android软件开发项目 编辑:程序博客网 时间:2024/05/29 19:36
以32位ARM架构芯片为例,寄存器是32位的。寄存器可以直接理解为一个32位的内存,内存就是用指针来表示。ARM芯片的片内外设对应的就有一段内存,这段内存是用来定义相应的寄存器,一个寄存器占据4字节的存储单元。如下所示为lpc2148芯片头文件中寄存器定义
#define IOPIN0 (*((volatile unsigned long *) 0xE0028000))#define IOSET0 (*((volatile unsigned long *) 0xE0028004))#define IODIR0 (*((volatile unsigned long *) 0xE0028008))#define IOCLR0 (*((volatile unsigned long *) 0xE002800C))#define IOPIN1 (*((volatile unsigned long *) 0xE0028010))#define IOSET1 (*((volatile unsigned long *) 0xE0028014))#define IODIR1 (*((volatile unsigned long *) 0xE0028018))#define IOCLR1 (*((volatile unsigned long *) 0xE002801C))#define IO0PIN (*((volatile unsigned long *) 0xE0028000))#define IO0SET (*((volatile unsigned long *) 0xE0028004))#define IO0DIR (*((volatile unsigned long *) 0xE0028008))#define IO0CLR (*((volatile unsigned long *) 0xE002800C))#define IO1PIN (*((volatile unsigned long *) 0xE0028010))#define IO1SET (*((volatile unsigned long *) 0xE0028014))#define IO1DIR (*((volatile unsigned long *) 0xE0028018))
截取部分可看出来每个外设寄存器处于一段连续内存中,每个寄存器需要4个字符。嵌入式系统编程,要求程序员能够利用C语言访问固定的内存地址。既然是个地址,那么按照C语言的语法规则,这个表示地址的量应该是指针类型。所以,知道要访问的内存地址后,比如0x5F,
第一步是要把它强制转换为指针类型
(unsigned long *)0xE0028018,AVR的SREG是32位寄存器,所以0xE0028018强制转换为指向unsigned long类型。
volatile(可变的)这个关键字说明这变量可能会被意想不到地改变,这样编译器就不会去假设这个变量的值了。这种“意想不到地改变”,不是由程序去改变,而是由硬件去改变——意想不到。
第二步,对指针变量解引用,就能操作指针所指向的地址的内容了
*(volatile (unsigned long *)0xE0028018
第三步,小心地把#define宏中的参数用括号括起来,这是一个很好的习惯,所以#define IO1DIR (*(volatile(unsigned long *)0xE0028018))
阅读全文
0 0
- ARM编程寄存器定义
- ARM编程:关于ARM寄存器的宏定义
- ARM编程:关于ARM寄存器的宏定义
- ARM编程:关于ARM寄存器的宏定义
- ARM寄存器的定义
- AAPCS关于ARM寄存器的定义
- Linux下ARM寄存器映射定义
- ARM汇编编程基础(一) -- ARM CPU寄存器
- ARM汇编编程基础(一) -- ARM CPU寄存器
- ARM汇编编程基础(一) -- ARM CPU寄存器
- ARM汇编编程基础(一) -- ARM CPU寄存器
- ARM汇编编程基础(一) -- ARM CPU寄存器
- ARM定义特殊寄存器(*(volatile unsigned long *))的理解
- ARM定义特殊寄存器(*(volatile unsigned long *))的理解
- 转:ARM定义特殊寄存器(*(volatile unsigned long *))的理解 .
- ARM子函数定义中的参数放入寄存器的规则
- ARM定义特殊寄存器(*(volatile unsigned long *))的理解
- ARM定义特殊寄存器(*(volatile unsigned long *))的理解
- Codeforces Round#218(Div.2) C. Hamburgers
- 交换排序
- 14. 对象组合
- 核方法原理
- Binder通信机制原理解析
- ARM编程寄存器定义
- 被时间遗忘的角落
- 119. Pascal's Triangle II
- 数论——斐波那契练习题二——斐波那契变式
- NLP之Stanford Parser using NLTK
- 贝叶斯(01) 初识贝叶斯
- 蓝桥杯 基础练习 十六进制转八进制
- cin、cin.get()、cin.getline()、getline()、gets()等函数的用法
- ThreadLocal-单例模式下高并发线程安全