嵌入式底层开发的一些细节

嵌入式底层开发的一些细节

  1. #define GPB5_out (1<<(5*2)) 移位操作,左移n位就在[n]
  2. #define GPBCON (*(volatile unsigned long *)0x56000010) 对于不同的计算机体系结构,设备可能是端口映射,也可能是内存映射的。如果系统结构支持独立的IO地址空间,并且是端口映射,就必须使用汇编语言完成实际对设备的控制,因为C语言并没有提供真正的“端口”的概念。如果是内存映射,那就方便的多了。ARM的外设就是采用内存映射。ARM嵌入式系统编程,要求程序员能够利用C语言访问固定的内存地址。既然是个地址,那么按照C语言的语法规则,这个表示地址的量应该是指针类型。
    第一步是要把它强制转换为指针类型
    比如,(volatile unsigned long *)0x56000010。volatile(可变的)这个关键字说明这变量可能会被意想不到地改变,这样编译器就不会去假设这个变量的值了。这种“意想不到地改变”,不是由程序去改变,而是由硬件去改变——意想不到。
    第二步,对指针变量解引用,就能操作指针所指向的地址的内容了
    比如,*(volatile unsigned long *)0x56000010
    第三步,把#define宏中的参数用括号括起来,这是一个很好的习惯,
    所以#define GPBCON (*(volatile unsigned long *)0x56000010)
  3. GSTATUS1寄存器为通用状态寄存器,用来描述芯片ID(标识),可以通过读取GSTATUS1寄存器的值来确定处理器的类型:
    0x32410000=S3C2410
    0x32410002=S3C2410a
    0x32440000=S3C2440
    0x32440002=S3C2440a

你可能感兴趣的:(嵌入式)