#define GPFCON (* (volatile unsigned long * )0x56000050 )

int   a;
int   *p;
p   = &a;
*p = 0x100;   //a=0x100

p   = (int *)0x56000050;
*p =0x100;
*(  ( int * ) 0x56000050) = 0x100

加上volatile是为了防止编译器优化这个寄存器

#define GPBCON (*(volatile unsigned long *)0x56000010)
#define GPBDAT (*(volatile unsigned long *)0x56000014)

#define GPB5_out (1<<(5*2))
#define GPB6_out (1<<(6*2))
#define GPB7_out (1<<(7*2))
#define GPB8_out (1<<(8*2))

GPBCON = GPB5_out | GPB6_out | GPB7_out | GPB8_out;

时间: 2024-10-10 06:12:58

#define GPFCON (* (volatile unsigned long * )0x56000050 )的相关文章

C语言之强制类型转换与指针--#define DIR *((volatile unsigned int *) 0x0022)

强制类型转换形式:(类型说明符) (表达式) 举例说明:1) int a; a = (int)1.9; 2)char *b; int *p; p = (int *) b; //将b的值强制转换为指向整型数据的指针类型,后赋给p 注示:类型说明符和表达式都必须加括号,表达式为单个变量可不加括号. 总结:只要看到(类型说明符) (表达式) 的一定为强制类型转换:如(int *) 0x0022; 再举一例:#define DIR *((volatile unsigned int *) 0x0022)

(*(volatile unsigned long *)详解

(*(volatile unsigned long *) 对于不同的计算机体系结构,设备可能是端口映射,也可能是内存映射的.如果系统结构支持独立的IO地址空间,并且是端口映射,就必须使用汇编语言完成实际对设备的控制,因为C语言并没有提供真正的"端口"的概念.如果是内存映射,那就方便的多了. 以 #define IOPIN (*((volatile unsigned long *) 0xE0028000)) 为例:作为一个宏定义语句,define是定义一个变量或常量的伪指令.首先( vo

指针之 *((volatile unsigned long *)(x))解析

今天重新温习了一下C语言的指针部分,突然想到了经常会碰见的一种宏定义:#define PGAS (*((volatile unsinged long *)(x))) 在解析该宏定义前,先看看指针变量的声明 声明一个int类型的指针变量:int* p; 仅仅是这样定义,这个指针是不能够直接拿来使用的,还必须给它赋值(初始化),例如: int a = 10; int* p = &a; 或: int a = 10; int* p; p = &a; 其中,&a表示变量a所代表的内存地址,所

嵌入式开发中对(*(volatile unsigned long *)) 的理解

一.说明 (*(volatile unsigned long *)) 这个语句对于不同的计算机体系结构,设备可能是端口映射,也可能是内存映射的.如果系统结构支持独立的IO地址空间,并且是端口映射,就必须使用汇编语言完成实际对设备的控制,因为C语言并没有提供真正的"端口"的概念.如果是内存映射,那就方便多了. 二.举例讲解 以 #define IOPIN (*((volatile unsigned long *)0xE0028000))为例: 作为一个宏定义语句,define是定义一个变

volatile 和const 变量的使用

一.volatile定义: 一个定义为volatile的变量是说这变量可能会被意想不到的被改变,这样,有了volatile变量后,就提醒编译器就不会去假设这个变量的值了.精确地说就是,编译中的优化器在用到这个变量时必须每次都小心地重新读取这个变量的值,而不是使用保存在寄存器里的备份. eg: 1.硬件设备的寄存器(如:状态寄存器) #define GPFCON (*(volatile unsigned long *)0x56000050) 2.一个中断服务子程序中会访问到的非自动变量(Non-a

嵌入式学习笔记008-裸奔篇之串口

串口是个好东西,前几篇裸奔程序由于没有串口,自己调试都是有led等来表示的,比较"苦逼",终于可以用串口了~~~,这里主要采用上一篇博文(嵌入式学习笔记007-裸奔篇之定时器),也就是串口也是用中断实现的,而且也只是在前一篇博文增加串口的初始化uart0_init(),以及在中断处理函数增加对串口的处理.只要稍微改造前一篇博文就是一个通用的中断处理程序! 这里主要实现在串口输入一个字符,接受后+2再发送到串口,所以在串口输入a 会返回c---. 由于code都有相应的注释,读者自行查看

嵌入式学习笔记007-裸奔篇之定时器

s3c2440的定时器比较简单,这里主要借鉴韦东山老是的code加以改造一下,一个是对head.S的flow改善,另一个是设置FCLK=400MHZ,比例为1:4:8,试过将SDRAM的HCLK=200MHZ,发现不work,查看我的SDRAM是HY57V561620FLT-H clock = 133MHZ,故设置为100MHZ. 基本上看code及注释应该了解了,就不过多解释了,共有7个文件,如下: head.S init.c interrupt.c main.c Makefile s3c24

实验六--中断

一.环境 开发板:jz2440 系统:  ubuntu12.04 编译器:arm-linux-gcc 二.中断系统 先省下. 三.直接贴代码 Makefile: 1 objs := head.o init.o interrupt.o main.o 2 3 int.bin: $(objs) 4 arm-linux-ld -Ttext 0x00000000 -o int_elf $^ 5 arm-linux-objcopy -O binary -S int_elf [email protected]

ARM--存储管理器

初入领悟: 1. bank.L-bank的概念 2. s3c2440内部管理SDRAM寄存器配置 Frist part:原理分析 S3c2440为32位微处理器,其可访问空间为4G:但其中提供1G外设访问空间,这1G空间有8个bank组成:及平均每个bank有128M的访问空间:其中8bank的特性为: 1. bank0~bank5支持外接SRAM.ROM等,bank6.bank7支持外接SRAM.ROM与SDRAM等: 2. bank0~bank6的起始地址是固定 3. bank7的起始地址可