|
发表于 2013-5-15 21:35:41
|
显示全部楼层
BitBand位带,最早知道这个位带的概念是在阅读正点原子大哥的STM32开发板手册里,然后顺着指引查看了CM3权威指南的相关部分,对位带有了大体的认识,LPC1768也是CM3内核的,和STM32有相同之处。这个位带其实在51单片机里面已经用了,操作起来还是很方便的,以前我们对一个寄存器的单个位操作是,通常的作法是先把这个寄存器读回来,然后再修改相应的位,最后在写回去,有了位带操作后,我们可以直接操作这个位。
关于位带操作的GPIO的速度:经过三牛的测试,位带的操作速度,比直接操作整个IO口寄存器快45%左右,这个是用示波器直接测出来,可能和理论上有偏差。
LPC1768的CPU时钟100M,直接操作寄存器IO口输出为6.25Mhz,通过位带操作11.2Mhz,因为用的是C语言,这个速度这数据手册上有很大差别,这里仅仅是说明通过位带操作比直接操作要快。
看看位带操作的一些宏定义,这个是从正点原子那里修改而来的
//位带操作,实现51类似的GPIO控制功能
//具体实现思想,参考<<CM3权威指南>>第五章(87页~92页).
//IO口操作宏定义
#define BITBAND(addr, bitnum) ((addr & 0xF0000000)+0x2000000+((addr &0xFFFFF)<<5)+(bitnum<<2))
#define MEM_ADDR(addr) *((volatile unsigned long *)(addr))
#define BIT_ADDR(addr, bitnum) MEM_ADDR(BITBAND(addr, bitnum))
//IO口地址映射
//FIOPIN 地址,这里LPC1768和STM32有点不一样,
//LPC1768的 FIOPIN 直接反映端口的状态,不分输入还是输出
#define GPIO0_FIOPIN (LPC_GPIO0_BASE + 0x00014)
#define GPIO1_FIOPIN (LPC_GPIO1_BASE + 0x00014)
#define GPIO2_FIOPIN (LPC_GPIO2_BASE + 0x00014)
#define GPIO3_FIOPIN (LPC_GPIO3_BASE + 0x00014)
#define GPIO4_FIOPIN (LPC_GPIO4_BASE + 0x00014)
#define GPIO0(n) BIT_ADDR(GPIO0_FIOPIN,n)
#define GPIO1(n) BIT_ADDR(GPIO1_FIOPIN,n)
#define GPIO2(n) BIT_ADDR(GPIO2_FIOPIN,n)
#define GPIO3(n) BIT_ADDR(GPIO3_FIOPIN,n)
#define GPIO4(n) BIT_ADDR(GPIO4_FIOPIN,n)
#define LED0 GPIO3(25)
于是我们控制LED0就可以这样些了
#define LED0_ON() LED0 = 0;//低电平LED亮
#define LED0_OFF() LED0 = 1;//高电平LED灭
和51单片机一样操作啦
三牛电子工作室:http://www.sanliu85.com/ |
|